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

  :root {
    --bg: #0a0d0c;
    --bg-2: #131a1d;
    --surface: #11161a;
    --surface-2: #181e22;
    --surface-3: #1f262b;
    --border: rgba(255,255,255,0.07);
    --border-2: rgba(255,255,255,0.13);
    --border-accent: rgba(30,204,0,0.35);
    --text: #e6eaec;
    --text-2: #9ba2a5;
    --text-3: #757c7f;
    --accent: #1ecc00;
    --accent-2: #2bff0a;
    --accent-soft: rgba(30,204,0,0.12);
    --accent-soft-2: rgba(30,204,0,0.06);
    --accent-glow: 0 0 0 1px rgba(30,204,0,0.35), 0 0 24px rgba(30,204,0,0.18);
    --danger: #ff5252;
    --danger-soft: rgba(255,82,82,0.12);
    --on-accent: #000;
    --overlay-bg: rgba(10,13,12,0.75);
    --modal-bg: rgba(5,7,7,0.7);
    --modal-shadow: 0 20px 48px rgba(0,0,0,0.6);
    --grid-dot: rgba(255,255,255,0.025);
    --select-arrow: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' fill='none' stroke='%239ba2a5' stroke-width='1.5'%3E%3Cpath d='M3 4.5l3 3 3-3'/%3E%3C/svg%3E");
    --r-lg: 10px;
    --r-md: 6px;
    --r-sm: 4px;
  }

  [data-theme="light"] {
    --bg: #f5f6f5;
    --bg-2: #eef0ee;
    --surface: #ffffff;
    --surface-2: #f0f2f0;
    --surface-3: #e4e7e4;
    --border: rgba(0,0,0,0.08);
    --border-2: rgba(0,0,0,0.14);
    --border-accent: rgba(22,163,0,0.4);
    --text: #14181a;
    --text-2: #5a6266;
    --text-3: #686f72;
    --accent: #16a300;
    --accent-2: #1ecc00;
    --accent-soft: rgba(22,163,0,0.10);
    --accent-soft-2: rgba(22,163,0,0.05);
    --accent-glow: 0 0 0 1px rgba(22,163,0,0.3), 0 0 18px rgba(22,163,0,0.14);
    --danger: #d93838;
    --danger-soft: rgba(217,56,56,0.10);
    --on-accent: #ffffff;
    --overlay-bg: rgba(245,246,245,0.82);
    --modal-bg: rgba(20,24,26,0.35);
    --modal-shadow: 0 20px 48px rgba(20,30,25,0.18);
    --grid-dot: rgba(20,30,25,0.05);
    --select-arrow: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' fill='none' stroke='%235a6266' stroke-width='1.5'%3E%3Cpath d='M3 4.5l3 3 3-3'/%3E%3C/svg%3E");
  }

  html, body { height: 100%; }
  body { font-family: 'Space Grotesk', system-ui, sans-serif; background: var(--bg); color: var(--text); font-size: 15px; line-height: 1.55; -webkit-font-smoothing: antialiased; overflow: hidden; }
  .mono, .mono-label { font-family: 'JetBrains Mono', monospace; font-feature-settings: "tnum" 1; }
  .skip-link { position: absolute; left: 8px; top: -40px; background: var(--accent); color: var(--on-accent); padding: 8px 14px; border-radius: var(--r-md); font-size: 13px; font-weight: 500; z-index: 1000; text-decoration: none; }
  .skip-link:focus { top: 8px; }
  *:focus { outline: none; }
  *:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; border-radius: var(--r-sm); }
  .app { display: flex; height: 100dvh; overflow: hidden; }
  .sidebar { width: 260px; flex-shrink: 0; background: var(--surface); border-right: 1px solid var(--border); display: flex; flex-direction: column; overflow: hidden; position: relative; }
  .sidebar-logo { padding: 32px 20px 26px; border-bottom: 1px solid var(--border); }
  .brand-logo { color: var(--text); }
  .logo-mark { display: flex; align-items: center; gap: 8px; font-size: 18px; font-weight: 600; color: var(--text); letter-spacing: -0.01em; line-height: 1; }
  .logo-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 8px var(--accent), 0 0 14px rgba(30,204,0,0.5); flex-shrink: 0; }
  .logo-sub { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-3); letter-spacing: 0.04em; margin-top: 8px; margin-left: 16px; }
  .sidebar-section { padding: 20px 16px 8px; font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-3); }
  .sidebar-nav { flex: 1; overflow-y: auto; padding-bottom: 16px; }
  .nav-item { display: flex; align-items: center; gap: 10px; padding: 9px 12px; margin: 1px 8px; border-radius: var(--r-md); cursor: pointer; color: var(--text-2); font-size: 14px; font-family: inherit; font-weight: 400; transition: background 0.12s, color 0.12s; border: none; background: none; width: calc(100% - 16px); text-align: left; min-height: 36px; position: relative; }
  .nav-item:hover { background: var(--surface-2); color: var(--text); }
  .nav-item.active { background: var(--accent-soft); color: var(--accent); }
  .nav-item.active::before { content: ''; position: absolute; left: -8px; top: 50%; transform: translateY(-50%); width: 3px; height: 16px; background: var(--accent); border-radius: 0 2px 2px 0; box-shadow: 0 0 8px var(--accent); }
  .nav-item .nav-icon { width: 16px; height: 16px; flex-shrink: 0; }
  .client-list { padding: 0 8px; }
  .client-chip { display: flex; align-items: center; gap: 10px; padding: 7px 10px; border-radius: var(--r-md); cursor: pointer; margin-bottom: 1px; transition: background 0.12s; border: none; background: none; width: 100%; text-align: left; font-family: inherit; color: var(--text-2); min-height: 36px; }
  .client-chip:hover { background: var(--surface-2); color: var(--text); }
  .client-chip.active { background: var(--accent-soft); color: var(--accent); }
  .client-avatar { width: 26px; height: 26px; border-radius: var(--r-sm); background: var(--surface-3); color: var(--text-2); display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 600; font-family: 'JetBrains Mono', monospace; flex-shrink: 0; border: 1px solid var(--border); }
  .client-chip.active .client-avatar { background: var(--accent-soft); color: var(--accent); border-color: var(--border-accent); }
  .client-name { font-size: 13px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex: 1; }
  .sidebar-footer { padding: 12px; border-top: 1px solid var(--border); }
  .btn-new { width: 100%; padding: 10px 12px; background: var(--accent); color: var(--on-accent); border: none; border-radius: var(--r-md); font-family: inherit; font-size: 13px; font-weight: 600; cursor: pointer; transition: background 0.15s, box-shadow 0.15s, transform 0.1s; letter-spacing: 0.01em; min-height: 40px; display: flex; align-items: center; justify-content: center; gap: 6px; }
  .btn-new:hover { background: var(--accent-2); box-shadow: var(--accent-glow); }
  .btn-new:active { transform: translateY(1px); }
  .main { flex: 1; display: flex; flex-direction: column; overflow: hidden; min-width: 0; }
  .topbar { padding: 18px 32px; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; background: var(--bg); flex-shrink: 0; gap: 16px; min-height: 72px; }
  .topbar-title { font-size: 22px; font-weight: 600; letter-spacing: -0.02em; color: var(--text); }
  .topbar-sub { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-3); margin-top: 4px; letter-spacing: 0.02em; }
  .topbar-breadcrumb { display: none; align-items: center; gap: 4px; font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-3); margin-bottom: 6px; flex-wrap: wrap; letter-spacing: 0.02em; }
  .topbar-breadcrumb.show { display: flex; }
  .topbar-breadcrumb .crumb-back { display: inline-flex; align-items: center; gap: 4px; color: var(--text-2); cursor: pointer; background: none; border: 1px solid var(--border); padding: 3px 8px 3px 6px; font: inherit; border-radius: var(--r-md); transition: color .15s, background .15s, border-color .15s; margin-right: 6px; }
  .topbar-breadcrumb .crumb-back:hover { color: var(--text); background: var(--surface-2); border-color: var(--border-2); }
  .topbar-breadcrumb .crumb-back svg { width: 12px; height: 12px; }
  .topbar-breadcrumb .crumb { color: var(--text-3); cursor: pointer; background: none; border: none; padding: 2px 4px; font: inherit; border-radius: var(--r-md); transition: color .15s, background .15s; max-width: 220px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .topbar-breadcrumb .crumb:hover { color: var(--text); background: var(--surface-2); }
  .topbar-breadcrumb .crumb.current { color: var(--text); cursor: default; }
  .topbar-breadcrumb .crumb.current:hover { background: none; }
  .topbar-breadcrumb .crumb-sep { color: var(--text-3); opacity: 0.6; }
  .topbar-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
  .menu-toggle { display: none; width: 40px; height: 40px; align-items: center; justify-content: center; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); cursor: pointer; color: var(--text); flex-shrink: 0; }
  .menu-toggle:hover { background: var(--surface-2); }
  .theme-toggle { width: 40px; height: 40px; display: inline-flex; align-items: center; justify-content: center; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); cursor: pointer; color: var(--text-2); flex-shrink: 0; transition: background 0.15s, color 0.15s, border-color 0.15s; }
  .theme-toggle:hover { background: var(--surface-2); color: var(--text); border-color: var(--border-2); }
  #authBtn.authenticated { color: #22c55e; border-color: rgba(34,197,94,0.35); position: relative; }
  #authBtn.authenticated::after { content: ''; position: absolute; top: 8px; right: 8px; width: 6px; height: 6px; border-radius: 50%; background: #22c55e; }
  .theme-toggle .theme-icon-light { display: none; }
  [data-theme="light"] .theme-toggle .theme-icon-dark { display: none; }
  [data-theme="light"] .theme-toggle .theme-icon-light { display: block; }
  .btn { padding: 9px 16px; border-radius: var(--r-md); font-family: inherit; font-size: 13px; font-weight: 500; cursor: pointer; transition: background 0.15s, border-color 0.15s, color 0.15s; border: 1px solid var(--border-2); background: var(--surface); color: var(--text); min-height: 36px; display: inline-flex; align-items: center; gap: 6px; }
  .btn:hover { background: var(--surface-2); border-color: var(--text-3); }
  .btn-primary { background: var(--accent); color: var(--on-accent); border-color: var(--accent); font-weight: 600; }
  .btn-primary:hover { background: var(--accent-2); border-color: var(--accent-2); box-shadow: var(--accent-glow); }
  .btn-primary:disabled { opacity: 0.5; cursor: not-allowed; box-shadow: none; }
  .btn-danger { color: var(--danger); border-color: rgba(255,82,82,0.25); }
  .btn-danger:hover { background: var(--danger-soft); border-color: var(--danger); color: var(--danger); }
  .content { flex: 1; overflow-y: auto; padding: 28px 32px 64px; position: relative; }
  .content::before { content: ''; position: absolute; inset: 0; background-image: radial-gradient(circle, var(--grid-dot) 1px, transparent 1px); background-size: 28px 28px; pointer-events: none; z-index: 0; mask-image: linear-gradient(180deg, rgba(0,0,0,0.4), rgba(0,0,0,0)); }
  .content > * { position: relative; z-index: 1; }
  .view { display: none; }
  .view.active { display: block; }
  .stats-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 36px; }
  .stat-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 18px 22px; position: relative; overflow: hidden; transition: border-color 0.2s, background 0.2s; }
  .stat-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--accent-soft), transparent); opacity: 0; transition: opacity 0.25s; }
  .stat-card:hover { border-color: var(--border-2); }
  .stat-card:hover::before { opacity: 1; }
  .stat-label { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.1em; }
  .stat-value { font-family: 'JetBrains Mono', monospace; font-size: 32px; font-weight: 500; color: var(--text); margin-top: 6px; letter-spacing: -0.02em; font-feature-settings: "tnum" 1; line-height: 1.1; }
  .stat-sub { font-size: 12px; color: var(--text-3); margin-top: 4px; }
  .section-title { font-size: 16px; font-weight: 600; color: var(--text); margin-bottom: 14px; letter-spacing: -0.01em; display: flex; align-items: center; gap: 10px; }
  .section-title::before { content: ''; width: 4px; height: 14px; background: var(--accent); border-radius: 1px; box-shadow: 0 0 6px var(--accent-soft); }
  .client-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 12px; }
  .sort-bar { display: flex; align-items: center; gap: 8px; margin-bottom: 14px; flex-wrap: wrap; }
  .sort-bar-label { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.08em; margin-right: 4px; }
  .sort-btn { padding: 5px 12px; border-radius: var(--r-md); border: 1px solid var(--border-2); background: var(--surface); color: var(--text-2); font-family: inherit; font-size: 12px; cursor: pointer; transition: all 0.15s; white-space: nowrap; }
  .sort-btn:hover { background: var(--surface-2); color: var(--text); border-color: var(--text-3); }
  .sort-btn.active { background: var(--accent-soft); color: var(--accent); border-color: var(--border-accent); }
  .client-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 18px 22px; cursor: pointer; transition: border-color 0.2s, background 0.2s, transform 0.15s; text-align: left; width: 100%; font-family: inherit; color: inherit; position: relative; overflow: hidden; }
  .client-card:hover { border-color: var(--border-accent); background: var(--surface-2); transform: translateY(-1px); }
  .client-card:hover .cc-avatar { background: var(--accent-soft); color: var(--accent); border-color: var(--border-accent); }
  .cc-header { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 12px; }
  .cc-menu-btn { position: absolute; top: 10px; right: 10px; width: 28px; height: 28px; border-radius: var(--r-sm); border: none; background: transparent; color: var(--text-3); cursor: pointer; display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity 0.15s, background 0.15s, color 0.15s; flex-shrink: 0; z-index: 2; }
  .client-card:hover .cc-menu-btn { opacity: 1; }
  .cc-menu-btn:hover { background: var(--surface-3); color: var(--text); }
  .cc-dropdown { position: absolute; top: 36px; right: 10px; background: var(--surface-2); border: 1px solid var(--border-2); border-radius: var(--r-md); box-shadow: 0 8px 24px rgba(0,0,0,0.4); min-width: 160px; z-index: 50; overflow: hidden; }
  .cc-dropdown-item { display: flex; align-items: center; gap: 8px; padding: 9px 14px; font-size: 13px; color: var(--text-2); cursor: pointer; transition: background 0.1s, color 0.1s; border: none; background: none; width: 100%; text-align: left; font-family: inherit; }
  .cc-dropdown-item:hover { background: var(--surface-3); color: var(--text); }
  .cc-dropdown-item.danger { color: var(--danger); }
  .cc-dropdown-item.danger:hover { background: var(--danger-soft); color: var(--danger); }
  .cc-avatar { width: 36px; height: 36px; border-radius: var(--r-md); background: var(--surface-3); border: 1px solid var(--border-2); display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 600; color: var(--text-2); font-family: 'JetBrains Mono', monospace; flex-shrink: 0; transition: background 0.2s, color 0.2s, border-color 0.2s; }
  .cc-name { font-weight: 500; font-size: 15px; color: var(--text); }
  .cc-toimiala { font-size: 12px; color: var(--text-3); margin-top: 2px; }
  .cc-meta { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--border); }
  .tag { font-size: 11px; padding: 3px 9px; border-radius: var(--r-sm); background: var(--surface-3); color: var(--text-2); border: 1px solid var(--border); font-family: 'JetBrains Mono', monospace; letter-spacing: 0.01em; }
  .tag.accent { background: var(--accent-soft); color: var(--accent); border-color: var(--border-accent); }
  .tag.success { background: var(--accent-soft); color: var(--accent); border-color: var(--border-accent); }
  .tag.success::before { content: '●'; margin-right: 4px; font-size: 8px; vertical-align: middle; }
  .some-chip { display: inline-flex; align-items: center; gap: 4px; padding: 4px 10px; font-size: 12px; background: var(--surface-2); color: var(--text-2); border: 1px solid var(--border); border-radius: var(--r-md); text-decoration: none; font-family: 'JetBrains Mono', monospace; transition: background .15s, color .15s, border-color .15s; }
  .some-chip:hover { background: var(--accent-soft); color: var(--accent); border-color: var(--border-accent); }
  .some-chip::before { content: '↗ '; opacity: 0.6; }
  .kpi-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-bottom: 14px; }
  .kpi-tile { display: flex; flex-direction: column; align-items: flex-start; gap: 4px; padding: 12px 14px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); cursor: pointer; text-align: left; font-family: inherit; color: inherit; transition: background .15s, border-color .15s, transform .12s; min-height: 88px; }
  .kpi-tile:hover { background: var(--surface-2); border-color: var(--border-2); transform: translateY(-1px); }
  .kpi-tile-label { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.08em; }
  .kpi-tile-value { font-size: 24px; font-weight: 600; color: var(--text); line-height: 1.1; }
  .kpi-tile-sub { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-3); }
  @media (max-width: 720px) { .kpi-row { grid-template-columns: repeat(2, 1fr); } }
  .sources-section { margin-bottom: 14px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); overflow: hidden; }
  .sources-section > summary { display: flex; align-items: center; gap: 8px; padding: 10px 14px; cursor: pointer; font-size: 13px; color: var(--text-2); list-style: none; transition: background .15s; }
  .sources-section > summary::-webkit-details-marker { display: none; }
  .sources-section > summary::before { content: '▸'; font-size: 10px; color: var(--text-3); transition: transform .15s; }
  .sources-section[open] > summary::before { transform: rotate(90deg); }
  .sources-section > summary:hover { background: var(--surface-2); }
  .sources-title { font-weight: 500; }
  .sources-count { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-3); background: var(--surface-3); padding: 1px 7px; border-radius: 999px; }
  .sources-body { padding: 4px 14px 14px; display: flex; flex-direction: column; gap: 12px; }
  .sources-list { list-style: none; display: flex; flex-direction: column; gap: 8px; }
  .source-item { padding: 10px 12px; background: var(--bg-2); border: 1px solid var(--border); border-radius: var(--r-md); display: flex; flex-direction: column; gap: 4px; }
  .source-item-head { display: flex; align-items: center; gap: 8px; }
  .source-type { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--accent); background: var(--accent-soft); padding: 2px 7px; border-radius: var(--r-sm); text-transform: uppercase; letter-spacing: 0.05em; }
  .source-date { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-3); margin-left: auto; }
  .source-date.stale { color: #eab308; }
  .source-date.stale::before { content: '⚠ '; }
  .source-delete { background: none; border: none; color: var(--text-3); cursor: pointer; font-size: 18px; line-height: 1; padding: 0 4px; transition: color .15s; }
  .source-delete:hover { color: var(--danger); }
  .source-label { font-size: 13px; color: var(--text); }
  .source-label a { color: var(--accent); text-decoration: none; }
  .source-label a:hover { text-decoration: underline; }
  .source-meta, .source-summary { font-size: 12px; color: var(--text-3); }
  .source-summary { font-style: italic; }
  .sources-empty { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-3); padding: 4px 0; }
  .sources-add { align-self: flex-start; font-size: 12px; padding: 6px 12px; }
  .form-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
  .form-full { grid-column: 1 / -1; }
  .field { display: flex; flex-direction: column; gap: 6px; }
  .field label { font-family: 'JetBrains Mono', monospace; font-size: 11px; font-weight: 500; color: var(--text-2); text-transform: uppercase; letter-spacing: 0.06em; }
  .req { color: var(--accent); margin-left: 2px; }
  .field input, .field select, .field textarea { padding: 10px 14px; border: 1px solid var(--border-2); border-radius: var(--r-md); background: var(--surface); font-family: inherit; font-size: 14px; color: var(--text); transition: border-color 0.15s, box-shadow 0.15s, background 0.15s; outline: none; width: 100%; min-height: 40px; }
  .field input::placeholder, .field textarea::placeholder { color: var(--text-3); opacity: 0.7; }
  .field select { appearance: none; -webkit-appearance: none; background-image: var(--select-arrow); background-repeat: no-repeat; background-position: right 12px center; background-size: 12px; padding-right: 32px; }
  .field select option { background: var(--surface); color: var(--text); }
  .field input:hover, .field select:hover, .field textarea:hover { border-color: var(--text-3); }
  .field input:focus-visible, .field select:focus-visible, .field textarea:focus-visible { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); outline: none; }
  .field.invalid input, .field.invalid select, .field.invalid textarea { border-color: var(--danger); }
  .field-error { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--danger); display: none; }
  .field.invalid .field-error { display: block; }
  .field textarea { resize: vertical; min-height: 80px; }
  .form-section { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 22px 24px; margin-bottom: 16px; }
  .form-section-title { font-family: 'JetBrains Mono', monospace; font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-2); margin-bottom: 18px; padding-bottom: 12px; border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 8px; }
  .form-section-title .step-num { color: var(--accent); font-weight: 600; }
  .tags-picker { display: flex; flex-wrap: wrap; gap: 6px; }
  .tag-pick { padding: 7px 14px; border-radius: var(--r-md); border: 1px solid var(--border-2); background: var(--bg); font-size: 12px; color: var(--text-2); cursor: pointer; transition: all 0.15s; font-family: inherit; min-height: 32px; }
  .tag-pick:hover { border-color: var(--accent); color: var(--accent); }
  .tag-pick.on { background: var(--accent-soft); border-color: var(--border-accent); color: var(--accent); }
  .range-row { display: flex; align-items: center; gap: 14px; }
  .range-row input[type=range] { flex: 1; accent-color: var(--accent); height: 4px; }
  .range-val { font-family: 'JetBrains Mono', monospace; font-weight: 500; font-size: 14px; color: var(--accent); min-width: 70px; text-align: right; font-feature-settings: "tnum" 1; }
  .result-wrap { animation: fadeIn 0.3s ease; }
  @keyframes fadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
  .result-section { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 22px 24px; margin-bottom: 16px; }
  .result-section-title { font-size: 16px; font-weight: 600; color: var(--text); margin-bottom: 16px; letter-spacing: -0.01em; display: flex; align-items: center; gap: 10px; }
  .result-section-title::before { content: ''; width: 4px; height: 14px; background: var(--accent); border-radius: 1px; box-shadow: 0 0 6px var(--accent-soft); }
  .month-row { display: grid; grid-template-columns: 130px 1fr; gap: 18px; padding: 14px 0; border-bottom: 1px solid var(--border); align-items: start; }
  .month-row:last-child { border-bottom: none; }
  .month-label { font-weight: 500; font-size: 14px; color: var(--text); font-family: 'JetBrains Mono', monospace; }
  .month-theme { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--accent); background: var(--accent-soft); border: 1px solid var(--border-accent); padding: 2px 8px; border-radius: var(--r-sm); display: inline-block; margin-top: 6px; }
  .month-detail { font-size: 13px; color: var(--text-2); line-height: 1.6; }
  .month-detail strong { color: var(--text); font-weight: 500; }
  .kampanja-card { border: 1px solid var(--border); background: var(--surface-2); border-radius: var(--r-md); padding: 16px 20px; margin-bottom: 12px; }
  .kampanja-header { display: flex; flex-direction: column; gap: 6px; margin-bottom: 8px; }
  .kampanja-header-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; flex-wrap: wrap; }
  .kampanja-name { font-weight: 600; font-size: 15px; color: var(--text); line-height: 1.3; }
  .kampanja-budget { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--accent); font-weight: 500; white-space: nowrap; font-feature-settings: "tnum" 1; background: var(--accent-soft); border: 1px solid var(--border-accent); border-radius: 4px; padding: 2px 8px; align-self: flex-start; }
  .kampanja-meta { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-3); margin-bottom: 14px; letter-spacing: 0.02em; line-height: 1.6; word-break: break-word; }
  .ad-card { background: var(--bg); border: 1px solid var(--border); border-radius: var(--r-sm); padding: 12px 16px; margin-bottom: 8px; border-left: 2px solid var(--accent); }
  .ad-var { font-family: 'JetBrains Mono', monospace; font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-3); margin-bottom: 6px; }
  .ad-headline { font-weight: 600; font-size: 14px; color: var(--text); margin-bottom: 4px; }
  .ad-body { font-size: 13px; color: var(--text-2); line-height: 1.55; }
  .ad-cta { display: inline-block; margin-top: 10px; font-family: 'JetBrains Mono', monospace; font-size: 10px; padding: 3px 10px; border-radius: var(--r-sm); background: var(--accent-soft); color: var(--accent); border: 1px solid var(--border-accent); text-transform: uppercase; letter-spacing: 0.06em; }
  .kuvabrief { margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--border); font-size: 13px; color: var(--text-2); line-height: 1.6; }
  .kuvabrief strong { color: var(--text); font-weight: 500; }
  .kuvabrief-actions { display: flex; align-items: center; gap: 10px; margin-top: 10px; flex-wrap: wrap; }
  .btn-gen-img { display: inline-flex; align-items: center; gap: 6px; padding: 7px 14px; background: var(--surface-3); border: 1px solid var(--border-2); border-radius: var(--r-md); color: var(--text); font-family: inherit; font-size: 12px; font-weight: 500; cursor: pointer; transition: background 0.12s, border-color 0.12s, color 0.12s; white-space: nowrap; }
  .btn-gen-img:hover { background: var(--accent-soft); border-color: var(--border-accent); color: var(--accent); }
  .ad-img-preview { margin-top: 12px; border-radius: var(--r-md); overflow: hidden; border: 1px solid var(--border-2); }
  .ad-img-preview img { display: block; width: 100%; height: auto; max-height: 320px; object-fit: contain; background: var(--surface-3); }
  .ad-img-actions { display: flex; gap: 8px; padding: 8px 10px; background: var(--surface-2); border-top: 1px solid var(--border); }
  .btn-gen-img[style*="60a5fa"]:hover { background: rgba(59,130,246,0.12); border-color: rgba(59,130,246,0.5); color: #60a5fa; }
  .btn-gen-img:disabled { opacity: 0.45; cursor: not-allowed; }
  .btn-gen-img svg { flex-shrink: 0; }
  .img-result { margin-top: 14px; border-radius: var(--r-md); overflow: hidden; border: 1px solid var(--border); background: var(--surface-3); position: relative; }
  .img-result img { display: block; width: 100%; height: auto; border-radius: var(--r-md); }
  .img-result-actions { display: flex; gap: 8px; padding: 10px 12px; background: var(--surface-2); border-top: 1px solid var(--border); }
  .img-loader { display: flex; align-items: center; gap: 10px; padding: 18px 16px; font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-2); letter-spacing: 0.06em; }
  .img-loader-ring { width: 18px; height: 18px; border: 2px solid var(--surface-3); border-top-color: var(--accent); border-radius: 50%; animation: spin 0.8s linear infinite; flex-shrink: 0; }
  .img-error { padding: 12px 16px; font-size: 12px; color: var(--danger); font-family: 'JetBrains Mono', monospace; }
  .settings-section { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 22px 24px; margin-bottom: 16px; }
  .theme-picker { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; max-width: 480px; }
  .theme-option { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; padding: 18px 12px; background: var(--bg); border: 1px solid var(--border-2); border-radius: var(--r-md); color: var(--text-2); font-family: inherit; font-size: 13px; cursor: pointer; transition: background 0.15s, border-color 0.15s, color 0.15s; min-height: 88px; }
  .theme-option:hover { background: var(--surface-2); border-color: var(--text-3); color: var(--text); }
  .theme-option.active { background: var(--accent-soft); border-color: var(--border-accent); color: var(--accent); }
  .theme-option-label { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; }
  @media (max-width: 480px) { .theme-picker { grid-template-columns: 1fr; } }
  .settings-section-title { font-size: 14px; font-weight: 600; color: var(--text); margin-bottom: 16px; display: flex; align-items: center; gap: 10px; letter-spacing: -0.01em; }
  .settings-section-title::before { content: ''; width: 4px; height: 14px; background: var(--accent); border-radius: 1px; box-shadow: 0 0 6px var(--accent-soft); }
  .input-with-action { display: flex; gap: 8px; align-items: stretch; }
  .input-with-action input { flex: 1; min-width: 0; }
  .input-with-action .fetch-info-btn { flex-shrink: 0; white-space: nowrap; padding: 0 14px; min-height: 40px; font-size: 12px; gap: 6px; }
  .input-with-action .fetch-info-btn:disabled { opacity: 0.55; cursor: progress; }
  .fetch-info-btn .spin { animation: spin 0.8s linear infinite; }
  .field-hint { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-3); margin-top: 6px; line-height: 1.5; }
  .field-hint strong { color: var(--text-2); font-weight: 500; }
  .api-key-row { display: flex; gap: 8px; align-items: stretch; }
  .api-key-row .field { flex: 1; margin-bottom: 0; }
  .api-key-row .btn { padding-top: 0; padding-bottom: 0; min-height: 0; }
  .api-status { font-family: 'JetBrains Mono', monospace; font-size: 11px; margin-top: 8px; display: flex; align-items: center; gap: 6px; }
  .api-status.ok { color: var(--accent); }
  .api-status.missing { color: var(--text-3); }
  .budget-table { width: 100%; border-collapse: collapse; }
  .budget-table tr { border-bottom: 1px solid var(--border); }
  .budget-table tr:last-child { border-bottom: none; }
  .budget-table td { padding: 10px 0; font-size: 14px; color: var(--text-2); }
  .budget-table td:last-child { text-align: right; color: var(--accent); font-weight: 500; font-family: 'JetBrains Mono', monospace; font-feature-settings: "tnum" 1; }
  .budget-table tr.budget-total { border-top: 2px solid var(--border); border-bottom: none; }
  .budget-table tr.budget-total td { font-weight: 600; padding-top: 14px; color: var(--text); }
  .budget-table tr.budget-total td:last-child { color: var(--accent); }
  .budget-table tr.budget-period { border-top: none; }
  .budget-table tr.budget-period td { padding-top: 4px; font-size: 13px; }
  .loading-overlay { position: fixed; inset: 0; z-index: 999; display: none; align-items: center; justify-content: center; flex-direction: column; gap: 28px; background: var(--overlay-bg); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); animation: fadeIn 0.2s ease; }
  .loading-overlay.show { display: flex; }
  .loading-spinner { width: 44px; height: 44px; border: 2px solid rgba(30,204,0,0.15); border-top-color: var(--accent); border-radius: 50%; animation: spin 1.2s linear infinite; box-shadow: 0 0 20px rgba(30,204,0,0.2); }
  .loading-box { display: flex; flex-direction: column; align-items: center; gap: 12px; }
  .loading-label { font-family: 'JetBrains Mono', monospace; font-size: 13px; color: var(--accent); letter-spacing: 0.08em; text-align: center; transition: opacity 0.6s ease; }
  .loading-label::before { content: '> '; opacity: 0.5; }
  .loading-sublabel { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-3); letter-spacing: 0.05em; text-align: center; transition: opacity 0.6s ease; }
  .loading-progress { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--accent); letter-spacing: 0.05em; text-align: center; min-height: 16px; margin-top: 4px; }
  .loading-progress:empty { display: none; }
  .loading-preview { max-width: min(620px, 80vw); padding: 10px 14px; background: var(--bg-2); border: 1px solid var(--border); border-radius: var(--r-md); font-size: 12px; line-height: 1.5; color: var(--text-2); text-align: left; max-height: 6.5em; overflow: hidden; position: relative; }
  .loading-preview:empty { display: none; }
  .loading-preview::after { content: ''; position: absolute; left: 0; right: 0; bottom: 0; height: 2.5em; background: linear-gradient(transparent, var(--bg-2)); pointer-events: none; }
  .loader-ring { width: 36px; height: 36px; border: 2px solid var(--surface-3); border-top-color: var(--accent); border-radius: 50%; animation: spin 0.8s linear infinite; box-shadow: 0 0 12px rgba(30,204,0,0.15); }
  @keyframes spin { to { transform: rotate(360deg); } }
  .loader-text { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--text-2); text-transform: uppercase; letter-spacing: 0.12em; animation: pulse 1.5s ease-in-out infinite; }
  .loader-text::before { content: '> '; color: var(--accent); }

  .notes-wrap { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; margin-bottom: 16px; }
  .notes-title { font-size: 15px; font-weight: 600; color: var(--text); letter-spacing: -0.01em; display: flex; align-items: center; gap: 10px; padding: 14px 20px; border-bottom: 1px solid var(--border); }
  .notes-title::before { content: ''; width: 4px; height: 14px; background: var(--accent); border-radius: 1px; box-shadow: 0 0 6px var(--accent-soft); }
  .notes-count { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-3); background: var(--surface-3); padding: 2px 8px; border-radius: 10px; font-weight: 400; }
  .notes-list { max-height: 360px; overflow-y: auto; padding: 12px 16px; display: flex; flex-direction: column; gap: 10px; }
  .notes-empty { text-align: center; padding: 28px 0; font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--text-3); }
  .note-item { display: flex; gap: 10px; align-items: flex-start; animation: fadeIn 0.2s ease; }
  .note-avatar { width: 28px; height: 28px; border-radius: 6px; background: var(--accent-soft); border: 1px solid var(--border-accent); color: var(--accent); font-size: 11px; font-weight: 700; font-family: 'JetBrains Mono', monospace; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 2px; }
  .note-body { flex: 1; min-width: 0; }
  .note-meta { display: flex; align-items: baseline; gap: 8px; margin-bottom: 3px; }
  .note-author { font-size: 13px; font-weight: 600; color: var(--text); }
  .note-time { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-3); }
  .note-text { font-size: 13px; color: var(--text-2); line-height: 1.6; background: var(--surface-2); border: 1px solid var(--border); border-radius: 0 8px 8px 8px; padding: 8px 12px; white-space: pre-wrap; word-break: break-word; }
  .note-delete { background: none; border: none; color: var(--text-3); cursor: pointer; padding: 2px 6px; font-size: 16px; line-height: 1; transition: color 0.15s, background 0.15s; flex-shrink: 0; margin-top: 4px; border-radius: var(--r-sm); }
  .note-delete:hover { color: var(--danger); background: var(--danger-soft); }
  .notes-input-wrap { padding: 12px 16px; border-top: 1px solid var(--border); background: var(--surface-2); }
  .notes-input-row { display: flex; gap: 8px; align-items: flex-end; }
  .notes-input { flex: 1; padding: 10px 14px; background: var(--bg); border: 1px solid var(--border-2); border-radius: var(--r-md); font-family: inherit; font-size: 13px; color: var(--text); resize: none; min-height: 40px; max-height: 120px; line-height: 1.5; transition: border-color 0.15s, box-shadow 0.15s; }
  .notes-input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
  .notes-input::placeholder { color: var(--text-3); }
  .notes-send { padding: 10px 16px; background: var(--accent); color: var(--on-accent); border: none; border-radius: var(--r-md); font-family: inherit; font-size: 13px; font-weight: 600; cursor: pointer; transition: background 0.15s; flex-shrink: 0; display: flex; align-items: center; gap: 6px; min-height: 40px; }
  .notes-send:hover { background: var(--accent-2); }
  .notes-hint { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-3); margin-top: 6px; }
  @keyframes pulse { 0%,100% { opacity: 0.55; } 50% { opacity: 1; } }
  .empty { text-align: center; padding: 64px 20px; color: var(--text-3); grid-column: 1 / -1; }
  .empty-icon { width: 44px; height: 44px; margin: 0 auto 16px; color: var(--text-3); opacity: 0.5; }
  .empty-title { font-size: 17px; font-weight: 600; color: var(--text-2); margin-bottom: 6px; letter-spacing: -0.01em; }
  .empty-sub { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--text-3); }
  .empty-sub::before { content: '// '; color: var(--accent); opacity: 0.6; }
  .toast { position: fixed; bottom: 24px; right: 24px; background: var(--surface-2); border: 1px solid var(--border-accent); color: var(--text); padding: 12px 18px; border-radius: var(--r-md); font-size: 13px; opacity: 0; transform: translateY(8px); transition: opacity 0.25s, transform 0.25s; pointer-events: none; z-index: 100; box-shadow: 0 8px 24px rgba(0,0,0,0.4), var(--accent-glow); display: flex; align-items: center; gap: 10px; max-width: calc(100vw - 48px); }
  .toast.show { opacity: 1; transform: translateY(0); pointer-events: auto; }
  .toast::before { content: ''; width: 8px; height: 8px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 6px var(--accent); flex-shrink: 0; }
  .toast.error { border-color: rgba(255,82,82,0.5); box-shadow: 0 8px 24px rgba(0,0,0,0.4), 0 0 24px rgba(255,82,82,0.2); }
  .toast.error::before { background: var(--danger); box-shadow: 0 0 6px var(--danger); }
  .modal-bg { position: fixed; inset: 0; background: var(--modal-bg); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); align-items: center; justify-content: center; z-index: 80; display: none; padding: 24px; animation: fadeIn 0.15s ease; }
  .modal-bg.open { display: flex; }
  .modal { background: var(--surface); border: 1px solid var(--border-2); border-radius: var(--r-lg); padding: 24px 28px; width: 440px; max-width: 100%; max-height: 80vh; overflow-y: auto; box-shadow: var(--modal-shadow); }
  .modal-title { font-size: 18px; font-weight: 600; margin-bottom: 8px; letter-spacing: -0.01em; }
  .modal-body { color: var(--text-2); font-size: 14px; line-height: 1.55; margin-bottom: 20px; }
  .modal-actions { display: flex; gap: 8px; justify-content: flex-end; }
  .sidebar-scrim { position: fixed; inset: 0; background: rgba(0,0,0,0.5); backdrop-filter: blur(2px); z-index: 55; display: none; }
  .sidebar-scrim.show { display: block; }
  ::-webkit-scrollbar { width: 8px; height: 8px; }
  ::-webkit-scrollbar-track { background: transparent; }
  ::-webkit-scrollbar-thumb { background: var(--surface-3); border-radius: 4px; }
  ::-webkit-scrollbar-thumb:hover { background: var(--border-2); }
  ::selection { background: var(--accent-soft); color: var(--accent); }
  @media (max-width: 860px) { .stats-grid { grid-template-columns: 1fr; } .form-grid { grid-template-columns: 1fr; } .topbar { padding: 14px 18px; min-height: 64px; } .topbar-title { font-size: 18px; } .content { padding: 20px 18px 56px; } .month-row { grid-template-columns: 1fr; gap: 8px; } .kello-grid { grid-template-columns: 1fr !important; } }
  @media (max-width: 600px) {
    .kello-grid { grid-template-columns: 1fr !important; }
    /* Topbar — toimintonapit kääriytyvät omalle riville mobiilissa */
    .topbar { padding: 10px 12px; gap: 6px; min-height: 0; flex-wrap: wrap; row-gap: 6px; }
    .topbar-title { font-size: 15px; line-height: 1.25; }
    .topbar-sub { font-size: 10px; margin-top: 2px; }
    .topbar > div[style*="flex:1"] { min-width: 0; }
    /* Toimintonapit (Muokkaa/Yhdistä/Poista yms.) toiselle riville */
    .topbar-actions { flex: 1 1 100%; order: 1; gap: 4px; flex-wrap: wrap; }
    .topbar-actions:empty { display: none; }
    /* Topbar-toimintonapit ikoneiksi — mahduttavat 3+ napit kapealle ruudulle */
    .topbar-btn { padding: 0 10px !important; min-width: 38px; gap: 0 !important; justify-content: center; flex: 0 1 auto; }
    .topbar-btn .btn-label { display: none; }
    .menu-toggle, .theme-toggle { width: 38px; height: 38px; flex-shrink: 0; }
    /* Asiakaslista — yksi sarake, kapeampi padding */
    .client-grid { grid-template-columns: 1fr; gap: 10px; }
    .client-card { padding: 14px 16px; }
    .cc-menu-btn { opacity: 1; top: 8px; right: 8px; }
    /* Video-, strategia- ja kuvakortit — yksi sarake */
    .video-grid, .strategy-grid { grid-template-columns: 1fr; gap: 10px; }
    .video-card, .strategy-card { padding: 14px 16px; }
    /* Asiakas-välilehdet — kompaktit, vaakavieritettävät */
    .client-tabs { padding: 4px; gap: 1px; flex-wrap: nowrap; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
    .client-tabs::-webkit-scrollbar { display: none; }
    .client-tab { padding: 8px 10px; font-size: 12px; gap: 4px; flex-shrink: 0; white-space: nowrap; }
    .client-tab .tab-count { font-size: 10px; padding: 0 5px; min-width: 16px; }
    /* Sisältö — pienempi padding */
    .content { padding: 16px 14px 48px; }
    /* Pikkunapit ja syöttörivit */
    .api-key-row { flex-wrap: wrap; }
    .api-key-row .field { flex-basis: 100%; }
    .api-key-row > .btn { flex-grow: 1; }
    /* Asetukset-osiot */
    .settings-section { padding: 16px; }
    /* Lomake-napit — anna täysi leveys */
    .btn-row { flex-wrap: wrap; }
    .btn-row .btn { flex: 1 1 auto; min-width: 0; }
    /* Modaalit — leveämmät napit, käärittävät */
    .modal-bg { padding: 12px; }
    .modal { padding: 18px 20px; }
    .modal-actions { flex-wrap: wrap; gap: 6px; }
    .modal-actions .btn { flex: 1 1 auto; }
    /* Sort-bar — kompakti */
    .sort-bar { gap: 6px; }
    .sort-btn { padding: 4px 9px; font-size: 11px; }
  }
  @media (max-width: 768px) { body { overflow: auto; } .app { flex-direction: column; height: auto; min-height: 100dvh; overflow: visible; } .sidebar { position: fixed; top: 0; left: 0; bottom: 0; width: 280px; transform: translateX(-100%); transition: transform 0.25s ease; z-index: 60; } .sidebar.open { transform: translateX(0); } .main { width: 100%; height: auto; } .menu-toggle { display: inline-flex; } .topbar { position: sticky; top: 0; z-index: 10; } .content { overflow: visible; } }
  @media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; scroll-behavior: auto !important; } }
  /* ── Videosuunnittelutyökalu ─────────────────────────────────────────────── */
  .video-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 12px; }
  .video-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 18px 22px; cursor: pointer; transition: border-color 0.2s, background 0.2s, transform 0.15s; text-align: left; width: 100%; font-family: inherit; color: inherit; position: relative; }
  .video-card:hover { border-color: rgba(139,92,246,0.4); background: var(--surface-2); transform: translateY(-1px); }
  .video-card-header { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 10px; }
  .video-card-icon { width: 36px; height: 36px; border-radius: var(--r-md); background: rgba(139,92,246,0.12); border: 1px solid rgba(139,92,246,0.3); display: flex; align-items: center; justify-content: center; flex-shrink: 0; color: #a78bfa; }
  .video-card-name { font-weight: 600; font-size: 15px; color: var(--text); }
  .video-card-sub { font-size: 12px; color: var(--text-3); margin-top: 2px; }
  .video-card-meta { display: flex; gap: 6px; flex-wrap: wrap; padding-top: 10px; border-top: 1px solid var(--border); }
  .tag-video { font-size: 11px; padding: 3px 9px; border-radius: var(--r-sm); background: rgba(139,92,246,0.1); color: #a78bfa; border: 1px solid rgba(139,92,246,0.25); font-family: 'JetBrains Mono', monospace; }

  .video-result-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); margin-bottom: 16px; overflow: hidden; }
  .video-result-header { padding: 16px 20px; border-bottom: 1px solid var(--border); background: var(--surface-2); display: flex; align-items: center; gap: 12px; }
  .video-num { width: 28px; height: 28px; border-radius: 50%; background: rgba(139,92,246,0.15); border: 1px solid rgba(139,92,246,0.3); color: #a78bfa; font-family: 'JetBrains Mono', monospace; font-size: 12px; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
  .video-result-title { font-weight: 600; font-size: 15px; color: var(--text); flex: 1; }
  .video-result-type { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: #a78bfa; background: rgba(139,92,246,0.1); padding: 3px 8px; border-radius: var(--r-sm); border: 1px solid rgba(139,92,246,0.2); white-space: nowrap; }
  .video-result-body { padding: 16px 20px; display: flex; flex-direction: column; gap: 14px; }
  .video-field { display: flex; flex-direction: column; gap: 4px; }
  .video-field-label { font-family: 'JetBrains Mono', monospace; font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-3); }
  .video-field-value { font-size: 13px; color: var(--text-2); line-height: 1.6; }
  .video-field-value strong { color: var(--text); font-weight: 500; }
  .video-hook { background: rgba(139,92,246,0.08); border: 1px solid rgba(139,92,246,0.2); border-radius: var(--r-md); padding: 10px 14px; font-size: 13px; color: var(--text); line-height: 1.6; font-style: italic; }
  .video-runko-item { display: flex; gap: 10px; align-items: flex-start; padding: 6px 0; border-bottom: 1px solid var(--border); }
  .video-runko-item:last-child { border-bottom: none; }
  .video-runko-num { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: #a78bfa; background: rgba(139,92,246,0.1); padding: 2px 6px; border-radius: 3px; flex-shrink: 0; margin-top: 1px; }
  .video-caption { background: var(--surface-3); border-radius: var(--r-md); padding: 10px 14px; font-size: 13px; color: var(--text-2); line-height: 1.6; white-space: pre-wrap; }
  .video-hashtags { display: flex; flex-wrap: wrap; gap: 6px; }
  .video-hashtag { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: #60a5fa; background: rgba(59,130,246,0.08); border: 1px solid rgba(59,130,246,0.2); padding: 3px 8px; border-radius: var(--r-sm); }
  .video-copy-btn { font-size: 11px; padding: 5px 10px; background: var(--surface-3); border: 1px solid var(--border-2); border-radius: var(--r-sm); color: var(--text-2); cursor: pointer; font-family: inherit; transition: all 0.15s; display: inline-flex; align-items: center; gap: 4px; }
  .video-copy-btn:hover { background: rgba(139,92,246,0.1); border-color: rgba(139,92,246,0.3); color: #a78bfa; }

  /* ── Refine-laatikko (per-item AI-muokkaus) ──────────────────────────────── */
  .refine-box { display: flex; flex-direction: column; gap: 8px; padding: 14px 16px; background: var(--surface-2); border-top: 1px solid var(--border); }
  .video-result-card .refine-box { border-radius: 0 0 var(--r-lg) var(--r-lg); }
  .kampanja-card .refine-box { margin-top: 12px; border-radius: var(--r-sm); border: 1px dashed var(--border-2); border-top: 1px dashed var(--border-2); background: var(--surface-3); }
  .refine-label { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.08em; }
  .refine-textarea { padding: 10px 12px; background: var(--bg); border: 1px solid var(--border-2); border-radius: var(--r-sm); color: var(--text); font-family: inherit; font-size: 13px; resize: vertical; min-height: 64px; max-height: 200px; line-height: 1.5; transition: border-color 0.15s, box-shadow 0.15s; }
  .refine-textarea::placeholder { color: var(--text-3); opacity: 0.7; }
  .refine-textarea:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
  .refine-actions { display: flex; justify-content: flex-end; }
  .refine-btn { font-size: 12px; padding: 7px 14px; min-height: 32px; }

  /* ── Some strategiatyökalu ───────────────────────────────────────────────── */
  .strategy-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 12px; }
  .strategy-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 18px 22px; cursor: pointer; transition: border-color 0.2s, background 0.2s, transform 0.15s; text-align: left; width: 100%; font-family: inherit; color: inherit; }
  .strategy-card:hover { border-color: rgba(245,158,11,0.4); background: var(--surface-2); transform: translateY(-1px); }
  .strategy-card-icon { width: 36px; height: 36px; border-radius: var(--r-md); background: rgba(245,158,11,0.12); border: 1px solid rgba(245,158,11,0.3); display: flex; align-items: center; justify-content: center; flex-shrink: 0; color: #f59e0b; margin-bottom: 10px; }
  .tag-strategy { font-size: 11px; padding: 3px 9px; border-radius: var(--r-sm); background: rgba(245,158,11,0.1); color: #f59e0b; border: 1px solid rgba(245,158,11,0.25); font-family: 'JetBrains Mono', monospace; }

  .strategy-section { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); margin-bottom: 16px; overflow: hidden; }
  .strategy-section-header { padding: 14px 20px; background: var(--surface-2); border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 10px; }
  .strategy-section-icon { width: 24px; height: 24px; border-radius: 6px; background: rgba(245,158,11,0.15); border: 1px solid rgba(245,158,11,0.3); display: flex; align-items: center; justify-content: center; color: #f59e0b; flex-shrink: 0; }
  .strategy-section-title { font-size: 14px; font-weight: 600; color: var(--text); }
  .strategy-section-body { padding: 16px 20px; }
  .strategy-pillar { background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--r-md); padding: 12px 16px; margin-bottom: 10px; border-left: 3px solid #f59e0b; }
  .strategy-pillar:last-child { margin-bottom: 0; }
  .strategy-pillar-name { font-weight: 600; font-size: 14px; color: var(--text); margin-bottom: 4px; }
  .strategy-pillar-desc { font-size: 13px; color: var(--text-2); line-height: 1.55; }
  .strategy-pillar-meta { margin-top: 8px; display: flex; gap: 6px; flex-wrap: wrap; }
  .strategy-freq { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px,1fr)); gap: 8px; }
  .strategy-freq-item { background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--r-md); padding: 10px 14px; }
  .strategy-freq-platform { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: #f59e0b; text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 4px; }
  .strategy-freq-val { font-size: 14px; font-weight: 600; color: var(--text); }
  .strategy-freq-sub { font-size: 11px; color: var(--text-3); margin-top: 2px; }
  .strategy-kpi { display: flex; gap: 8px; align-items: flex-start; padding: 8px 0; border-bottom: 1px solid var(--border); }
  .strategy-kpi:last-child { border-bottom: none; }
  .strategy-kpi-dot { width: 6px; height: 6px; border-radius: 50%; background: #f59e0b; flex-shrink: 0; margin-top: 6px; }
  .strategy-kpi-text { font-size: 13px; color: var(--text-2); line-height: 1.55; }

  /* ── Asiakas-välilehdet (client-tabs) ───────────────────────────────────── */
  .client-tabs { display: flex; gap: 2px; flex-wrap: wrap; padding: 6px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); margin-bottom: 16px; }
  .client-tab { display: inline-flex; align-items: center; gap: 8px; padding: 10px 16px; background: transparent; border: 1px solid transparent; border-radius: var(--r-md); font-family: inherit; font-size: 13px; font-weight: 500; color: var(--text-2); cursor: pointer; transition: background 0.15s, color 0.15s, border-color 0.15s; }
  .client-tab:hover { background: var(--surface-2); color: var(--text); }
  .client-tab.active { background: var(--surface-2); color: var(--accent); border-color: var(--border-accent); }
  .client-tab svg { flex-shrink: 0; }
  .tab-count { font-size: 11px; padding: 1px 7px; border-radius: var(--r-md); background: var(--surface-3); color: var(--text-3); font-family: 'JetBrains Mono', monospace; min-width: 18px; text-align: center; }
  .client-tab.active .tab-count { background: var(--accent-soft); color: var(--accent); }

  /* ── Tietopankki — sub-välilehdet ja apuelementit ─────────────────────── */
  .tietopankki-subtabs { display: flex; gap: 4px; flex-wrap: wrap; padding: 4px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); margin-bottom: 16px; }
  .tp-subtab { display: inline-flex; align-items: center; gap: 8px; padding: 8px 14px; background: transparent; border: 1px solid transparent; border-radius: var(--r-md); font-family: inherit; font-size: 12px; font-weight: 500; color: var(--text-2); cursor: pointer; transition: background 0.15s, color 0.15s, border-color 0.15s; }
  .tp-subtab:hover { background: var(--surface-2); color: var(--text); }
  .tp-subtab.active { background: var(--surface-2); color: var(--accent); border-color: var(--border-accent); }
  .tp-subtab-missing { font-size: 10px; padding: 1px 6px; border-radius: var(--r-md); background: rgba(245, 158, 11, 0.15); color: #f59e0b; font-family: 'JetBrains Mono', monospace; min-width: 16px; text-align: center; font-weight: 600; }
  .tp-subtab-done { font-size: 10px; color: #1ecc00; font-weight: 700; }
  .tp-subtab.active .tp-subtab-missing { background: rgba(245, 158, 11, 0.25); }

  .tietopankki-content { animation: tp-fade 0.18s ease; }
  @keyframes tp-fade { from { opacity: 0.4; transform: translateY(2px); } to { opacity: 1; transform: translateY(0); } }

  @media (max-width: 600px) {
    .tietopankki-subtabs { flex-wrap: nowrap; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; padding: 3px; }
    .tietopankki-subtabs::-webkit-scrollbar { display: none; }
    .tp-subtab { padding: 7px 10px; font-size: 11px; gap: 5px; flex-shrink: 0; white-space: nowrap; }
  }

  /* ── btn-primary (CTA) ──────────────────────────────────────────────────── */
  .btn-primary { background: var(--accent); color: var(--accent-on, #fff); border-color: var(--accent); }
  .btn-primary:hover { filter: brightness(1.06); }
  .btn-primary:disabled { opacity: 0.5; cursor: not-allowed; filter: none; }

  /* ── CSV-tuontimodaali ──────────────────────────────────────────────────── */
  .csv-dropzone { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; padding: 28px 16px; background: var(--surface-2); border: 2px dashed var(--border-2); border-radius: var(--r-lg); cursor: pointer; color: var(--text-2); transition: border-color 0.15s, background 0.15s; text-align: center; }
  .csv-dropzone:hover, .csv-dropzone.drag { border-color: var(--accent); background: var(--accent-soft); color: var(--accent); }
  .csv-dropzone-label { font-size: 13px; font-weight: 500; }
  .csv-error { margin-top: 12px; padding: 10px 14px; background: rgba(248,113,113,0.10); border: 1px solid rgba(248,113,113,0.3); border-radius: var(--r-md); color: #f87171; font-size: 13px; }
  .csv-preview { margin-top: 14px; padding: 12px 14px; background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--r-md); font-size: 13px; color: var(--text-2); }
  .csv-preview-row { padding: 6px 0; border-bottom: 1px dashed var(--border); display: flex; justify-content: space-between; gap: 10px; }
  .csv-preview-row:last-child { border-bottom: none; }
  .csv-preview-row .replace-mark { color: var(--accent); font-family: 'JetBrains Mono', monospace; font-size: 11px; }

  /* ── Google Ads -välilehti ──────────────────────────────────────────────── */
  .ads-empty { padding: 48px 24px; text-align: center; background: var(--surface); border: 1px dashed var(--border-2); border-radius: var(--r-lg); }
  .ads-empty-title { font-size: 16px; font-weight: 600; margin-bottom: 8px; color: var(--text); }
  .ads-empty-desc { font-size: 13px; color: var(--text-3); margin-bottom: 18px; line-height: 1.55; max-width: 420px; margin-left: auto; margin-right: auto; }

  .ads-summary { display: flex; gap: 8px; flex-wrap: wrap; padding: 10px 14px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); margin-bottom: 14px; align-items: center; }
  /* Chip-tyyliset stat-laatikot — vierekkäin, eivät enää tekstilaatikoita */
  .ads-summary-item { display: inline-flex; align-items: center; gap: 8px; padding: 6px 12px; border-radius: var(--r-md); background: var(--surface-2); border: 1px solid var(--border); font-size: 12px; line-height: 1.2; white-space: nowrap; }
  .ads-summary-label { font-family: 'JetBrains Mono', monospace; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.06em; font-size: 10px; }
  .ads-summary-value { font-weight: 600; color: var(--text); font-size: 13px; }
  .ads-summary-actions { margin-left: auto; display: flex; gap: 6px; flex-shrink: 0; }

  /* Ads-välilehti: chat-pohja tasolla viewport-alareunan kanssa (kuten sivupalkin "Lisää asiakas" -nappi).
     Kun ads-grid on näkyvissä, .content-paddingia pienennetään → grid täyttää loppuun asti.
     Vähennys = topbar(108) + content padding(28+12) + tabit+marg(50+16) + summary+marg(48+14) ≈ 276px */
  .content:has(.ads-grid) { padding-bottom: 12px; }
  .ads-grid { display: grid; grid-template-columns: minmax(280px, 360px) 1fr; gap: 14px; height: calc(100dvh - 280px); min-height: 420px; }
  @media (max-width: 980px) { .ads-grid { grid-template-columns: 1fr; height: auto; min-height: 0; } }

  .ads-campaign-list-wrap { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); display: flex; flex-direction: column; height: 100%; min-height: 0; overflow: hidden; }
  .ads-campaign-filterbar { display: flex; gap: 6px; padding: 10px 12px; border-bottom: 1px solid var(--border); flex-shrink: 0; flex-wrap: wrap; }
  .ads-campaign-filter-btn { display: inline-flex; align-items: center; gap: 6px; padding: 5px 10px; background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--r-md); font-family: inherit; font-size: 12px; font-weight: 500; color: var(--text-2); cursor: pointer; transition: background 0.15s, border-color 0.15s, color 0.15s; }
  .ads-campaign-filter-btn:hover { background: var(--surface-3); border-color: var(--border-2); color: var(--text); }
  .ads-campaign-filter-btn.active { background: var(--accent-soft); border-color: var(--border-accent); color: var(--accent); }
  .ads-campaign-filter-count { display: inline-block; min-width: 20px; padding: 0 5px; height: 18px; line-height: 18px; text-align: center; font-size: 10px; font-family: 'JetBrains Mono', monospace; color: var(--text-3); background: var(--bg); border-radius: 9px; }
  .ads-campaign-filter-btn.active .ads-campaign-filter-count { color: var(--accent); background: var(--surface); }
  .ads-campaign-empty { padding: 24px 12px; text-align: center; color: var(--text-3); font-size: 13px; font-style: italic; }
  .ads-campaign-list { padding: 12px; overflow-y: auto; flex: 1; min-height: 0; }
  .ads-campaign { padding: 11px 12px; border-radius: var(--r-md); cursor: pointer; transition: background 0.15s, border-color 0.15s; border: 1px solid var(--border); background: var(--surface-2); margin-bottom: 8px; }
  .ads-campaign:hover { background: var(--surface-3); border-color: var(--border-2); }
  .ads-campaign.selected { background: var(--accent-soft); border-color: var(--border-accent); }
  .ads-campaign-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; margin-bottom: 8px; }
  .ads-campaign-title { min-width: 0; flex: 1; }
  .ads-campaign-name { font-size: 14px; font-weight: 600; color: var(--text); line-height: 1.3; word-break: break-word; }
  .ads-campaign-id { display: inline-block; font-size: 10px; font-family: 'JetBrains Mono', monospace; color: var(--accent); background: var(--accent-soft); padding: 1px 6px; border-radius: 3px; margin-right: 6px; vertical-align: 2px; }
  .ads-campaign-status { font-size: 10px; font-family: 'JetBrains Mono', monospace; padding: 2px 8px; border-radius: 3px; flex-shrink: 0; text-transform: uppercase; letter-spacing: 0.04em; }
  .ads-campaign-status.aktiivinen { background: var(--accent-soft); color: var(--accent); }
  .ads-campaign-status.pausetettu { background: rgba(253,214,99,0.10); color: #fdd663; }
  .ads-campaign-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 4px 10px; font-size: 12px; }
  .ads-campaign-stat { display: flex; justify-content: space-between; gap: 6px; }
  .ads-campaign-stat-label { color: var(--text-3); font-family: 'JetBrains Mono', monospace; font-size: 10px; text-transform: uppercase; letter-spacing: 0.04em; }
  .ads-campaign-stat-value { color: var(--text); font-weight: 500; }
  .ads-campaign.selected .ads-campaign-stat-value { color: var(--accent); }
  .ads-campaign-type { font-size: 11px; color: var(--text-3); font-family: 'JetBrains Mono', monospace; margin-top: 6px; padding-top: 6px; border-top: 1px dashed var(--border); }

  .ads-chat { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); display: flex; flex-direction: column; height: 100%; min-height: 0; }
  .ads-chat-msgs { flex: 1; overflow-y: auto; padding: 18px 22px; display: flex; flex-direction: column; gap: 14px; min-height: 0; }
  .ads-msg { max-width: 100%; }
  .ads-msg.user { align-self: flex-end; max-width: 80%; padding: 10px 14px; background: var(--surface-3); border-radius: var(--r-md); font-size: 14px; line-height: 1.5; color: var(--text); white-space: pre-wrap; }
  .ads-msg.ai { align-self: flex-start; max-width: 100%; padding: 10px 0; font-size: 14px; line-height: 1.6; color: var(--text); }
  .ads-msg.ai p { margin: 0 0 10px 0; }
  .ads-msg.ai p:last-child { margin-bottom: 0; }
  .ads-msg.ai code { background: var(--surface-2); padding: 1px 6px; border-radius: 4px; font-family: 'JetBrains Mono', monospace; font-size: 12px; }
  .ads-typing { color: var(--text-3); font-size: 13px; font-style: italic; padding: 4px 0; }
  .ads-typing::after { content: '...'; animation: dots 1.2s steps(3, end) infinite; }
  @keyframes dots { 0%, 20% { content: ''; } 40% { content: '.'; } 60% { content: '..'; } 80%, 100% { content: '...'; } }

  /* Pikakysymykset chat-paneelin pohjalla — täyttää chatin leveyden tasaisesti */
  .ads-suggestions { padding: 0 22px 12px 22px; display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 6px; }
  .ads-suggestion { padding: 8px 12px; background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--r-md); font-size: 12px; color: var(--text-2); cursor: pointer; font-family: inherit; transition: border-color 0.15s, background 0.15s, color 0.15s; line-height: 1.35; text-align: left; }
  .ads-suggestion:hover { border-color: var(--border-accent); background: var(--accent-soft); color: var(--accent); }

  /* Yhdenmukainen syöttörivi sekä kilpailija- että chat-syötteelle */
  .ads-input-bar { border-top: 1px solid var(--border); padding: 12px 18px; display: flex; flex-direction: column; gap: 8px; flex-shrink: 0; }
  .ads-input-row { display: flex; gap: 8px; align-items: stretch; }
  .ads-input { flex: 1; padding: 10px 16px; border-radius: var(--r-md); border: 1px solid var(--border); background: var(--surface-2); color: var(--text); font-family: inherit; font-size: 13px; resize: none; min-height: 40px; max-height: 140px; line-height: 1.4; }
  .ads-input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
  .ads-input.multiline { padding: 10px 18px; }
  .ads-action-btn { padding: 0 18px; height: 40px; min-width: 170px; justify-content: center; border-radius: var(--r-md); background: var(--accent); color: var(--accent-on, #fff); border: 1px solid var(--accent); cursor: pointer; font-family: inherit; font-size: 13px; font-weight: 500; white-space: nowrap; transition: filter 0.15s; flex-shrink: 0; display: inline-flex; align-items: center; gap: 6px; }
  .ads-action-btn:hover { filter: brightness(1.08); }
  .ads-action-btn:disabled { opacity: 0.4; cursor: not-allowed; filter: none; }
  .ads-action-btn.secondary { background: var(--surface-2); color: var(--text-2); border-color: var(--border); }
  .ads-action-btn.secondary:hover { border-color: var(--accent); color: var(--accent); filter: none; }

  /* Pikatoimenpide-napit summary-rivin oikeassa reunassa: ikoni-pohjainen, kompakti */
  .ads-icon-btn { width: 32px; height: 32px; border-radius: var(--r-md); background: var(--surface-2); border: 1px solid var(--border); color: var(--text-2); cursor: pointer; display: inline-flex; align-items: center; justify-content: center; transition: border-color 0.15s, color 0.15s, background 0.15s; flex-shrink: 0; padding: 0; }
  .ads-icon-btn:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-soft); }
  .ads-icon-btn:disabled { opacity: 0.4; cursor: not-allowed; }

  /* ── Sivupalkin haku ja asiakaslistan meta ──────────────────────────────── */
  .sidebar-section-count { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-3); padding: 1px 6px; border-radius: var(--r-md); background: var(--surface-3); margin-left: 4px; }
  .sidebar-search { position: relative; padding: 0 12px 8px; }
  .sidebar-search-icon { position: absolute; left: 22px; top: 9px; color: var(--text-3); pointer-events: none; }
  .sidebar-search-input { width: 100%; padding: 7px 28px 7px 30px; background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--r-md); color: var(--text); font-family: inherit; font-size: 12px; }
  .sidebar-search-input::placeholder { color: var(--text-3); }
  .sidebar-search-input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-soft); }
  .sidebar-search-clear { position: absolute; right: 18px; top: 6px; width: 22px; height: 22px; border: none; background: transparent; color: var(--text-3); cursor: pointer; font-size: 18px; line-height: 1; padding: 0; }
  .sidebar-search-clear:hover { color: var(--text); }
  .sidebar-search-empty { padding: 12px 16px; font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-3); }

  /* Asiakaschipin laajempi versio (meta-rivi alle) */
  .client-chip { flex-direction: row; align-items: flex-start; min-height: auto; padding: 8px 10px; }
  .client-chip-body { display: flex; flex-direction: column; min-width: 0; flex: 1; gap: 2px; }
  .client-chip .client-name { width: 100%; }
  .client-chip-meta { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-3); display: flex; gap: 6px; flex-wrap: wrap; line-height: 1.2; }
  .client-chip-meta-item { white-space: nowrap; }
  .client-chip-meta-item.has-ads { color: var(--accent); }
  .client-chip.active .client-chip-meta { color: var(--accent); opacity: 0.85; }

  /* Hakutulos: Projektihakurivit */
  .sidebar-search-results { padding: 4px 8px; }
  .sidebar-search-result { display: flex; flex-direction: column; gap: 2px; padding: 8px 10px; cursor: pointer; border-radius: var(--r-md); transition: background 0.12s; border: none; background: none; width: 100%; text-align: left; font-family: inherit; color: var(--text-2); }
  .sidebar-search-result:hover { background: var(--surface-2); color: var(--text); }
  .sidebar-search-result-title { font-size: 12px; font-weight: 500; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .sidebar-search-result-sub { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-3); display: flex; align-items: center; gap: 6px; }
  .sidebar-search-result-kind { padding: 1px 6px; border-radius: 3px; background: var(--surface-3); color: var(--text-3); font-size: 9px; text-transform: uppercase; letter-spacing: 0.05em; }
  .sidebar-search-result-kind.client { background: var(--accent-soft); color: var(--accent); }
  .sidebar-search-result-kind.strategia { background: rgba(245,158,11,0.12); color: #f59e0b; }
  .sidebar-search-result-kind.video { background: rgba(139,92,246,0.12); color: #a78bfa; }
  .sidebar-search-result-kind.kuvasarja { background: rgba(16,185,129,0.12); color: #10b981; }
  .sidebar-search-result-kind.ads { background: rgba(67,153,242,0.12); color: #4399f2; }
  .sidebar-search-section-label { padding: 8px 14px 4px; font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.06em; }

  /* Vaakatasoinen nappirivi — säilyttää vakio-pyöristyksen .btn:llä, scrollataan vaakaan jos kapea */
  .btn-row { display: flex; gap: 8px; flex-wrap: nowrap; overflow-x: auto; padding-bottom: 4px; -webkit-overflow-scrolling: touch; scrollbar-width: thin; }
  .btn-row::-webkit-scrollbar { height: 6px; }
  .btn-row::-webkit-scrollbar-thumb { background: var(--border-2); border-radius: var(--r-sm); }
  .btn-row .btn { flex-shrink: 0; white-space: nowrap; }

  /* Sivupalkin järjestys-pudotus (ikoni + select) */
  .sidebar-sort { position: relative; padding: 0 12px 8px; }
  .sidebar-sort-icon { position: absolute; left: 22px; top: 9px; color: var(--text-3); pointer-events: none; }
  .sidebar-sort-select { width: 100%; padding: 6px 24px 6px 30px; background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--r-md); color: var(--text-2); font-family: inherit; font-size: 11px; cursor: pointer; appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10' fill='none' stroke='%239aa0a6' stroke-width='1.5'><polyline points='2,4 5,7 8,4'/></svg>"); background-repeat: no-repeat; background-position: right 8px center; }
  .sidebar-sort-select:hover { color: var(--text); border-color: var(--border-2); }
  .sidebar-sort-select:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-soft); }

  /* ── Kuvageneraattori ───────────────────────────────────────────────────── */
  .image-sets-list { display: flex; flex-direction: column; gap: 16px; }
  .image-set-card { background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 18px 20px; }
  .image-set-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; margin-bottom: 10px; flex-wrap: wrap; }
  .image-set-title { min-width: 0; flex: 1; }
  .image-set-meta { font-size: 12px; color: var(--text-2); margin: 4px 0; line-height: 1.5; }
  .image-set-meta strong { color: var(--text); font-weight: 600; }
  .image-set-prompts { margin-top: 14px; display: flex; flex-direction: column; gap: 10px; }
  .image-set-prompt-block { background: var(--bg); border: 1px solid var(--border); border-radius: var(--r-md); padding: 12px 14px; }
  .image-set-prompt-label { display: flex; justify-content: space-between; align-items: center; gap: 10px; margin-bottom: 8px; }
  .image-set-prompt-tag { font-family: 'JetBrains Mono', monospace; font-size: 10px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-3); padding: 2px 8px; border-radius: var(--r-sm); background: var(--surface-3); border: 1px solid var(--border); }
  .image-set-prompt-tag.base { background: var(--accent-soft); color: var(--accent); border-color: var(--border-accent); }
  .image-set-prompt-text { font-family: 'JetBrains Mono', monospace; font-size: 12px; line-height: 1.55; color: var(--text-2); white-space: pre-wrap; word-break: break-word; }

  /* ── Yhdistä-modaalin asiakas-haku ──────────────────────────────────────── */
  .merge-target-picker { position: relative; }
  .merge-target-input { width: 100%; padding: 8px 12px; background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--r-md); color: var(--text); font-family: inherit; font-size: 13px; outline: none; }
  .merge-target-input:focus { border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-soft); }
  .merge-target-suggestions { margin-top: 4px; max-height: 240px; overflow-y: auto; border-radius: var(--r-md); display: flex; flex-direction: column; gap: 2px; }
  .merge-target-suggestions:empty { display: none; }
  .merge-target-item { display: flex; flex-direction: column; gap: 2px; padding: 8px 12px; background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--r-md); cursor: pointer; text-align: left; font-family: inherit; color: inherit; transition: border-color 0.12s, background 0.12s; }
  .merge-target-item:hover { border-color: var(--accent); background: var(--accent-soft); color: var(--accent); }
  .merge-target-item-name { font-weight: 600; font-size: 13px; }
  .merge-target-item-sub { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-3); }
  .merge-target-empty { padding: 10px 12px; font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-3); }
  .merge-target-selected { display: flex; align-items: center; gap: 12px; padding: 10px 12px; background: var(--accent-soft); border: 1px solid var(--border-accent); border-radius: var(--r-md); }

  /* ── Landing / kirjautumissivu ─────────────────────────────────────────── */
  .landing { display: none; position: fixed; inset: 0; z-index: 1500; background: var(--bg); color: var(--text); overflow-y: auto; }
  body.auth-gate-active { overflow: hidden; }
  body.auth-gate-active .app { display: none !important; }
  body.auth-gate-active .landing { display: block; }
  body.auth-gate-active .landing[aria-hidden="false"] { display: block; }
  /* Hide topbar auth/theme/settings buttons while gate active (defensive — .app is hidden anyway) */
  body.auth-gate-active .loading-overlay { display: none !important; }

  .landing-bg {
    position: absolute; inset: 0; overflow: hidden; pointer-events: none;
    background:
      radial-gradient(circle at 18% 22%, var(--accent-soft) 0%, transparent 42%),
      radial-gradient(circle at 82% 78%, var(--accent-soft-2) 0%, transparent 45%),
      radial-gradient(circle at 55% 100%, rgba(30,204,0,0.06) 0%, transparent 50%);
  }
  .landing-bg::before {
    content: ''; position: absolute; inset: 0;
    background-image: radial-gradient(var(--grid-dot) 1px, transparent 1px);
    background-size: 24px 24px;
    opacity: 0.6;
  }

  .landing-shell {
    position: relative; z-index: 1;
    min-height: 100dvh; display: flex; flex-direction: column; align-items: center; justify-content: center;
    padding: 48px 24px; gap: 28px;
  }

  .landing-brand { display: flex; flex-direction: column; align-items: center; gap: 10px; color: var(--text); }
  .landing-logo { width: 140px; height: auto; display: block; }
  .landing-product { display: inline-flex; align-items: center; gap: 8px; font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-3); letter-spacing: 0.06em; text-transform: uppercase; }
  .landing-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 8px var(--accent), 0 0 14px rgba(30,204,0,0.5); }

  .landing-card {
    width: 100%; max-width: 420px; padding: 32px 28px;
    background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg);
    box-shadow: 0 24px 60px rgba(0,0,0,0.45), 0 2px 0 rgba(255,255,255,0.02) inset;
  }
  [data-theme="light"] .landing-card { box-shadow: 0 20px 50px rgba(20,30,25,0.10), 0 1px 0 rgba(255,255,255,0.6) inset; }

  .landing-title { font-size: 22px; font-weight: 600; letter-spacing: -0.01em; margin-bottom: 6px; color: var(--text); }
  .landing-lead { font-size: 13px; color: var(--text-2); line-height: 1.5; margin-bottom: 22px; }

  .landing-card .field { margin-bottom: 14px; }
  .landing-card .field label { display: block; font-size: 11px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--text-3); margin-bottom: 6px; font-family: 'JetBrains Mono', monospace; }
  .landing-card .field input {
    width: 100%; padding: 11px 13px; background: var(--surface-2); border: 1px solid var(--border);
    border-radius: var(--r-md); color: var(--text); font-family: inherit; font-size: 14px; outline: none;
    transition: border-color 0.12s, box-shadow 0.12s;
  }
  .landing-card .field input:focus { border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-soft); }

  .landing-row-sub { margin: -4px 0 16px; text-align: right; }
  .landing-row-sub a { font-size: 12px; color: var(--text-3); text-decoration: none; }
  .landing-row-sub a:hover { color: var(--accent); }

  .landing-error { display: block; margin-bottom: 14px; padding: 10px 12px; background: rgba(239,68,68,0.10); border: 1px solid rgba(239,68,68,0.30); border-radius: var(--r-md); font-size: 12px; color: #ef4444; }
  .landing-success { display: block; margin-bottom: 14px; padding: 10px 12px; background: rgba(34,197,94,0.10); border: 1px solid rgba(34,197,94,0.30); border-radius: var(--r-md); font-size: 12px; color: #22c55e; }

  .landing-submit { width: 100%; padding: 12px 16px; font-size: 14px; min-height: 44px; }
  .landing-submit[disabled] { opacity: 0.6; cursor: not-allowed; }

  .landing-footer { max-width: 420px; text-align: center; font-size: 11px; color: var(--text-3); line-height: 1.5; }

  @media (max-width: 480px) {
    .landing-shell { padding: 32px 16px; gap: 22px; }
    .landing-card { padding: 26px 20px; }
    .landing-logo { width: 110px; }
  }

  @media (prefers-reduced-motion: reduce) {
    .landing-bg { background-image: none; background: var(--bg); }
  }
