
    :root {
      --bg: #f5f5f7;
      --bg-alt: #ffffff;
      --card: #ffffff;
      --border-soft: #e5e7eb;
      --border-strong: #d1d5db;
      --text-main: #111827;
      --text-soft: #4b5563;
      --accent: #f97316;  /* Eyetrosoft orange, slightly lighter */
      --accent-soft: rgba(249, 115, 22, 0.1);
      --accent-strong: #ea580c;
      --pill-bg: #111827;
      --radius-lg: 18px;
      --shadow-soft: 0 18px 40px rgba(15, 23, 42, 0.16);
    }

    *,
    *::before,
    *::after {
      box-sizing: border-box;
    }

    body {
      margin: 0;
      padding: 0;
      font-family: system-ui, -apple-system, BlinkMacSystemFont, "SF Pro Text",
        "Segoe UI", sans-serif;
      background: radial-gradient(circle at top, #ffffff 0, #f5f5f7 45%, #e5e7eb 100%);
      color: var(--text-main);
    }

    .page {
      max-width: 1240px;
      margin: 0 auto;
      padding: 20px 16px 40px;
    }

    header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      margin-bottom: 18px;
    }

    .brand {
      display: flex;
      align-items: center;
      gap: 10px;
    }

    .brand-mark {
      width: 56px;
      height: 56px;
      border-radius: 0;
      border: none;
      display: flex;
      align-items: center;
      justify-content: center;
      background: transparent;
      overflow: hidden;
      flex: 0 0 auto;
    }

    .brand-mark img {
      width: 100%;
      height: 100%;
      object-fit: contain;
      display: block;
    }

    .brand-text {
      display: flex;
      flex-direction: column;
    }

    .brand-text span:first-child {
      font-size: 0.75rem;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      color: var(--text-soft);
    }

    .brand-text span:last-child {
      font-size: 1.1rem;
      font-weight: 600;
      color: var(--text-main);
    }

    .build-tag {
      font-size: 0.75rem;
      padding: 6px 10px;
      border-radius: 999px;
      border: 1px solid var(--border-soft);
      background: rgba(255,255,255,0.9);
      color: var(--text-soft);
      display: inline-flex;
      align-items: center;
      gap: 6px;
      white-space: nowrap;
    }

    .build-dot {
      width: 6px;
      height: 6px;
      border-radius: 50%;
      background: var(--accent);
    }

    .hero {
      background: radial-gradient(circle at top, #ffffff 0, #f5f5f7 60%, #e5e7eb 100%);
      border-radius: 26px;
      padding: 22px 22px 18px;
      box-shadow: var(--shadow-soft);
      border: 1px solid rgba(209, 213, 219, 0.8);
      margin-bottom: 20px;
    }

    .hero-title {
      font-size: clamp(1.5rem, 3vw, 2.1rem);
      font-weight: 700;
      margin-bottom: 4px;
    }

    .hero-sub {
      font-size: 0.9rem;
      color: var(--text-soft);
      max-width: 640px;
    }

    .hero-sub span {
      font-weight: 500;
      color: var(--accent-strong);
    }

    .hero-row {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
    }

    .hero-pills {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-top: 12px;
    }

    .hero-pill {
      font-size: 0.78rem;
      padding: 4px 10px;
      border-radius: 999px;
      border: 1px solid var(--border-soft);
      background: rgba(255,255,255,0.9);
      display: inline-flex;
      align-items: center;
      gap: 6px;
      color: var(--text-soft);
    }

    .hero-pill strong {
      font-weight: 600;
      color: var(--text-main);
    }

    .tab-bar {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-bottom: 14px;
    }

    .tab-btn {
      border-radius: 999px;
      border: 1px solid transparent;
      background: rgba(255,255,255,0.9);
      padding: 7px 14px;
      font-size: 0.85rem;
      display: inline-flex;
      align-items: center;
      gap: 6px;
      cursor: pointer;
      color: var(--text-soft);
      transition: background 0.15s ease, border-color 0.15s ease,
        transform 0.05s ease, box-shadow 0.15s ease, color 0.15s ease;
      box-shadow: 0 1px 3px rgba(15, 23, 42, 0.12);
      backdrop-filter: blur(10px);
    }

    .tab-btn span.icon {
      font-size: 1.05rem;
    }

    .tab-btn.active {
      background: linear-gradient(135deg, var(--accent), var(--accent-strong));
      color: #ffffff;
      border-color: rgba(0,0,0,0.05);
      box-shadow: 0 10px 25px rgba(0, 0, 0, 0.22);
    }

    .tab-btn:active {
      transform: scale(0.97);
    }

    .panel {
      display: none;
      background: var(--bg-alt);
      border-radius: 22px;
      padding: 18px 18px 20px;
      border: 1px solid var(--border-soft);
      box-shadow: 0 14px 32px rgba(15, 23, 42, 0.1);
      margin-bottom: 20px;
    }

    .panel.active {
      display: block;
    }

    .panel-header {
      display: flex;
      align-items: baseline;
      justify-content: space-between;
      gap: 10px;
      margin-bottom: 10px;
    }

    .panel-title {
      font-size: 1rem;
      letter-spacing: 0.16em;
      text-transform: uppercase;
      color: var(--text-soft);
      font-weight: 600;
    }

    .panel-sub {
      font-size: 0.85rem;
      color: var(--text-soft);
      max-width: 520px;
    }

    .panel-sub strong {
      color: var(--accent-strong);
      font-weight: 600;
    }

    .grid-2 {
      display: grid;
      grid-template-columns: minmax(0, 1.05fr) minmax(0, 1.35fr);
      gap: 16px;
    }

    @media (max-width: 900px) {
      .grid-2 {
        grid-template-columns: minmax(0, 1fr);
      }
    }

    .field-label {
      font-size: 0.78rem;
      text-transform: uppercase;
      letter-spacing: 0.16em;
      color: var(--text-soft);
      margin-bottom: 4px;
    }

    textarea,
    input[type="text"],
    select {
      width: 100%;
      font-family: inherit;
      font-size: 0.9rem;
      padding: 9px 11px;
      border-radius: 12px;
      border: 1px solid var(--border-soft);
      background: #f9fafb;
      color: var(--text-main);
      resize: vertical;
      min-height: 44px;
    }

    textarea {
      min-height: 140px;
      white-space: pre;
    }

    textarea:focus,
    input[type="text"]:focus,
    select:focus {
      outline: none;
      border-color: var(--accent);
      box-shadow: 0 0 0 1px rgba(249, 115, 22, 0.3);
      background: #ffffff;
    }

    .btn-primary {
      border-radius: 999px;
      border: none;
      padding: 10px 18px;
      background: linear-gradient(135deg, var(--accent), var(--accent-strong));
      color: #ffffff;
      font-size: 0.9rem;
      font-weight: 500;
      display: inline-flex;
      align-items: center;
      gap: 8px;
      cursor: pointer;
      box-shadow: 0 12px 25px rgba(249, 115, 22, 0.35);
      transition: transform 0.05s ease, box-shadow 0.15s ease, opacity 0.15s ease;
    }

    .btn-primary:disabled {
      opacity: 0.65;
      cursor: default;
      box-shadow: none;
    }

    .btn-primary:active {
      transform: scale(0.97);
      box-shadow: 0 4px 12px rgba(249, 115, 22, 0.3);
    }

    .btn-secondary {
      border-radius: 999px;
      border: 1px solid var(--border-soft);
      padding: 9px 14px;
      background: #ffffff;
      color: var(--text-soft);
      font-size: 0.85rem;
      display: inline-flex;
      align-items: center;
      gap: 6px;
      cursor: pointer;
    }

    .status-line {
      font-size: 0.78rem;
      color: var(--text-soft);
      margin-top: 6px;
    }

    .status-line strong {
      color: var(--accent-strong);
    }

    .results-column {
      display: flex;
      flex-direction: column;
      gap: 10px;
      max-height: 520px;
      overflow-y: auto;
      padding-right: 4px;
    }

    .card {
      background: #ffffff;
      border-radius: 16px;
      border: 1px solid var(--border-soft);
      padding: 10px 12px 12px;
      box-shadow: 0 6px 16px rgba(15, 23, 42, 0.06);
      display: flex;
      flex-direction: column;
      gap: 6px;
    }

    .card-top {
      display: flex;
      justify-content: space-between;
      align-items: baseline;
      gap: 8px;
    }

    .card-title {
      font-size: 0.95rem;
      font-weight: 600;
      color: var(--text-main);
    }

    .card-subtitle {
      font-size: 0.8rem;
      color: var(--text-soft);
    }

    .badges-row {
      display: flex;
      flex-wrap: wrap;
      gap: 6px;
      font-size: 0.74rem;
    }

    .badge {
      padding: 3px 8px;
      border-radius: 999px;
      border: 1px solid var(--border-soft);
      background: #f9fafb;
      color: var(--text-soft);
      display: inline-flex;
      align-items: center;
      gap: 4px;
    }

    .badge-pill {
      border-radius: 999px;
    }

    
    .date-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
    .date-row input{min-width:160px}
    .badge-btn{cursor:pointer;user-select:none}
    .badge-btn:hover{filter:brightness(0.98)}
    .badge-btn:active{transform:translateY(1px)}
    .hint-inline{font-size:0.8rem;color:var(--text-soft);margin-top:6px}

.badge-source {
      background: var(--pill-bg);
      color: #ffffff;
      border-color: transparent;
    }

    .badge-sentiment-positive {
      background: rgba(22, 163, 74, 0.08);
      border-color: rgba(22, 163, 74, 0.3);
      color: #15803d;
    }

    .badge-sentiment-neutral {
      background: rgba(148, 163, 184, 0.08);
      border-color: rgba(148, 163, 184, 0.4);
      color: #4b5563;
    }

    .badge-sentiment-negative {
      background: rgba(220, 38, 38, 0.08);
      border-color: rgba(220, 38, 38, 0.4);
      color: #b91c1c;
    }

    .card-snippet {
      font-size: 0.82rem;
      color: var(--text-soft);
      line-height: 1.45;
      max-height: 90px;
      overflow: hidden;
    }

    .card-snippet.has-page-extracts {
      max-height: 320px;
      overflow: auto;
      padding-right: 4px;
    }

    .doc-extracts {
      display: flex;
      flex-direction: column;
      gap: 8px;
      margin-top: 8px;
    }

    .doc-extracts-head {
      display: flex;
      justify-content: space-between;
      gap: 8px;
      align-items: baseline;
      flex-wrap: wrap;
      font-size: 0.78rem;
      color: var(--text-soft);
    }

    .doc-extract-page {
      border: 1px solid var(--border-soft);
      border-radius: 8px;
      background: rgba(255,255,255,0.78);
      padding: 8px 10px;
    }

    .doc-extract-page-title {
      font-size: 0.78rem;
      font-weight: 700;
      color: var(--text);
      margin-bottom: 6px;
    }

    .doc-extract-item {
      font-size: 0.8rem;
      line-height: 1.45;
      color: var(--text-soft);
      margin-top: 5px;
      overflow-wrap: anywhere;
    }

    .doc-extract-item:first-child {
      margin-top: 0;
    }

    .doc-extract-keyword {
      font-weight: 700;
      color: var(--accent-strong);
    }

    .doc-extract-divider {
      padding: 0 4px;
      color: var(--text-soft);
    }

    .card-footer {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 8px;
      margin-top: 4px;
    }

    .card-footer a {
      font-size: 0.8rem;
      color: var(--accent-strong);
      text-decoration: none;
      display: inline-flex;
      align-items: center;
      gap: 4px;
    }

    .card-footer a:hover {
      text-decoration: underline;
    }

    .meta-line {
      font-size: 0.75rem;
      color: var(--text-soft);
    }

    .progress-outer {
      width: 100%;
      border-radius: 999px;
      border: 1px solid var(--border-soft);
      height: 8px;
      overflow: hidden;
      background: #f3f4f6;
      margin-top: 4px;
    }

    .progress-inner {
      height: 100%;
      width: 0%;
      background: linear-gradient(90deg, var(--accent), var(--accent-strong));
      transition: width 0.25s ease;
    }

    .section-footer {
      margin-top: 8px;
      font-size: 0.8rem;
      color: var(--text-soft);
    }

    .reporting-panel {
      background: #ffffff;
      border-radius: 22px;
      padding: 18px 18px 20px;
      border: 1px solid var(--border-soft);
      box-shadow: 0 10px 26px rgba(15,23,42,0.08);
    }

    .report-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
      gap: 12px;
      margin-top: 6px;
    }

    .report-card {
      border-radius: 16px;
      border: 1px solid var(--border-soft);
      padding: 10px 12px;
      background: #f9fafb;
      font-size: 0.82rem;
      display: flex;
      flex-direction: column;
      gap: 4px;
    }

    .report-card h4 {
      margin: 0;
      font-size: 0.86rem;
      font-weight: 600;
      color: var(--text-main);
    }

    .emoji-cloud {
      margin-top: 4px;
      font-size: 1.1rem;
    }

    .export-row {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      align-items: center;
      margin-top: 10px;
    }

    @media (max-width: 640px) {
      header {
        flex-direction: column;
        align-items: flex-start;
      }
      .hero-row {
        flex-direction: column;
        align-items: flex-start;
      }
      .results-column {
        max-height: none;
      }
    }
  
    .api-status-strip {
      margin-top: 24px;
      padding: 16px 18px;
      border-radius: 18px;
      background: linear-gradient(135deg, rgba(15,23,42,0.96), rgba(15,23,42,0.99));
      border: 1px solid rgba(148, 163, 184, 0.4);
      box-shadow: 0 20px 45px rgba(15, 23, 42, 0.7);
    }
    .api-status-heading {
      font-size: 0.85rem;
      text-transform: uppercase;
      letter-spacing: 0.12em;
      color: #9ca3af;
      margin-bottom: 10px;
    }
    .api-status-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 10px;
    }
    @media (max-width: 1100px) {
      .api-status-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }
    }
    @media (max-width: 768px) {
      .api-status-grid {
        grid-template-columns: minmax(0, 1fr);
      }
    }
    .api-status-card {
      background: rgba(15, 23, 42, 0.9);
      border-radius: 12px;
      padding: 10px 12px;
      border: 1px solid rgba(148, 163, 184, 0.4);
      display: flex;
      flex-direction: column;
      gap: 4px;
    }
    .api-status-label {
      font-size: 0.78rem;
      color: #e5e7eb;
    }
    .api-status-pill {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      align-self: flex-start;
      padding: 3px 10px;
      border-radius: 999px;
      font-size: 0.75rem;
      border: 1px solid rgba(148, 163, 184, 0.5);
      background: rgba(15, 23, 42, 0.9);
      transition: background 0.18s, border-color 0.18s, color 0.18s;
    }
    .api-status-dot {
      width: 8px;
      height: 8px;
      border-radius: 999px;
      background: #6b7280;
      box-shadow: 0 0 0 3px rgba(107, 114, 128, 0.25);
    }
    .api-status-text {
      white-space: nowrap;
    }
    .api-status-note {
      font-size: 0.72rem;
      color: #9ca3af;
    }
    .api-status-error {
      margin-top: 6px;
      font-size: 0.72rem;
      color: #f97373;
    }
    .api-status-pill--ok {
      border-color: #22c55e;
      background: rgba(34, 197, 94, 0.12);
      color: #bbf7d0;
    }
    .api-status-pill--ok .api-status-dot {
      background: #22c55e;
      box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.27);
    }
    .api-status-pill--warn {
      border-color: #facc15;
      background: rgba(250, 204, 21, 0.12);
      color: #fef9c3;
    }
    .api-status-pill--warn .api-status-dot {
      background: #facc15;
      box-shadow: 0 0 0 3px rgba(250, 204, 21, 0.27);
    }
    .api-status-pill--error {
      border-color: #ef4444;
      background: rgba(239, 68, 68, 0.12);
      color: #fee2e2;
    }
    .api-status-pill--error .api-status-dot {
      background: #ef4444;
      box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.27);
    }
    .api-status-pill--unknown {
      border-color: rgba(148, 163, 184, 0.6);
      background: rgba(15, 23, 42, 0.9);
      color: #e5e7eb;
    }

  
    .btn-row{
      display:flex;
      flex-wrap:wrap;
      gap:10px;
      margin-top:10px;
      align-items:center;
    }
    .btn-secondary{
      border-radius: 999px;
      border: 1px solid var(--border-strong);
      background: rgba(255,255,255,0.9);
      padding: 10px 14px;
      font-size: 0.9rem;
      cursor: pointer;
      color: var(--text-main);
      box-shadow: 0 1px 3px rgba(15, 23, 42, 0.12);
    }
    .btn-secondary:disabled{
      opacity:0.55;
      cursor:not-allowed;
    }
    .camera-wrap{
      margin-top:12px;
      border:1px solid var(--border-soft);
      border-radius: 18px;
      overflow:hidden;
      background:#000;
      min-height:240px;
      display:flex;
      align-items:center;
      justify-content:center;
    }
    #camera-video, #camera-capture{
      width:100%;
      height:auto;
      display:block;
      max-height:420px;
      object-fit:contain;
    }

  
    .backend-row{
      display:flex;
      align-items:center;
      gap:12px;
      padding:10px 0 12px;
      border-bottom: 1px solid rgba(148,163,184,0.18);
      margin-bottom: 12px;
      flex-wrap: wrap;
    }
    .backend-label{
      font-size:12px;
      letter-spacing:0.12em;
      text-transform:uppercase;
      color:#9ca3af;
      min-width: 120px;
    }
    .backend-controls{
      display:flex;
      align-items:center;
      gap:10px;
      flex: 1;
      min-width: 260px;
    }
    #backend-url{
      flex: 1;
      min-width: 260px;
      padding: 10px 12px;
      border-radius: 12px;
      border: 1px solid rgba(148,163,184,0.25);
      background: rgba(15,23,42,0.35);
      color: #e5e7eb;
      outline: none;
    }
    .backend-note{
      font-size: 12px;
      color: #9ca3af;
    }

    /* Technical robot status bar (global) */
    .robot-bar {
      margin-top: 14px;
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 10px 12px;
      border-radius: 16px;
      border: 1px solid var(--border-soft);
      background: rgba(255,255,255,0.92);
      box-shadow: 0 10px 20px rgba(15, 23, 42, 0.08);
      backdrop-filter: blur(10px);
    }

    .robot-led {
      width: 10px;
      height: 10px;
      border-radius: 999px;
      background: var(--robot-color, #f59e0b);
      box-shadow: 0 0 14px var(--robot-color, #f59e0b);
      flex: 0 0 auto;
    }

    .robot-track {
      flex: 1;
      height: 10px;
      border-radius: 999px;
      background: rgba(17, 24, 39, 0.08);
      overflow: hidden;
      position: relative;
    }

    .robot-fill {
      height: 100%;
      width: 22%;
      border-radius: 999px;
      background: var(--robot-color, #f59e0b);
      box-shadow: 0 0 18px var(--robot-color, #f59e0b);
      transition: width 0.2s ease, filter 0.2s ease;
    }

    .robot-text {
      font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
      font-size: 0.78rem;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: rgba(17, 24, 39, 0.78);
      white-space: nowrap;
    }

    @keyframes robotPulse {
      0% { filter: brightness(1); }
      50% { filter: brightness(1.35); }
      100% { filter: brightness(1); }
    }

    .robot-bar.robot-idle { --robot-color: #f59e0b; }
    .robot-bar.robot-run  { --robot-color: #10b981; }
    .robot-bar.robot-ok   { --robot-color: #22c55e; }
    .robot-bar.robot-err  { --robot-color: #ef4444; }

    .robot-bar.robot-run .robot-led,
    .robot-bar.robot-run .robot-fill {
      animation: robotPulse 0.9s ease-in-out infinite;
    }

    .robot-bar.robot-err .robot-led,
    .robot-bar.robot-err .robot-fill {
      animation: robotPulse 0.55s ease-in-out infinite;
    }
  
    /* b16 additions */
    .platform-tabs{display:flex;gap:10px;flex-wrap:wrap;margin:6px 0 14px}
    .platform-tab{border:1px solid var(--line);background:var(--panel);color:var(--muted);padding:10px 12px;border-radius:12px;cursor:pointer;font-weight:700}
    .platform-tab.active{background:rgba(249,115,22,.12);border-color:rgba(249,115,22,.35);color:var(--text)}
    .platform-pane{display:none}
    .platform-pane.active{display:block}
    .results-tabs{display:flex;gap:10px;margin:10px 0 12px}
    .subtab-btn{border:1px solid var(--line);background:var(--panel);color:var(--muted);padding:8px 10px;border-radius:10px;cursor:pointer;font-weight:700;font-size:13px}
    .subtab-btn.active{background:rgba(34,197,94,.10);border-color:rgba(34,197,94,.35);color:var(--text)}


    /* ===== B16.1.7 Keyword-Priority + Dashboard ===== */
    .gauge-strip{
      margin-top:10px;
      display:flex;
      gap:10px;
      align-items:center;
      flex-wrap:wrap;
    }
    .gauge{
      flex: 1 1 170px;
      min-width:170px;
      border:1px solid rgba(148,163,184,0.35);
      border-radius:999px;
      padding:7px 10px;
      display:flex;
      align-items:center;
      gap:10px;
      background: rgba(255,255,255,0.75);
    }
    .gauge-label{
      font-size:11px;
      letter-spacing:0.12em;
      text-transform:uppercase;
      color:#6b7280;
      min-width:76px;
    }
    .gauge-track{
      position:relative;
      height:10px;
      flex:1;
      border-radius:999px;
      overflow:hidden;
      background: rgba(15,23,42,0.08);
    }
    .gauge-fill{
      position:absolute;
      inset:0;
      width:40%;
      border-radius:999px;
      background: var(--gauge-color, #f59e0b);
      box-shadow: 0 0 16px var(--gauge-color, #f59e0b);
      transform: translateX(-60%);
    }
    .gauge.run .gauge-fill{
      animation: gaugeSweep 1.2s linear infinite;
    }
    .gauge.idle { --gauge-color:#f59e0b; }
    .gauge.ok   { --gauge-color:#22c55e; }
    .gauge.err  { --gauge-color:#ef4444; }
    .gauge.ok .gauge-fill{ width:100%; transform:none; }
    .gauge.err .gauge-fill{ width:100%; transform:none; animation: robotPulse 0.55s ease-in-out infinite; }
    @keyframes gaugeSweep{
      0%{ transform: translateX(-70%); width:35%; }
      50%{ transform: translateX(40%); width:55%; }
      100%{ transform: translateX(140%); width:35%; }
    }

    .dash-wrap{
      margin-top:16px;
      display:flex;
      flex-direction:column;
      gap:14px;
    }
    .dash-kpis{
      display:grid;
      grid-template-columns: repeat(3, minmax(0,1fr));
      gap:12px;
    }
    @media (max-width: 860px){ .dash-kpis{ grid-template-columns: 1fr; } }
    .kpi{
      border:1px solid var(--border-soft);
      background: rgba(255,255,255,0.92);
      border-radius:18px;
      padding:14px 16px;
      box-shadow: 0 10px 20px rgba(15, 23, 42, 0.06);
    }
    .kpi-label{
      font-size:12px;
      letter-spacing:0.12em;
      text-transform:uppercase;
      color:#6b7280;
    }
    .kpi-value{
      margin-top:6px;
      font-size:28px;
      font-weight:800;
      color:#0f172a;
    }
    .dash-grid{
      display:grid;
      grid-template-columns: repeat(2, minmax(0,1fr));
      gap:12px;
    }
    @media (max-width: 980px){ .dash-grid{ grid-template-columns: 1fr; } }
    .dash-card{
      border:1px solid var(--border-soft);
      background: rgba(255,255,255,0.92);
      border-radius:18px;
      padding:14px 16px;
      box-shadow: 0 10px 20px rgba(15, 23, 42, 0.06);
    }
    .dash-card h4{
      margin:0 0 10px 0;
      font-size:15px;
      letter-spacing:0.02em;
    }
    .dash-summary{
      font-size:14px;
      color:#111827;
      line-height:1.45;
      white-space:pre-wrap;
    }
    .mini-list{
      display:flex;
      flex-direction:column;
      gap:8px;
    }
    .mini-item{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:12px;
      padding:8px 10px;
      border:1px solid rgba(148,163,184,0.35);
      border-radius:12px;
      background: rgba(255,255,255,0.8);
    }
    .mini-item .name{
      font-weight:700;
      color:#0f172a;
      overflow:hidden;
      text-overflow:ellipsis;
      white-space:nowrap;
    }
    .mini-item .val{
      font-variant-numeric: tabular-nums;
      font-weight:800;
      color:#0f172a;
    }
    .pub-table{
      width:100%;
      border-collapse:collapse;
      font-size:13px;
      overflow:hidden;
      border-radius:14px;
      border:1px solid rgba(148,163,184,0.20);
      background:#fff;
    }
    .pub-table th,.pub-table td{
      padding:10px 12px;
      border-bottom:1px solid rgba(148,163,184,0.25);
      text-align:left;
      vertical-align:top;
    }
    .pub-table th{
      color:#4b5563;
      font-size:12px;
      letter-spacing:0.08em;
      text-transform:uppercase;
      background:rgba(249,115,22,0.08);
    }
    .pub-table tbody tr:nth-child(odd){background:rgba(255,255,255,0.65)}
    .pub-table tbody tr:hover{background:rgba(249,115,22,0.08)}



    /* ===== Premium Report Studio (b98) ===== */
    #report-panel{overflow:hidden}
    #report-panel *, #rsCampaignPicker *{box-sizing:border-box}
    .rs-picker-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;align-items:end}
    .rs-picker-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-start}
    .rs-picker-actions > *{flex:1 1 220px}
    .rs-wrap{display:grid;grid-template-columns:minmax(220px,260px) minmax(0,1fr);gap:14px;align-items:start;max-width:100%}
    .rs-sidebar{position:sticky;top:14px;max-height:calc(100vh - 120px);overflow:auto;overflow-x:hidden;padding:12px;border:1px solid var(--line);border-radius:8px;background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));backdrop-filter:blur(10px)}
    .rs-scope{font-weight:800;padding:10px 12px;border-radius:8px;border:1px solid rgba(249,115,22,.35);background:rgba(249,115,22,.10);color:var(--text);margin-bottom:10px;overflow-wrap:anywhere}
    .rs-nav{width:100%;text-align:left;padding:10px 12px;border-radius:8px;border:1px solid var(--line);background:var(--panel);color:var(--muted);cursor:pointer;font-weight:750;margin-bottom:6px;line-height:1.35}
    .rs-nav.active{background:rgba(249,115,22,.14);border-color:rgba(249,115,22,.35);color:var(--text)}
    .rs-actions{display:grid;gap:10px;margin-top:12px}
    .rs-actions .btn-secondary{width:100%}
    .rs-main,.rs-topbar,.rs-meta,.rs-kpis,.rs-grid,.rs-card,.rs-section,.rs-sections{min-width:0}
    .rs-topbar{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:start;margin-bottom:12px}
    .rs-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}
    .rs-period,.rs-platforms{padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:var(--panel);color:var(--muted);font-weight:700;white-space:normal;overflow-wrap:anywhere}
    .rs-hint{color:var(--muted);font-weight:650;max-width:280px;text-align:right;align-self:center}
    .rs-source-tabs{display:flex;gap:10px;flex-wrap:wrap;margin:0 0 14px}
    .rs-source-tab{border:1px solid var(--line);background:var(--panel);color:var(--muted);padding:10px 12px;border-radius:8px;cursor:pointer;font-weight:800;line-height:1.2}
    .rs-source-tab.active{background:rgba(249,115,22,.12);border-color:rgba(249,115,22,.35);color:var(--text)}
    .rs-source-tab:disabled{opacity:.48;cursor:not-allowed}
    .rs-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin:12px 0 14px}
    .rs-kpi{border:1px solid rgba(148,163,184,0.18);border-radius:18px;background:linear-gradient(180deg,#ffffff,rgba(249,250,251,0.96));padding:14px;overflow:hidden;box-shadow:0 14px 28px rgba(15,23,42,0.06)}
    .rs-kpi-label{color:var(--muted);font-weight:800;font-size:.85rem}
    .rs-kpi-value{font-weight:900;font-size:1.55rem;margin-top:4px;overflow-wrap:anywhere}
    .rs-spark{display:block;width:100% !important;max-width:100%;margin-top:8px;border-radius:8px;border:1px solid rgba(255,255,255,.08);background:rgba(0,0,0,.12)}
    .rs-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-bottom:14px}
    .rs-grid-visuals{grid-template-columns:repeat(2,minmax(0,1fr))}
    .rs-card{border:1px solid rgba(148,163,184,0.18);border-radius:18px;background:linear-gradient(180deg,#ffffff,rgba(249,250,251,0.98));padding:14px;overflow:hidden;box-shadow:0 14px 30px rgba(15,23,42,0.06)}
    .rs-card-title{font-weight:900;margin-bottom:8px;overflow-wrap:anywhere;font-size:1.02rem}
    .rs-card-sub{color:var(--muted);margin-top:8px;font-weight:650;white-space:pre-line;overflow-wrap:anywhere}
    .rs-sections{display:grid;gap:14px}
    .rs-section{border:1px solid rgba(148,163,184,0.18);border-radius:18px;background:linear-gradient(180deg,#ffffff,rgba(249,250,251,0.98));padding:16px;overflow:hidden;box-shadow:0 14px 30px rgba(15,23,42,0.05)}
    .rs-section h3{margin:0 0 12px 0;font-weight:950;overflow-wrap:anywhere;font-size:1.08rem}
    .rs-body{color:var(--text);line-height:1.5;overflow-wrap:anywhere}
    .rs-body ul{margin:8px 0 0 20px;padding-right:6px;display:grid;gap:8px}
    .rs-body li{margin:0}
    .rs-pill{display:inline-block;padding:6px 10px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--muted);font-weight:700;margin:4px 6px 0 0;max-width:100%;overflow-wrap:anywhere}
    .rs-table{width:100%;border-collapse:collapse;margin-top:10px;table-layout:fixed}
    .rs-table th,.rs-table td{border-bottom:1px solid rgba(255,255,255,.08);padding:8px 6px;text-align:left;vertical-align:top;overflow-wrap:anywhere}
    .rs-table th{color:var(--muted);font-weight:900}
    .rs-table a{overflow-wrap:anywhere;word-break:break-word}
    .rs-audit-wrap{display:grid;gap:14px}
    .rs-audit-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}
    .rs-audit-stat{border:1px solid rgba(249,115,22,.18);border-radius:8px;padding:12px;background:linear-gradient(180deg,rgba(249,115,22,.10),rgba(255,255,255,.02))}
    .rs-audit-stat-label{color:var(--muted);font-size:.82rem;font-weight:800}
    .rs-audit-stat-value{font-size:1.35rem;font-weight:900;margin-top:4px}
    .rs-evidence-shell{border:1px solid rgba(255,255,255,.08);border-radius:8px;overflow:hidden;background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.015))}
    .rs-evidence-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03)}
    .rs-evidence-title{font-weight:900}
    .rs-evidence-sub{color:var(--muted);font-size:.92rem;margin-top:4px}
    .rs-evidence-meta{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}
    .rs-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.04);color:var(--muted);font-weight:750;font-size:.82rem}
    .rs-badge.is-positive{border-color:rgba(16,185,129,.35);background:rgba(16,185,129,.10);color:#d1fae5}
    .rs-badge.is-neutral{border-color:rgba(148,163,184,.28);background:rgba(148,163,184,.10);color:#e2e8f0}
    .rs-badge.is-negative{border-color:rgba(239,68,68,.35);background:rgba(239,68,68,.10);color:#fee2e2}
    .rs-evidence-table{width:100%;border-collapse:separate;border-spacing:0}
    .rs-evidence-table thead th{
      position:sticky;
      top:0;
      background:linear-gradient(180deg,#0f172a,#111827);
      z-index:1;
      color:#fff;
      font-size:.78rem;
      text-transform:uppercase;
      letter-spacing:.08em;
      box-shadow:inset 0 -1px 0 rgba(255,255,255,.08);
    }
    .rs-evidence-table th,.rs-evidence-table td{padding:14px 12px;border-bottom:1px solid rgba(255,255,255,.06);text-align:left;vertical-align:top}
    .rs-evidence-table tbody tr:nth-child(odd){background:rgba(255,255,255,.018)}
    .rs-evidence-table tbody tr:hover{background:rgba(249,115,22,.08)}
    .rs-evidence-title-cell{display:grid;gap:6px}
    .rs-evidence-item-title{font-weight:850;line-height:1.35}
    .rs-evidence-preview{color:var(--muted);font-size:.92rem;line-height:1.45}
    .rs-evidence-link{display:inline-flex;align-items:center;gap:6px;font-weight:800}
    .rs-evidence-source{display:grid;gap:4px}
    .rs-evidence-source strong{font-weight:850}
    .rs-evidence-source span{color:var(--muted);font-size:.9rem}
    .rs-evidence-score{font-weight:900;font-size:1.05rem}
    .rs-card canvas,.rs-kpi canvas,.rs-main canvas{display:block;width:100% !important;max-width:100%}
    .rs-stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:14px}
    .rs-stat-card{border:1px solid rgba(148,163,184,0.18);border-radius:16px;background:linear-gradient(180deg,rgba(249,115,22,0.10),rgba(255,255,255,0.92));padding:14px}
    .rs-stat-label{font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;color:#6b7280;font-weight:800}
    .rs-stat-value{font-size:1.12rem;font-weight:900;color:#111827;margin-top:8px;line-height:1.35}
    .rs-stat-note{font-size:.88rem;color:#4b5563;margin-top:6px;line-height:1.45}
    .rs-split-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-bottom:14px}
    .rs-surface-card{border:1px solid rgba(148,163,184,0.18);border-radius:16px;padding:14px;background:rgba(255,255,255,0.9)}
    .rs-surface-title{font-weight:900;margin-bottom:10px;color:#111827}
    .rs-empty-card{padding:12px;border:1px dashed rgba(148,163,184,0.35);border-radius:14px;background:rgba(248,250,252,0.85);color:#64748b}
    .rs-bar-list{display:grid;gap:12px}
    .rs-bar-row{display:grid;gap:6px}
    .rs-bar-head{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:.95rem}
    .rs-bar-head span{font-weight:700;color:#111827;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
    .rs-bar-head strong{font-weight:900;color:#111827;white-space:nowrap}
    .rs-bar-track{height:10px;border-radius:999px;background:rgba(148,163,184,0.18);overflow:hidden}
    .rs-bar-fill{display:block;height:100%;border-radius:999px}
    .rs-bar-fill--orange{background:linear-gradient(90deg,#f97316,#fb923c)}
    .rs-bar-fill--slate{background:linear-gradient(90deg,#0f172a,#475569)}
    .rs-bar-meta{font-size:.82rem;color:#6b7280}
    .rs-insight-grid{display:grid;gap:10px}
    .rs-insight-card{padding:12px 14px;border-radius:14px;border:1px solid rgba(148,163,184,0.16);background:#fff;color:#334155;line-height:1.5}
    .rs-insight-card--orange{background:linear-gradient(180deg,rgba(249,115,22,0.12),rgba(255,255,255,0.96))}
    .rs-insight-card--slate{background:linear-gradient(180deg,rgba(15,23,42,0.06),rgba(255,255,255,0.96))}
    .rs-voice-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
    .rs-voice-card{border:1px solid rgba(148,163,184,0.18);border-radius:16px;background:#fff;padding:14px;display:grid;gap:12px}
    .rs-voice-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
    .rs-voice-top h4{margin:0;font-size:1rem;color:#111827}
    .rs-voice-top p{margin:4px 0 0;color:#64748b;font-size:.9rem}
    .rs-voice-metrics{display:flex;flex-wrap:wrap;gap:10px;font-size:.88rem;color:#475569}
    .rs-voice-metrics strong{color:#111827}

    .rs-modal{position:fixed;inset:0;display:none;z-index:9999}
    .rs-modal.show{display:block}
    .rs-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.65)}
    .rs-modal-card{position:relative;max-width:980px;margin:60px auto;background:#0b0f19;border:1px solid rgba(255,255,255,.12);border-radius:22px;box-shadow:0 18px 60px rgba(0,0,0,.55);overflow:hidden}
    .rs-modal-head{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.10)}
    .rs-modal-title{font-weight:950}
    .rs-modal-close{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);color:#fff;border-radius:12px;padding:8px 10px;cursor:pointer}
    .rs-modal-body{padding:12px 14px;max-height:70vh;overflow:auto}

    @media (max-width: 1200px){
      .rs-wrap{grid-template-columns:1fr}
      .rs-sidebar{position:relative;top:auto;max-height:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px}
      .rs-scope,.rs-actions{grid-column:1 / -1}
      .rs-actions{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
      .rs-nav{margin-bottom:0}
      .rs-topbar{grid-template-columns:1fr}
      .rs-hint{max-width:none;text-align:left}
    }

    @media (max-width: 980px){
      #report-panel .panel-header{display:grid;gap:10px}
      .rs-sidebar{grid-template-columns:1fr}
      .rs-picker-grid{grid-template-columns:1fr}
      .rs-picker-actions{display:grid;grid-template-columns:1fr}
      .rs-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}
      .rs-grid{grid-template-columns:1fr}
      .rs-grid-visuals{grid-template-columns:1fr}
      .rs-split-grid{grid-template-columns:1fr}
      .rs-source-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}
      .rs-table{display:block;overflow:auto}
      .rs-table tbody,.rs-table thead,.rs-table tr{width:100%}
      .rs-evidence-head{display:grid}
      .rs-evidence-meta{justify-content:flex-start}
    }

    @media (max-width: 640px){
      .rs-kpis{grid-template-columns:1fr}
      .rs-source-tabs{grid-template-columns:1fr}
    }

    @media print{
      .tab-bar, .rs-sidebar, .rs-hint, .btn-primary, .btn-secondary, .rs-source-tabs { display:none !important; }
      body { background:#fff !important; }
      .rs-section, .rs-card, .rs-kpi { break-inside:avoid; }
    }

  
/* ===== Details Modal (Social) ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;padding:24px;z-index:9999}
.modal-overlay.hidden{display:none}
.modal{background:rgba(17,24,39,.98);color:#fff;width:min(980px,100%);max-height:88vh;overflow:hidden;border-radius:18px;box-shadow:0 20px 60px rgba(0,0,0,.45);border:1px solid rgba(255,255,255,.10)}
.modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:16px 18px;border-bottom:1px solid rgba(255,255,255,.08)}
.modal-title{font-weight:800;font-size:15px;line-height:1.2;margin:0}
.modal-sub{opacity:.78;font-size:12px;margin-top:2px}
.modal-close{border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);color:#fff;border-radius:10px;padding:6px 10px;cursor:pointer}
.modal-close:hover{background:rgba(255,255,255,.10)}
.modal-body{padding:16px 18px;overflow:auto;max-height:calc(88vh - 64px)}
.kpi-row{display:flex;flex-wrap:wrap;gap:10px;margin:10px 0 14px}
.kpi-chip{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10);border-radius:999px;padding:8px 10px;font-size:12px;white-space:nowrap}
.details-text{white-space:pre-wrap;font-size:13px;opacity:.95;margin:10px 0 12px}
.section-title{font-weight:800;font-size:13px;margin:12px 0 8px}
.comments-list{display:flex;flex-direction:column;gap:10px}
.comment-item{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:10px 12px}
.comment-author{font-weight:800;font-size:12px}
.comment-text{opacity:.92;font-size:12px;margin-top:4px;white-space:pre-wrap}
.modal-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.link-btn{background:none;border:none;color:var(--accent-strong);font-size:0.8rem;cursor:pointer;padding:0;display:inline-flex;align-items:center;gap:4px}
.link-btn:hover{text-decoration:underline}


    /* Campaign gate + session */
    .campaign-header{
      display:flex;
      gap:10px;
      align-items:center;
      margin-left:auto;
      flex-wrap:wrap;
    }
    header{ display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap; }
    .campaign-chip{
      display:inline-flex;
      align-items:center;
      gap:8px;
      padding:8px 12px;
      border:1px solid var(--border-soft);
      background:rgba(255,255,255,0.75);
      backdrop-filter: blur(8px);
      border-radius:999px;
      color:var(--text-main);
      font-size:13px;
      box-shadow: 0 6px 18px rgba(15,23,42,0.08);
    }
    .campaign-chip span{ font-weight:700; }
    .campaign-modal{
      position:fixed; inset:0;
      display:none;
      align-items:center;
      justify-content:center;
      background:rgba(17,24,39,0.55);
      z-index:9999;
      padding:18px;
    }
    .campaign-modal.show{ display:flex; }
    .campaign-modal .box{
      width:min(980px, 100%);
      max-height: 92vh;
      overflow:auto;
      background:var(--card);
      border:1px solid var(--border-soft);
      border-radius: var(--radius-lg);
      box-shadow: var(--shadow-soft);
      padding:18px;
    }
    .campaign-modal .top{
      display:flex; align-items:center; justify-content:space-between; gap:10px;
      margin-bottom:10px;
    }
    .campaign-modal .title{ font-size:18px; font-weight:800; }
    .campaign-modal .grid{
      display:grid; grid-template-columns: 1fr 1fr; gap:14px;
    }
    @media (max-width: 860px){ .campaign-modal .grid{ grid-template-columns:1fr; } }
    .seg{ display:flex; gap:8px; flex-wrap:wrap; margin:10px 0 12px; }
    .seg button{
      padding:8px 10px;
      border-radius:999px;
      border:1px solid var(--border-soft);
      background:var(--bg-alt);
      cursor:pointer;
      font-weight:700;
      font-size:13px;
    }
    .seg button.active{
      border-color: var(--accent);
      background: var(--accent-soft);
      color: var(--text-main);
    }
    .campaign-list{
      border:1px solid var(--border-soft);
      border-radius:14px;
      overflow:hidden;
      background: #fff;
    }
    .campaign-list .row{
      padding:12px;
      border-bottom:1px solid var(--border-soft);
      cursor:pointer;
      display:flex;
      align-items:flex-start;
      justify-content:space-between;
      gap:12px;
    }
    .campaign-list .row:last-child{ border-bottom:none; }
    .campaign-list .row:hover{ background:rgba(249,115,22,0.07); }
    .campaign-list .row.active{ background:rgba(249,115,22,0.10); }
    .campaign-list .row-main{ min-width:0; flex:1 1 auto; }
    .campaign-list .row-actions{ display:flex; gap:8px; flex-wrap:wrap; justify-content:flex-end; }
    .campaign-row-btn{
      border:1px solid var(--border-soft);
      background:#fff;
      color:var(--text-main);
      border-radius:999px;
      padding:7px 10px;
      font-size:12px;
      font-weight:800;
      cursor:pointer;
    }
    .campaign-row-btn:hover{ background:rgba(249,115,22,0.08); border-color:rgba(249,115,22,0.28); }
    .campaign-row-btn.danger{ color:#b91c1c; border-color:rgba(239,68,68,0.28); }
    .campaign-row-btn.danger:hover{ background:rgba(239,68,68,0.08); }
    .campaign-list .name{ font-weight:800; }
    .campaign-list .meta{ color:var(--text-soft); font-size:12px; margin-top:2px; }
    .muted{ color:var(--text-soft); font-size:12px; }
    @media (max-width: 720px){
      .campaign-list .row{ flex-direction:column; }
      .campaign-list .row-actions{ width:100%; justify-content:flex-start; }
    }


    #global-toast{
      position:fixed;
      left:50%;
      transform:translateX(-50%);
      bottom:18px;
      padding:10px 14px;
      border-radius:999px;
      background: rgba(17,24,39,0.92);
      color:#fff;
      font-weight:700;
      font-size:13px;
      opacity:0;
      transition: opacity 200ms ease;
      z-index:10000;
      pointer-events:none;
      max-width:min(92vw, 920px);
      text-align:center;
    }
    #global-toast.err{ background: rgba(185,28,28,0.94); }



/* b50: simplify date range UI */
.date-row{display:none !important;}

/* b50: safety for clickability */
.campaign-modal{pointer-events:auto;}


/* ---------- Admin (SALGA) ---------- */
.form-row{
  display:grid;
  gap:10px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
@media (max-width: 900px){
  .form-row{ grid-template-columns: minmax(0,1fr); }
}
.field label{
  display:block;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--text-soft);
  margin-bottom: 4px;
}
.table-wrap{
  max-height: 420px;
  overflow:auto;
  border: 1px solid var(--border-soft);
  border-radius: 14px;
  background:#fff;
}
.admin-table{
  width:100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}
.admin-table th, .admin-table td{
  padding: 9px 10px;
  border-bottom: 1px solid var(--border-soft);
  vertical-align: top;
}
.admin-table thead th{
  position: sticky;
  top: 0;
  background: #f8fafc;
  z-index: 1;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-soft);
}
.admin-table tbody tr:hover{
  background: #fbfbff;
}


/* b58: Fix file inputs overflowing into right column and blocking doc buttons */
.docs-grid .left { overflow: hidden; }
.docs-grid input[type="file"] { width: 100%; max-width: 100%; box-sizing: border-box; }
.doc-actions-row { position: relative; z-index: 10; pointer-events: auto; }
.doc-actions-row button { position: relative; z-index: 11; pointer-events: auto; }



/* ===== Country-grouped news sources UI ===== */
.news-country-row{
  display:flex;
  gap:12px;
  align-items:flex-end;
  justify-content:space-between;
  margin:8px 0 4px;
}
.news-country-left{ flex:1; min-width:220px; }
.news-country-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
  justify-content:flex-end;
}

/* ===== Campaign modal reason ===== */
.campaign-reason{
  margin-top:10px;
  padding:10px 12px;
  border:1px solid rgba(255,255,255,0.10);
  border-radius:10px;
  background: rgba(255,255,255,0.04);
  color: rgba(255,255,255,0.85);
  font-size: 13px;
}

/* ===== Report Studio (needs campaign) ===== */
.rs-need-campaign .card{
  margin: 10px 0;
}


/* EIM Identity Lock (do not change names of buttons) */
.is-disabled{opacity:0.6;cursor:not-allowed;}
mark{background: rgba(245,158,11,0.25); padding:0 2px; border-radius:4px;}


/* --- Auth (b93) --- */
.auth-wrap{min-height:100vh; display:flex; align-items:center; justify-content:center; padding:24px;}
.auth-card{width:min(520px, 92vw); background:var(--card); border:1px solid var(--border-soft); border-radius:22px; padding:26px; box-shadow: 0 20px 60px rgba(0,0,0,.08);}
.auth-brand{display:flex; align-items:center; gap:12px; margin-bottom:14px;}
.brand-mark{width:56px; height:56px; border-radius:0; display:flex; align-items:center; justify-content:center; background:transparent; overflow:hidden; flex:0 0 auto;}
.brand-mark img{width:100%; height:100%; object-fit:contain; display:block;}
.brand-name{font-weight:800; letter-spacing:.12em; font-size:12px; color:var(--text-soft);}
.brand-sub{font-weight:800; font-size:18px; color:var(--text-main);}
.auth-title{margin:12px 0 4px; font-size:26px;}


/* LinkedIn + Executive + reliability */
#platform-linkedin .field-hint { color:#6b7280; font-size:12px; }
#linkedin-inputs, #linkedin-keywords, #linkedin-language-filter { width:100%; }

.badge-language {
  background: #eef4ff;
  color: #214e9b;
  border: 1px solid #cfe0ff;
}

.exec-shell{display:grid;gap:16px;border:1px solid rgba(148,163,184,0.18);background:linear-gradient(180deg,#ffffff,rgba(249,250,251,0.96))}
.exec-hero{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(280px,.8fr);gap:16px}
.exec-summary-panel,.exec-top-panel{border:1px solid rgba(148,163,184,0.18);border-radius:18px;padding:16px;background:#fff}
.exec-badge-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}
.exec-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:999px;font-size:.82rem;font-weight:800}
.exec-chip--green{background:rgba(34,197,94,0.12);color:#166534;border:1px solid rgba(34,197,94,0.24)}
.exec-chip--amber{background:rgba(245,158,11,0.14);color:#92400e;border:1px solid rgba(245,158,11,0.24)}
.exec-chip--red{background:rgba(239,68,68,0.12);color:#991b1b;border:1px solid rgba(239,68,68,0.24)}
.exec-chip--subtle{background:rgba(15,23,42,0.06);color:#334155;border:1px solid rgba(148,163,184,0.18)}
.exec-summary-text {
  font-size: 18px;
  line-height: 1.65;
  color: #1f2937;
  margin-bottom: 4px;
}
.exec-top-grid{display:grid;gap:10px}
.exec-mention-card{border:1px solid rgba(148,163,184,0.18);border-radius:14px;padding:12px;background:rgba(248,250,252,0.9);display:grid;gap:8px}
.exec-mention-top{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}
.exec-mention-source{font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;color:#f97316;font-weight:900}
.exec-mention-tag{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:#111827;color:#fff;font-size:.78rem;font-weight:800}
.exec-mention-title{font-weight:800;color:#111827;line-height:1.45}
.exec-mention-actions a{font-size:.9rem;font-weight:800}
.exec-empty{padding:14px;border-radius:14px;background:rgba(248,250,252,0.9);color:#64748b;border:1px dashed rgba(148,163,184,0.28)}
.exec-kpis {
  display:grid;
  grid-template-columns: repeat(6, minmax(0,1fr));
  gap:12px;
  margin: 0;
}
.exec-kpi {
  border:1px solid rgba(148,163,184,0.18);
  background:#fff;
  border-radius:16px;
  padding:14px;
  display:flex;
  flex-direction:column;
  gap:6px;
  box-shadow:0 12px 24px rgba(15,23,42,0.05);
}
.exec-kpi--risk{background:linear-gradient(180deg,rgba(249,115,22,0.10),#fff)}
.exec-kpi span {
  font-size:12px;
  text-transform:uppercase;
  color:#6b7280;
  letter-spacing:.08em;
}
.exec-kpi strong {
  font-size:28px;
  color:#111827;
}
.btn[disabled], .btn-primary[disabled], .btn-secondary[disabled], .btn-ghost[disabled] {
  opacity:.65;
  cursor:not-allowed;
}
@media (max-width: 1100px){
  .exec-hero{grid-template-columns:1fr}
  .exec-kpis { grid-template-columns: repeat(3, minmax(0,1fr)); }
}
@media (max-width: 720px){
  .exec-kpis { grid-template-columns: repeat(2, minmax(0,1fr)); }
}


/* ===== Feature 7 — WCAG 2.1 Accessibility Compliance ===== */
:focus-visible {
  outline: 3px solid #1d4ed8;
  outline-offset: 2px;
}

.skip-link {
  position: absolute;
  left: 12px;
  top: -48px;
  background: #111827;
  color: #ffffff;
  padding: 10px 14px;
  border-radius: 10px;
  z-index: 9999;
  text-decoration: none;
  transition: top .2s ease;
}
.skip-link:focus {
  top: 12px;
}

.sr-only {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}

/* Better contrast */
.field-hint, .hint, .muted, .panel-subtitle, .panel-sub {
  color: #4b5563 !important;
}

.badge-language {
  background: #dbeafe !important;
  color: #123a7a !important;
  border-color: #93c5fd !important;
}

.btn, .btn-primary, .btn-secondary, .btn-ghost, .tab-btn, .platform-tab, .subtab-btn, .subtab {
  min-height: 44px;
}

input, textarea, select, button {
  font-size: 16px;
}

.tab-btn.active, .platform-tab.active, .subtab-btn.active, .subtab.active {
  box-shadow: 0 0 0 2px rgba(29,78,216,.25);
}

@media (prefers-reduced-motion: reduce) {
  * {
    animation: none !important;
    transition: none !important;
    scroll-behavior: auto !important;
  }
}


/* ===== Feature 8 — Guided Onboarding Wizard ===== */
.modal-shell {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: rgba(15, 23, 42, .55);
  z-index: 10020;
  overflow: auto;
}
.modal-shell[aria-hidden="true"] {
  display: none;
}
.modal-card {
  width: min(92vw, 860px);
  max-height: min(86vh, 760px);
  overflow: auto;
  background: var(--card);
  color: var(--text);
  border: 1px solid var(--border-soft);
  border-radius: 8px;
  box-shadow: 0 24px 80px rgba(15, 23, 42, .32);
  padding: 22px;
}
.modal-card .modal-header {
  padding: 0 0 16px;
  border-bottom: 1px solid var(--border-soft);
  margin-bottom: 16px;
}
.modal-card .modal-title {
  font-size: 20px;
  font-weight: 800;
  color: var(--text);
}
.modal-card .modal-subtitle {
  margin-top: 4px;
  color: #4b5563;
}
.modal-card .modal-footer {
  border-top: 1px solid var(--border-soft);
  margin-top: 18px;
  padding-top: 16px;
}
.onboarding-card { max-width: 860px; width: min(92vw, 860px); }
.onboarding-start-panel {
  background: #fff7ed;
  border: 1px solid #fed7aa;
  border-radius: 8px;
  padding: 16px;
}
.onboarding-steps {
  display: grid;
  grid-template-columns: repeat(5, minmax(0,1fr));
  gap: 8px;
  margin: 8px 0 18px;
}
.onboarding-step {
  padding: 10px 12px;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  background: #fff;
  color: #6b7280;
  font-size: 13px;
  text-align: center;
}
.onboarding-step.active {
  background: #fff7ed;
  color: #9a3412;
  border-color: #fdba74;
  font-weight: 600;
}
.onboarding-action-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 12px;
}
.onboarding-action-row > * {
  flex: 1 1 220px;
}
.onboarding-body h3 { margin: 0 0 10px; }
.onboarding-body textarea,
.onboarding-body select {
  width: 100%;
}
.onboarding-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.onboarding-check-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.onboarding-check-grid label,
.onboarding-inline-check {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border: 1px solid var(--border-soft);
  border-radius: 8px;
  background: #fff;
}
.onboarding-inline-check {
  margin-top: 10px;
}
.onboarding-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.footer-actions { display: flex; gap: 10px; }
#rsCampaignSelect option:disabled {
  color: #9ca3af;
}
@media (max-width: 900px){
  .modal-shell { align-items: flex-start; padding: 14px; }
  .modal-card { width: 100%; max-height: calc(100vh - 28px); padding: 18px; }
  .onboarding-steps { grid-template-columns: 1fr; }
  .onboarding-form-grid,
  .onboarding-check-grid { grid-template-columns: 1fr; }
  .onboarding-action-row { display: grid; grid-template-columns: 1fr; }
  .onboarding-footer { flex-direction: column; gap: 12px; align-items: stretch; }
  .footer-actions { width: 100%; display: grid; grid-template-columns: 1fr 1fr; }
}


/* ===== Daily Email Alerts UI ===== */
.scheduler-help {
  background: #f8fafc;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: 10px 12px;
  line-height: 1.5;
}
.scheduler-help code {
  display: inline-block;
  margin-top: 6px;
  background: #111827;
  color: #fff;
  padding: 6px 8px;
  border-radius: 8px;
}
.email-preview-box {
  min-height: 180px;
  border: 1px solid #e5e7eb;
  background: #fff;
  border-radius: 14px;
  padding: 14px;
  overflow: auto;
}
.mt8 { margin-top: 8px; }
.mt16 { margin-top: 16px; }


/* ===== Quick start actions ===== */
.quickstart-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:16px;
}
.quickstart-card{
  border:1px solid #e5e7eb;
  background:#fff;
  border-radius:18px;
  padding:18px;
  text-align:left;
  cursor:pointer;
  box-shadow: 0 8px 24px rgba(0,0,0,.04);
}
.quickstart-card:hover{
  border-color:#fdba74;
  box-shadow: 0 12px 28px rgba(0,0,0,.06);
}
.quickstart-icon{
  font-size:28px;
  margin-bottom:10px;
}
.quickstart-title{
  font-size:18px;
  font-weight:700;
  color:#111827;
  margin-bottom:6px;
}
.quickstart-text{
  color:#4b5563;
  line-height:1.5;
}
select{
  appearance:auto;
  -webkit-appearance:menulist;
  -moz-appearance:menulist;
}
@media (max-width: 900px){
  .quickstart-grid{ grid-template-columns: 1fr; }
}

/* ===== Workspace shell + ad detection (b111) ===== */
.workspace-shell{
  display:grid;
  gap:14px;
  margin-bottom:18px;
}
.workspace-shell-top,
.workspace-widget-shell,
.ad-service-card{
  background:rgba(255,255,255,.92);
  border:1px solid rgba(209,213,219,.9);
  border-radius:20px;
  padding:16px;
  box-shadow:0 12px 28px rgba(15,23,42,.08);
}
.workspace-shell-top{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:16px;
  align-items:start;
}
.workspace-breadcrumbs{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  min-height:40px;
}
.workspace-breadcrumbs .crumb{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(209,213,219,.9);
  color:var(--text-soft);
  font-size:.85rem;
  white-space:nowrap;
}
.workspace-breadcrumbs .crumb.current{
  background:rgba(249,115,22,.12);
  border-color:rgba(249,115,22,.28);
  color:var(--text-main);
  font-weight:700;
}
.workspace-shell-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  justify-content:flex-end;
  align-items:end;
}
.workspace-date-filter,
.workspace-search{
  display:grid;
  gap:6px;
}
.workspace-date-filter{
  grid-template-columns:repeat(3,minmax(120px,1fr));
  align-items:end;
}
.workspace-date-filter .field-label,
.workspace-search .field-label,
.ad-match-filter .field-label{
  grid-column:1 / -1;
  margin:0;
}
.workspace-search-row{
  display:flex;
  gap:8px;
  align-items:center;
}
.workspace-search-row .input{
  min-width:280px;
}
.notification-btn{
  position:relative;
  min-height:42px;
}
.notification-count{
  min-width:22px;
  height:22px;
  padding:0 6px;
  border-radius:999px;
  background:var(--accent);
  color:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:.75rem;
  font-weight:800;
}
.workspace-widget-head{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
  margin-bottom:12px;
}
.widget-toggle-panel{
  display:flex;
  flex-wrap:wrap;
  gap:10px 14px;
  padding:12px 0 2px;
}
.widget-toggle-panel label{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:.92rem;
  color:var(--text-soft);
}
.home-widget-board{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:12px;
}
.home-widget{
  border:1px solid rgba(209,213,219,.9);
  border-radius:16px;
  background:#fff;
  padding:14px;
  display:grid;
  gap:8px;
  min-height:118px;
}
.home-widget strong{
  font-size:1.4rem;
}
.home-widget .muted{
  margin:0;
}
.home-widget .btn-secondary,
.home-widget .btn-primary{
  width:max-content;
}
.session-timeout-banner{
  margin:0 0 16px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(249,115,22,.3);
  background:rgba(249,115,22,.1);
  color:var(--text-main);
  font-weight:600;
}
.workspace-modal{
  position:fixed;
  inset:0;
  display:none;
  z-index:1100;
}
.workspace-modal.show{
  display:block;
}
.workspace-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(15,23,42,.42);
}
.workspace-modal-card{
  position:relative;
  max-width:920px;
  margin:48px auto;
  background:#fff;
  border-radius:20px;
  border:1px solid rgba(209,213,219,.9);
  box-shadow:0 28px 70px rgba(15,23,42,.24);
  padding:18px;
  width:min(calc(100% - 24px), 920px);
  max-height:calc(100vh - 96px);
  overflow:auto;
}
.workspace-modal-head,
.card-head-row,
.ad-service-card{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
  flex-wrap:wrap;
}
.workspace-search-row--modal{
  margin:12px 0 14px;
}
.workspace-modal-results{
  display:grid;
  gap:10px;
}
.workspace-search-result{
  border:1px solid rgba(209,213,219,.85);
  border-radius:14px;
  background:#fff;
  padding:12px 14px;
  display:grid;
  gap:6px;
}
.workspace-search-result-top{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
}
.workspace-search-tag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:4px 8px;
  background:rgba(15,23,42,.06);
  color:var(--text-soft);
  font-size:.75rem;
  font-weight:700;
}
.notification-drawer{
  position:fixed;
  top:0;
  right:-420px;
  width:min(420px,100vw);
  height:100vh;
  z-index:1090;
  background:#fff;
  border-left:1px solid rgba(209,213,219,.9);
  box-shadow:-12px 0 32px rgba(15,23,42,.18);
  transition:right .2s ease;
  display:flex;
  flex-direction:column;
}
.notification-drawer.show{
  right:0;
}
.notification-drawer-head{
  padding:18px 18px 10px;
  border-bottom:1px solid rgba(209,213,219,.85);
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
}
.notification-list{
  overflow:auto;
  padding:16px;
  display:grid;
  gap:10px;
}
.notification-item{
  border:1px solid rgba(209,213,219,.85);
  border-radius:14px;
  padding:12px;
  display:grid;
  gap:6px;
}
.notification-item[data-severity="high"]{
  border-color:rgba(220,38,38,.28);
  background:rgba(254,242,242,.95);
}
.notification-item[data-severity="medium"]{
  border-color:rgba(245,158,11,.28);
  background:rgba(255,251,235,.95);
}
.notification-item-head{
  display:flex;
  justify-content:space-between;
  gap:10px;
  align-items:center;
}
.ad-summary-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:12px;
  margin-bottom:14px;
}
#ad-panel .panel-header{
  display:grid;
  gap:8px;
  padding:18px 20px;
  margin-bottom:14px;
  border:1px solid rgba(249,115,22,.16);
  border-radius:22px;
  background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(255,247,237,.96) 100%);
  box-shadow:0 14px 30px rgba(15,23,42,.06);
}
.ad-country-row{
  margin-bottom:8px;
}
.ad-country-copy{
  margin:6px 0 12px;
  line-height:1.55;
}
.ad-defaults-grid{
  margin-top:4px;
}
.ad-url-editor textarea,
#ad-url-list{
  min-height:190px;
}
.ad-summary-card{
  border:1px solid rgba(209,213,219,.85);
  border-radius:16px;
  background:linear-gradient(180deg, #ffffff 0%, #fffaf5 100%);
  padding:14px;
  display:grid;
  gap:8px;
}
.ad-summary-card span{
  color:var(--text-soft);
  font-size:.85rem;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.ad-summary-card strong{
  font-size:1.7rem;
}
.ad-service-card{
  margin-bottom:14px;
}
.ad-service-card .field-hint{
  max-width:72ch;
}
.ad-service-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.ad-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:14px;
  margin-bottom:14px;
}
.table-shell{
  overflow:auto;
  margin-top:12px;
}
.ad-table th,
.ad-table td{
  vertical-align:top;
}
.ad-row-active-country{
  background:rgba(249,115,22,.05);
}
.ad-url-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.ad-country-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:32px;
  padding:0 12px;
  border-radius:999px;
  border:1px solid rgba(249,115,22,.2);
  background:rgba(249,115,22,.1);
  color:var(--accent-strong);
  font-size:.82rem;
  font-weight:800;
  letter-spacing:.02em;
}
.ad-reference-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:12px;
  margin-top:12px;
}
.ad-reference-card,
.ad-match-card{
  border:1px solid rgba(209,213,219,.85);
  border-radius:16px;
  background:#fff;
  padding:12px;
  display:grid;
  gap:8px;
}
.ad-reference-preview,
.ad-match-compare{
  background:#f8fafc;
  border:1px solid rgba(209,213,219,.8);
  border-radius:12px;
  min-height:132px;
  display:grid;
  place-items:center;
  overflow:hidden;
}
.ad-reference-preview img,
.ad-match-compare img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.ad-reference-meta,
.ad-match-meta{
  display:grid;
  gap:4px;
  color:var(--text-soft);
  font-size:.88rem;
}
.ad-match-list{
  display:grid;
  gap:12px;
  margin-top:12px;
}
.ad-match-compare{
  grid-template-columns:1fr 1fr;
}
.ad-match-compare > div{
  min-height:140px;
  border-right:1px solid rgba(209,213,219,.85);
  display:grid;
  place-items:center;
}
.ad-match-compare > div:last-child{
  border-right:none;
}
.ad-confidence{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:4px 10px;
  background:rgba(249,115,22,.12);
  color:var(--accent-strong);
  font-weight:800;
}
.ad-match-filter{
  min-width:140px;
}

@media (max-width: 980px){
  .workspace-shell-top{
    grid-template-columns:1fr;
  }
  .workspace-shell-actions,
  .workspace-date-filter{
    grid-template-columns:1fr;
    justify-content:stretch;
  }
  .workspace-search-row{
    flex-wrap:wrap;
  }
  .workspace-search-row .input{
    min-width:0;
    width:100%;
  }
  .ad-grid{
    grid-template-columns:1fr;
  }
  #ad-panel .panel-header{
    padding:16px;
  }
}
@media (max-width: 680px){
  header{
    flex-wrap:wrap;
    align-items:flex-start;
  }
  .campaign-header{
    width:100%;
  }
  .workspace-widget-head,
  .workspace-modal-head,
  .card-head-row,
  .ad-service-card{
    flex-direction:column;
  }
  .notification-drawer{
    width:100vw;
    right:-100vw;
  }
  .workspace-modal-card{
    margin:18px auto;
    max-height:calc(100vh - 36px);
  }
}
