/* ═══════════════════════════════════════════════════════════
   ai-geo.css  -  CoreElement.AI Geologist
   Design tokens + Insight Cards + Status Bar + Badges + Sparkle
   ═══════════════════════════════════════════════════════════ */

/* ── DESIGN TOKENS ── */
:root {
  --ai-bg: #0f1d30;
  --ai-bg2: #0b1522;
  --ai-border: #00c8ff;
  --ai-border-dim: rgba(0,200,255,0.18);
  --ai-text: #c0d0e0;
  --ai-text2: #8aa0b8;
  --ai-heading: #00c8ff;
  --ai-ok: #00e890;
  --ai-warn: #ffaa00;
  --ai-crit: #cc0000;
  --ai-font: 'JetBrains Mono','Courier New',monospace;
  --ai-radius: 6px;
  --ai-glow: 0 0 12px rgba(0,200,255,0.12);
}

/* ── ANIMATIONS ── */
@keyframes aiFadeSlide {
  from { opacity:0; transform:translateY(14px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes aiBlink {
  0%,100% { opacity:1; }
  50%     { opacity:0; }
}
@keyframes aiPulse {
  0%,100% { box-shadow:0 0 0 0 rgba(204,0,0,0.45); }
  50%     { box-shadow:0 0 0 5px rgba(204,0,0,0); }
}
@keyframes aiPulseGlow {
  0%,100% { opacity:0.6; }
  50%     { opacity:1; }
}
@keyframes aiBarFill {
  from { width:0; }
}

/* ── TYPING CURSOR ── */
.ai-cursor {
  display:inline-block; width:2px; height:13px;
  background:var(--ai-border);
  animation:aiBlink 1s step-end infinite;
  vertical-align:text-bottom;
  margin-left:1px;
}

/* ═══════════════════════════════════════
   AI INSIGHT CARD
   ═══════════════════════════════════════ */
.ai-card {
  background:var(--ai-bg);
  border-left:3px solid var(--ai-border);
  border-radius:var(--ai-radius);
  padding:14px 18px;
  margin:10px 0;
  max-width:580px;
  font-family:var(--ai-font);
  font-size:12px;
  line-height:1.65;
  color:var(--ai-text);
  animation:aiFadeSlide 300ms ease-out both;
  box-shadow:var(--ai-glow);
  position:relative;
}
.ai-card.ai-card-ok   { border-left-color:var(--ai-ok); }
.ai-card.ai-card-warn { border-left-color:var(--ai-warn); }
.ai-card.ai-card-crit { border-left-color:var(--ai-crit); }

.ai-card-head {
  display:flex; align-items:center; gap:8px;
  margin-bottom:6px;
}
.ai-avatar {
  width:28px; height:28px; border-radius:50%;
  border:1.5px solid var(--ai-border-dim);
  flex-shrink:0;
  object-fit:cover;
}
.ai-card-icon {
  color:var(--ai-heading); font-size:14px;
  animation:aiPulseGlow 2.5s ease-in-out infinite;
}
.ai-card-title {
  font-size:11px; font-weight:700;
  letter-spacing:1.8px;
  color:var(--ai-heading);
  text-transform:uppercase;
}
.ai-card-sep {
  height:1px;
  background:linear-gradient(90deg,rgba(0,200,255,0.25),transparent 80%);
  margin:6px 0 10px;
}
.ai-card-body {
  white-space:pre-wrap;
  word-break:break-word;
  min-height:18px;
}
.ai-card-body .ai-line-ok   { color:var(--ai-ok); }
.ai-card-body .ai-line-warn { color:var(--ai-warn); }
.ai-card-body .ai-line-crit { color:#ff4466; }
.ai-card-body .ai-line-hl   { color:#fff; }

/* Feature-importance bars inside cards */
.ai-bar-row { display:flex; align-items:center; gap:8px; margin:3px 0; }
.ai-bar-track { flex:1; height:8px; background:rgba(0,200,255,0.08); border-radius:4px; overflow:hidden; }
.ai-bar-fill  { height:100%; background:linear-gradient(90deg,var(--ai-border),rgba(0,200,255,0.4)); border-radius:4px; animation:aiBarFill 600ms ease-out both; }
.ai-bar-label { width:100px; font-size:10px; color:var(--ai-text2); }
.ai-bar-pct   { width:36px; text-align:right; font-size:10px; color:var(--ai-heading); }

/* Action buttons in cards */
.ai-card-actions {
  display:flex; gap:8px; flex-wrap:wrap;
  margin-top:12px; padding-top:10px;
  border-top:1px solid rgba(0,200,255,0.08);
}
.ai-btn {
  font-family:var(--ai-font); font-size:10px;
  letter-spacing:0.5px;
  padding:5px 14px;
  border-radius:4px;
  border:1px solid var(--ai-border);
  background:transparent;
  color:var(--ai-border);
  cursor:pointer;
  transition:all 0.2s;
}
.ai-btn:hover {
  background:var(--ai-border);
  color:#060a14;
}
.ai-btn-primary {
  background:rgba(0,200,255,0.12);
}
.ai-btn-ghost {
  border-color:rgba(0,200,255,0.25);
  color:var(--ai-text2);
}
.ai-btn-ghost:hover {
  border-color:var(--ai-border);
  color:var(--ai-border);
  background:transparent;
}
.ai-btn-ok {
  border-color:var(--ai-ok); color:var(--ai-ok);
}
.ai-btn-ok:hover {
  background:var(--ai-ok); color:#060a14;
}

/* Collapse link */
.ai-collapse {
  font-family:var(--ai-font); font-size:10px;
  color:var(--ai-text2); cursor:pointer;
  position:absolute; top:12px; right:14px;
  opacity:0.6; transition:opacity 0.2s;
}
.ai-collapse:hover { opacity:1; }


/* ═══════════════════════════════════════
   AI STATUS BAR
   ═══════════════════════════════════════ */
.ai-statusbar {
  position:fixed;
  bottom:0; left:0; right:0;
  height:34px;
  background:linear-gradient(180deg,#0c1524,#080e1a);
  border-top:1px solid;
  border-image:linear-gradient(90deg,var(--ai-border-dim),transparent 70%) 1;
  z-index:9000;
  font-family:var(--ai-font);
  font-size:11px;
  color:var(--ai-text2);
  transition:height 250ms ease-out;
  overflow:hidden;
  user-select:none;
}
.ai-statusbar.expanded {
  height:200px;
}

.ai-sb-inner {
  display:flex; align-items:center;
  height:34px; padding:0 16px;
  cursor:pointer;
  gap:10px;
}
.ai-sb-pulse {
  width:6px; height:6px;
  border-radius:50%;
  background:var(--ai-border);
  animation:aiPulseGlow 2s ease-in-out infinite;
  flex-shrink:0;
}
.ai-sb-icon {
  color:var(--ai-heading);
  font-size:12px;
  flex-shrink:0;
}
.ai-sb-text {
  flex:1;
  overflow:hidden;
  white-space:nowrap;
  text-overflow:ellipsis;
  min-height:14px;
}
.ai-sb-toggle {
  font-size:8px;
  color:var(--ai-text2);
  transition:transform 250ms;
  flex-shrink:0;
}
.ai-statusbar.expanded .ai-sb-toggle {
  transform:rotate(180deg);
}

/* Expanded panel */
.ai-sb-panel {
  padding:8px 16px 12px;
  border-top:1px solid rgba(0,200,255,0.06);
  overflow-y:auto;
  max-height:160px;
}
.ai-sb-entry {
  display:flex; align-items:flex-start; gap:8px;
  padding:5px 0;
  font-size:10px;
  color:var(--ai-text2);
  cursor:pointer;
  border-bottom:1px solid rgba(255,255,255,0.03);
  transition:color 0.15s;
}
.ai-sb-entry:hover { color:var(--ai-text); }
.ai-sb-entry:last-child { border-bottom:none; }
.ai-sb-time {
  color:rgba(0,200,255,0.4);
  min-width:44px;
  flex-shrink:0;
}
.ai-sb-dot {
  width:6px; height:6px;
  border-radius:50%;
  margin-top:4px;
  flex-shrink:0;
}
.ai-sb-dot-crit { background:var(--ai-crit); }
.ai-sb-dot-warn { background:var(--ai-warn); }
.ai-sb-dot-info { background:var(--ai-border); }


/* ═══════════════════════════════════════
   AI SPARKLE BUTTON (✦)
   ═══════════════════════════════════════ */
.ai-sparkle {
  display:inline-flex; align-items:center; justify-content:center;
  width:22px; height:22px;
  border-radius:4px;
  border:1px solid rgba(0,200,255,0.15);
  background:transparent;
  color:var(--ai-heading);
  font-size:12px;
  cursor:pointer;
  transition:all 0.2s;
  vertical-align:middle;
  margin-left:4px;
  position:relative;
}
.ai-sparkle:hover {
  background:rgba(0,200,255,0.1);
  border-color:var(--ai-border);
  box-shadow:0 0 8px rgba(0,200,255,0.2);
}
.ai-sparkle[title]:hover::after {
  content:attr(title);
  position:absolute;
  bottom:calc(100% + 6px); left:50%;
  transform:translateX(-50%);
  padding:3px 8px;
  border-radius:3px;
  background:#0a1020;
  border:1px solid var(--ai-border-dim);
  color:var(--ai-text);
  font-family:var(--ai-font);
  font-size:9px;
  white-space:nowrap;
  z-index:100;
  pointer-events:none;
}

/* Inline expansion below sparkle target */
.ai-sparkle-inline {
  margin:8px 0;
  animation:aiFadeSlide 250ms ease-out both;
}


/* ═══════════════════════════════════════
   AI NOTIFICATION BADGES (sidebar)
   ═══════════════════════════════════════ */
.ai-badge {
  font-family:var(--ai-font);
  font-size:7px;
  font-weight:700;
  width:13px !important;
  height:13px !important;
  min-width:13px !important;
  max-width:13px !important;
  display:inline-flex; align-items:center; justify-content:center;
  border-radius:50% !important;
  padding:0 !important;
  margin-left:6px;
  flex-shrink:0;
  letter-spacing:0;
  line-height:1;
  cursor:pointer;
  box-sizing:border-box;
  overflow:hidden;
}
.ai-badge-info {
  background:rgba(0,200,255,0.15);
  color:var(--ai-border);
  border:1px solid rgba(0,200,255,0.25);
}
.ai-badge-warn {
  background:rgba(255,170,0,0.12);
  color:var(--ai-warn);
  border:1px solid rgba(255,170,0,0.25);
}
.ai-badge-crit {
  background:rgba(204,0,0,0.15);
  color:#ff4466;
  border:1px solid rgba(204,0,0,0.3);
  animation:aiPulse 2s ease-in-out infinite;
}

/* Total badge in header / sidebar top */
.ai-badge-total {
  display:inline-flex; align-items:center; gap:4px;
  font-family:var(--ai-font);
  font-size:10px;
  padding:3px 10px;
  border-radius:10px;
  background:rgba(0,200,255,0.08);
  border:1px solid var(--ai-border-dim);
  color:var(--ai-heading);
  cursor:pointer;
  transition:all 0.2s;
  margin:8px 14px;
}
.ai-badge-total:hover {
  background:rgba(0,200,255,0.15);
  border-color:var(--ai-border);
}

/* Notification dropdown */
.ai-notif-dropdown {
  position:absolute;
  bottom:calc(100% + 6px); left:10px;
  width:300px;
  background:var(--ai-bg);
  border:1px solid var(--ai-border-dim);
  border-radius:var(--ai-radius);
  box-shadow:0 -4px 24px rgba(0,0,0,0.5);
  z-index:9100;
  font-family:var(--ai-font);
  padding:10px 0;
  display:none;
}
.ai-notif-dropdown.open { display:block; animation:aiFadeSlide 200ms ease-out both; }
.ai-notif-hdr {
  padding:0 14px 8px;
  font-size:11px; font-weight:700;
  letter-spacing:1.5px;
  color:var(--ai-heading);
  border-bottom:1px solid rgba(0,200,255,0.08);
}
.ai-notif-item {
  display:flex; align-items:center; gap:8px;
  padding:7px 14px;
  font-size:10px;
  color:var(--ai-text);
  cursor:pointer;
  transition:background 0.15s;
}
.ai-notif-item:hover { background:rgba(0,200,255,0.04); }


/* ═══════════════════════════════════════
   SCREEN BODY PADDING (for Status Bar)
   ═══════════════════════════════════════ */
/* Added by ai-geo.css to prevent content being hidden behind Status Bar */
/* .screen already has overflow handling in app.html */


/* ═══════════════════════════════════════
   INDEX.HTML  -  AI GEOLOGIST SECTION
   (Фаза B, styles pre-loaded)
   ═══════════════════════════════════════ */
.ai-hero-section {
  padding:60px 32px;
  position:relative;
  overflow:hidden;
}
.ai-hero-section::before {
  content:'';
  position:absolute; inset:0;
  background:radial-gradient(ellipse at 30% 50%,rgba(0,200,255,0.06) 0%,transparent 60%);
  pointer-events:none;
}
.ai-hero-grid {
  max-width:1280px; margin:0 auto;
  display:grid;
  grid-template-columns:380px 1fr;
  gap:40px;
  align-items:center;
}
.ai-hero-photo {
  border-radius:12px;
  overflow:hidden;
  border:1px solid var(--ai-border-dim);
  box-shadow:0 8px 32px rgba(0,0,0,0.4);
}
.ai-hero-photo img {
  width:100%; height:auto; display:block;
}
.ai-hero-quote {
  background:var(--ai-bg);
  border-left:3px solid var(--ai-border);
  border-radius:var(--ai-radius);
  padding:14px 18px;
  margin-top:20px;
  font-family:var(--ai-font);
  font-size:13px;
  color:var(--ai-text);
  min-height:60px;
}
.ai-scenario-cards {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  margin-top:28px;
}
.ai-scenario-card {
  background:var(--ai-bg);
  border:1px solid var(--ai-border-dim);
  border-radius:var(--ai-radius);
  padding:16px 14px;
  text-align:center;
  font-family:var(--ai-font);
  font-size:14px;
  font-weight:600;
  color:var(--ai-text2);
  cursor:default;
  transition:all 0.2s;
}
.ai-scenario-card:hover {
  border-color:var(--ai-border);
  background:rgba(0,200,255,0.04);
  color:var(--ai-text);
}
.ai-scenario-card .ai-sc-icon {
  font-size:26px;
  margin-bottom:8px;
  display:block;
  color:var(--ai-heading);
}
.ai-scenario-card .ai-sc-sub {
  margin-top:6px;
  font-size:11px;
  font-weight:400;
  color:rgba(0,200,255,0.5);
  line-height:1.4;
}

/* ── RESPONSIVE ── */
@media (max-width:768px) {
  .ai-statusbar {
    bottom: calc(56px + env(safe-area-inset-bottom, 0px));
    height: 30px;
    font-size: 10px;
    border-top: 1px solid rgba(0,200,255,0.08);
    cursor: pointer;
  }
  .ai-statusbar:active { background: rgba(0,200,255,0.08); }
  .ai-sb-toggle { display: none; }
  .ai-statusbar.expanded { height: 180px; }
  .ai-sb-inner { height: 30px; padding: 0 12px; gap: 6px; }
  .ai-sb-text { font-size: 10px; }
  .ai-card { max-width:100%; margin:8px 0; font-size:11px; padding:12px 14px; }
  .ai-card-title { font-size:10px; letter-spacing:1.2px; }
  .ai-avatar { width:24px; height:24px; }
  .ai-hero-grid { grid-template-columns:1fr; gap:24px; }
  .ai-scenario-cards { grid-template-columns:repeat(2,1fr); }
}
/* Tablet: status bar above mobile nav (app.html switches to mobile-nav at ≤1024px) */
@media (min-width:769px) and (max-width:1024px) {
  .ai-statusbar {
    bottom: calc(56px + env(safe-area-inset-bottom, 0px));
  }
  /* Overlay as bottom sheet on tablet too (mobile-nav is active up to 1024px) */
  [id^="ai-s"][id$="-zone"].ai-zone-overlay {
    position: fixed !important;
    top: auto !important;
    bottom: calc(56px + 34px + env(safe-area-inset-bottom, 0px)) !important;
    left: 0 !important;
    right: 0 !important;
    max-height: 65vh !important;
    border-radius: 16px 16px 0 0 !important;
    z-index: 9500 !important;
  }
}
@media (min-width:769px) and (max-width:1100px) {
  .ai-card { max-width:460px; }
  .ai-hero-grid { grid-template-columns:280px 1fr; gap:28px; }
}

/* ── AI ZONE OVERLAY (opened by badge click) ── */
[id^="ai-s"][id$="-zone"] {
  display:none !important;
}
[id^="ai-s"][id$="-zone"].ai-zone-overlay {
  position:absolute !important;
  top:0; left:0; right:0;
  z-index:500;
  display:block !important;
  padding:12px 20px 16px !important;
  max-height:65vh !important;
  overflow-y:auto !important;
  background:transparent;
  border-bottom:none;
  box-shadow:none;
  animation:aiFadeSlide 200ms ease-out both;
}
[id^="ai-s"][id$="-zone"].ai-zone-overlay .ai-card {
  max-width:620px;
  margin:0;
  background:rgba(8,14,26,0.94);
  box-shadow:0 4px 24px rgba(0,0,0,0.5);
  border-left-color:var(--ai-border);
}


/* ════════════════════════════════════════════════════════════
   PHASE F  -  Mobile Adaptation (≤768px)
   ════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {
  /* F.2: Overlay fullwidth on mobile */
  [id^="ai-s"][id$="-zone"].ai-zone-overlay {
    position: fixed !important;
    max-width: 100% !important;
    width: 100% !important;
    left: 0 !important;
    right: 0 !important;
    top: auto !important;
    bottom: calc(56px + 30px + env(safe-area-inset-bottom, 0px)) !important;
    border-radius: 16px 16px 0 0 !important;
    max-height: 70vh !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    padding: 12px !important;
    z-index: 9500 !important;
  }

  /* F.2: Card body min font size */
  .ai-card-body {
    font-size: 12px !important;
    line-height: 1.6 !important;
  }

  /* F.2: Buttons full width + touch targets */
  .ai-card-actions {
    flex-direction: column !important;
  }
  .ai-btn {
    min-height: 44px !important;
    width: 100% !important;
    justify-content: center !important;
    font-size: 12px !important;
  }

  /* F.2: Badge touch target (visual stays 13px, but tap area 36px) */
  .ai-sidebar-badge {
    position: relative;
  }
  .ai-sidebar-badge::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 36px;
    height: 36px;
    border-radius: 50%;
  }

  /* F.2: Card title compact */
  .ai-card-title {
    font-size: 10px !important;
    letter-spacing: 1px !important;
  }

  /* F.2: Close button larger for touch */
  .ai-card-close {
    width: 36px !important;
    height: 36px !important;
    font-size: 18px !important;
  }

  /* F.3: Swipe handle indicator */
  [id^="ai-s"][id$="-zone"].ai-zone-overlay::before {
    content: '';
    display: block;
    width: 40px;
    height: 4px;
    background: rgba(255,255,255,0.2);
    border-radius: 2px;
    margin: 0 auto 12px;
  }
}

@media (max-width: 480px) {
  /* F.3: Extra compact on small screens */
  [id^="ai-s"][id$="-zone"].ai-zone-overlay {
    padding: 8px !important;
    max-height: 75vh !important;
  }

  .ai-card-body {
    font-size: 11px !important;
  }

  .ai-card-title {
    font-size: 9px !important;
  }
}

/* ════════════════════════════════════════════════════════════
   PHASE K.1  -  Badge Tooltip on Hover
   ════════════════════════════════════════════════════════════ */

.ai-badge-tooltip {
  position: absolute;
  left: calc(100% + 8px);
  top: 50%;
  transform: translateY(-50%);
  background: var(--ai-bg, #0a1628);
  color: var(--ai-text, #c8d6e5);
  border: 1px solid rgba(0,200,255,0.15);
  border-radius: 6px;
  padding: 6px 10px;
  font-family: var(--mono, 'IBM Plex Mono', monospace);
  font-size: 10px;
  white-space: nowrap;
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  pointer-events: none;
  opacity: 0;
  transition: opacity 150ms ease;
  z-index: 999;
  box-shadow: 0 4px 12px rgba(0,0,0,0.4);
}
.ai-badge-tooltip::before {
  content: '';
  position: absolute;
  right: 100%;
  top: 50%;
  transform: translateY(-50%);
  border: 5px solid transparent;
  border-right-color: rgba(0,200,255,0.15);
}
.ai-badge-tooltip.ai-tooltip-visible {
  opacity: 1;
}

/* Hide tooltip on touch devices */
@media (hover: none) {
  .ai-badge-tooltip { display: none !important; }
}


/* ════════════════════════════════════════════════════════════
   PHASE G  -  Onboarding Overlay
   ════════════════════════════════════════════════════════════ */

#ai-onboarding {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(6,10,20,0.88);
  opacity: 0;
  transition: opacity 300ms ease;
  pointer-events: none;
}
#ai-onboarding.ai-onb-visible {
  opacity: 1;
  pointer-events: auto;
}
.ai-onb-card {
  background: var(--ai-bg, #0a1628);
  border: 1px solid rgba(0,200,255,0.12);
  border-radius: 16px;
  max-width: 480px;
  width: 90vw;
  padding: 32px;
  text-align: center;
  position: relative;
  box-shadow: 0 24px 64px rgba(0,0,0,0.5);
}
.ai-onb-avatar {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  border: 2px solid rgba(0,200,255,0.25);
  margin: 0 auto 16px;
  display: block;
  object-fit: cover;
}
.ai-onb-step-title {
  font-family: var(--heading-font, 'Outfit', sans-serif);
  font-size: 18px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 12px;
  min-height: 28px;
}
.ai-onb-step-text {
  font-family: var(--mono, 'IBM Plex Mono', monospace);
  font-size: 12px;
  color: var(--ai-text, #c8d6e5);
  line-height: 1.7;
  min-height: 60px;
  margin-bottom: 24px;
}
.ai-onb-dots {
  display: flex;
  gap: 8px;
  justify-content: center;
  margin-bottom: 20px;
}
.ai-onb-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(0,200,255,0.2);
  transition: all 200ms;
}
.ai-onb-dot.active {
  background: var(--accent, #00c8ff);
  width: 24px;
  border-radius: 4px;
}
.ai-onb-actions {
  display: flex;
  gap: 12px;
  justify-content: center;
}
.ai-onb-btn {
  font-family: var(--mono, 'IBM Plex Mono', monospace);
  font-size: 12px;
  padding: 10px 24px;
  border-radius: 6px;
  cursor: pointer;
  border: none;
  transition: all 200ms;
  letter-spacing: 0.5px;
}
.ai-onb-btn-primary {
  background: var(--accent, #00c8ff);
  color: #000;
  font-weight: 700;
}
.ai-onb-btn-primary:hover {
  background: #00e6ff;
  transform: translateY(-1px);
}
.ai-onb-btn-secondary {
  background: transparent;
  color: var(--ai-text, #c8d6e5);
  border: 1px solid rgba(0,200,255,0.2);
}
.ai-onb-btn-secondary:hover {
  border-color: rgba(0,200,255,0.4);
}
.ai-onb-highlight {
  position: absolute;
  border: 2px solid var(--accent, #00c8ff);
  border-radius: 8px;
  box-shadow: 0 0 20px rgba(0,200,255,0.3);
  pointer-events: none;
  z-index: 10001;
  transition: all 300ms ease;
}
@media (max-width: 768px) {
  .ai-onb-card { padding: 20px; }
  .ai-onb-step-title { font-size: 16px; }
  .ai-onb-step-text { font-size: 11px; }
}


/* ════════════════════════════════════════════════════════════
   PHASE I  -  Pre-Sales Consultant Bubble
   ════════════════════════════════════════════════════════════ */

#ai-presales {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 9000;
  pointer-events: none;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 300ms ease, transform 300ms ease;
}
#ai-presales.ai-ps-visible {
  pointer-events: auto;
  opacity: 1;
  transform: translateY(0);
}

.ai-ps-bubble {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: var(--ai-bg, #0a1628);
  border: 1px solid rgba(0,200,255,0.15);
  border-radius: 12px;
  padding: 14px 16px;
  max-width: 320px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5);
  cursor: pointer;
  position: relative;
}
.ai-ps-bubble:hover {
  border-color: rgba(0,200,255,0.3);
}

.ai-ps-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  flex-shrink: 0;
  border: 1.5px solid rgba(0,200,255,0.2);
}

.ai-ps-text {
  font-family: var(--mono, 'IBM Plex Mono', monospace);
  font-size: 11px;
  color: var(--ai-text, #c8d6e5);
  line-height: 1.6;
}

.ai-ps-close {
  position: absolute;
  top: 6px;
  right: 8px;
  width: 20px;
  height: 20px;
  font-size: 12px;
  color: rgba(255,255,255,0.3);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  transition: color 200ms;
  background: none;
  border: none;
  padding: 0;
}
.ai-ps-close:hover { color: rgba(255,255,255,0.7); }

.ai-ps-cta {
  display: inline-block;
  margin-top: 8px;
  font-family: var(--mono, 'IBM Plex Mono', monospace);
  font-size: 10px;
  color: var(--accent, #00c8ff);
  font-weight: 600;
  letter-spacing: 0.5px;
  text-decoration: none;
  transition: color 200ms;
}
.ai-ps-cta:hover { color: #00e6ff; }

/* Hide on mobile */
@media (max-width: 768px) {
  #ai-presales { display: none !important; }
}

/* ════════════════════════════════════════════════════════════
   PHASE L  -  Deep Interactivity
   ════════════════════════════════════════════════════════════ */

/* L.2: QA/QC Triple Cards row */
.ai-qaqc-row {
  display:flex; gap:10px; margin:8px 0;
}
.ai-qaqc-row .ai-card { flex:1; min-width:0; max-width:none; margin:0; }
@media (max-width:768px) {
  .ai-qaqc-row { flex-direction:column; }
}

/* L.1: SVG Chart containers */
.ai-svg-wrap {
  margin:8px 0 4px; padding:6px;
  background:rgba(0,0,0,0.15);
  border-radius:var(--ai-radius);
  position:relative;
  overflow:visible;
}
.ai-svg-wrap svg {
  display:block; width:100%; height:auto;
}
.ai-svg-wrap text {
  font-family:var(--ai-font); fill:var(--ai-text2);
}

/* SVG tooltip on hover */
.ai-svg-tip {
  position:absolute; z-index:600;
  background:var(--ai-bg); color:var(--ai-text);
  border:1px solid var(--ai-border-dim);
  border-radius:4px; padding:5px 8px;
  font-family:var(--ai-font); font-size:9px;
  white-space:pre; pointer-events:none;
  box-shadow:0 4px 16px rgba(0,0,0,0.5);
  opacity:0; transition:opacity 120ms;
}
.ai-svg-tip.visible { opacity:1; }

/* L.3: Scenario slider in ROI Model */
.ai-scenario-wrap {
  margin:10px 0 6px;
}
.ai-scenario-slider-row {
  display:flex; align-items:center; gap:10px; margin:6px 0 10px;
}
.ai-scenario-slider-row input[type=range] {
  flex:1; height:4px; -webkit-appearance:none; appearance:none;
  background:rgba(0,200,255,0.12); border-radius:2px; outline:none;
}
.ai-scenario-slider-row input[type=range]::-webkit-slider-thumb {
  -webkit-appearance:none; width:16px; height:16px;
  border-radius:50%; background:var(--ai-border);
  border:2px solid var(--ai-bg); cursor:pointer;
  box-shadow:0 0 6px rgba(0,200,255,0.4);
}
.ai-scenario-slider-row input[type=range]::-moz-range-thumb {
  width:16px; height:16px; border-radius:50%;
  background:var(--ai-border); border:2px solid var(--ai-bg);
  cursor:pointer;
}
.ai-scenario-val {
  font-family:var(--ai-font); font-size:13px;
  font-weight:700; color:var(--ai-heading);
  min-width:72px; text-align:right;
}
.ai-scenario-table {
  width:100%; border-collapse:collapse;
  font-family:var(--ai-font); font-size:11px;
}
.ai-scenario-table th {
  padding:4px 6px; font-size:9px; letter-spacing:1px;
  color:var(--ai-text2); text-align:center; font-weight:400;
}
.ai-scenario-table td {
  padding:5px 6px; text-align:center; color:var(--ai-text);
  border-bottom:1px solid rgba(255,255,255,0.03);
}
.ai-scenario-table td:first-child {
  text-align:left; color:var(--ai-text2); font-size:10px;
}
.ai-scenario-table .ai-sc-current {
  color:var(--ai-heading); font-weight:700;
}
.ai-scenario-table .ai-sc-marker { color:var(--ai-heading); font-size:9px; }
.ai-scenario-summary {
  margin-top:8px; padding-top:6px;
  border-top:1px solid rgba(0,200,255,0.08);
  font-family:var(--ai-font); font-size:11px; color:var(--ai-text);
}

/* L.4: Counter flash animation */
@keyframes aiCounterFlash {
  0%   { color:var(--ai-heading); }
  100% { color:inherit; }
}
.ai-counter-flash {
  animation:aiCounterFlash 600ms ease-out;
}

/* L.7: Compliance progress ring */
.ai-progress-rings {
  display:flex; gap:16px; align-items:center;
  justify-content:center; margin:12px 0;
}
.ai-ring-wrap {
  text-align:center; position:relative;
}
.ai-ring-wrap svg {
  transform:rotate(-90deg); display:block;
}
.ai-ring-label {
  font-family:var(--ai-font); font-size:9px;
  color:var(--ai-text2); margin-top:4px; letter-spacing:0.5px;
}
.ai-ring-pct {
  position:absolute; top:50%; left:50%;
  transform:translate(-50%,-55%);
  font-family:var(--ai-font); font-size:14px;
  font-weight:700; color:var(--ai-heading);
}
.ai-ring-wrap.ai-ring-sm .ai-ring-pct { font-size:11px; }

@keyframes aiRingFill {
  from { stroke-dashoffset:var(--ring-circ); }
}
.ai-ring-track { fill:none; stroke:rgba(0,200,255,0.08); }
.ai-ring-fill {
  fill:none; stroke-linecap:round;
  animation:aiRingFill 1.2s ease-out both;
}

/* L.8: Accordion sections */
.ai-accordion-item {
  border-bottom:1px solid rgba(0,200,255,0.06);
}
.ai-accordion-head {
  display:flex; align-items:center; gap:6px;
  padding:6px 0; cursor:pointer; font-family:var(--ai-font);
  font-size:11px; color:var(--ai-text); transition:color 0.15s;
}
.ai-accordion-head:hover { color:#fff; }
.ai-accordion-arrow {
  font-size:8px; color:var(--ai-text2);
  transition:transform 200ms; flex-shrink:0;
}
.ai-accordion-item.open .ai-accordion-arrow {
  transform:rotate(90deg);
}
.ai-accordion-body {
  max-height:0; overflow:hidden;
  transition:max-height 300ms ease, padding 300ms ease;
  font-family:var(--ai-font); font-size:10px;
  color:var(--ai-text2); line-height:1.6;
  padding:0 0 0 16px;
}
.ai-accordion-item.open .ai-accordion-body {
  max-height:200px; padding:4px 0 8px 16px;
}

/* L.5: Progress bar (reusable) */
.ai-progress {
  height:4px; background:rgba(0,200,255,0.08);
  border-radius:2px; margin:6px 0; overflow:hidden;
  position:relative;
}
.ai-progress-fill {
  height:100%; width:0;
  background:linear-gradient(90deg,var(--ai-border),var(--ai-ok));
  border-radius:2px; transition:width 150ms;
}
.ai-progress-pct {
  position:absolute; right:0; top:-14px;
  font-family:var(--ai-font); font-size:9px; color:var(--ai-heading);
}

/* L.9: Multi-report row */
.ai-report-row {
  display:flex; align-items:center; gap:8px;
  padding:6px 0;
  border-bottom:1px solid rgba(255,255,255,0.03);
  font-family:var(--ai-font); font-size:11px;
}
.ai-report-row:last-child { border-bottom:none; }
.ai-report-icon { font-size:14px; flex-shrink:0; }
.ai-report-name { flex:1; color:var(--ai-text); }
.ai-report-pct { color:var(--ai-heading); font-size:10px; min-width:50px; text-align:right; }
.ai-report-gen {
  font-family:var(--ai-font); font-size:9px;
  padding:3px 10px; border-radius:3px;
  border:1px solid var(--ai-border); background:rgba(0,200,255,0.08);
  color:var(--ai-border); cursor:pointer; transition:all 0.15s;
}
.ai-report-gen:hover { background:var(--ai-border); color:#060a14; }
.ai-report-gen:disabled { opacity:0.5; cursor:default; }
.ai-report-gen.done { border-color:var(--ai-ok); color:var(--ai-ok); background:rgba(0,232,144,0.08); }

/* ════════════════════════════════════════════════════════════
   PHASE J  -  Photo strips in AI cards
   ════════════════════════════════════════════════════════════ */

.ai-card-photo {
  width: 100%;
  border-radius: 6px;
  margin: 8px 0;
  opacity: 0.85;
  transition: opacity 200ms;
  display: block;
}
.ai-card-photo:hover { opacity: 1; }

.ai-card-photo-caption {
  font-family: var(--mono, 'IBM Plex Mono', monospace);
  font-size: 9px;
  color: rgba(0,200,255,0.45);
  letter-spacing: 0.5px;
  margin-top: -4px;
  margin-bottom: 6px;
}

/* ══════════════════════════════════════════════════════════
   DAY MODE OVERRIDES  -  CoreElement.AI theme patch v4
══════════════════════════════════════════════════════════ */
html[data-theme="day"] {
  --ai-bg:         #faf7f2;
  --ai-bg2:        #f0ebe0;
  --ai-border:     #1560a0;
  --ai-border-dim: rgba(21,96,160,0.22);
  --ai-text:       #36526e;
  --ai-text2:      #7a6e5e;
  --ai-heading:    #1560a0;
  --ai-ok:         #1a7a50;
  --ai-warn:       #a86000;
  --ai-crit:       #b82030;
}

/* Statusbar  -  warm beige, no jarring dark block */
html[data-theme="day"] .ai-statusbar {
  background: rgba(245,240,232,0.98) !important;
  border-image: none !important;
  border-top: 1px solid rgba(120,100,70,0.22) !important;
  color: #36526e !important;
  box-shadow: 0 -1px 8px rgba(0,0,0,0.06) !important;
}
html[data-theme="day"] .ai-sb-panel {
  background: rgba(240,234,224,0.98) !important;
  border-top: 1px solid rgba(120,100,70,0.1) !important;
}
html[data-theme="day"] .ai-sb-inner  { color: #36526e !important; }
html[data-theme="day"] .ai-sb-entry  { color: #36526e !important; border-color: rgba(120,100,70,0.08) !important; }
html[data-theme="day"] .ai-sb-entry:hover { color: #1c1914 !important; }
html[data-theme="day"] .ai-sb-time   { color: #7a6e5e !important; }
html[data-theme="day"] .ai-sb-text   { color: #36526e !important; }
html[data-theme="day"] .ai-sb-icon   { color: #1560a0 !important; }
html[data-theme="day"] .ai-sb-toggle { color: #7a6e5e !important; }
html[data-theme="day"] .ai-sb-pulse  { background: #1560a0 !important; }

/* AI Insight cards */
html[data-theme="day"] .ai-card {
  background: #ffffff !important;
  border-left-color: #1560a0 !important;
  color: #36526e !important;
  box-shadow: 0 1px 8px rgba(0,0,0,0.08) !important;
}
html[data-theme="day"] [id^="ai-s"][id$="-zone"].ai-zone-overlay .ai-card {
  background: #ffffff !important;
  box-shadow: 0 2px 16px rgba(0,0,0,0.10) !important;
  border-left-color: #1560a0 !important;
}
html[data-theme="day"] .ai-card.ai-card-ok   { border-left-color: #1a7a50 !important; }
html[data-theme="day"] .ai-card.ai-card-warn { border-left-color: #a86000 !important; }
html[data-theme="day"] .ai-card.ai-card-crit { border-left-color: #b82030 !important; }
html[data-theme="day"] .ai-card-title  { color: #1560a0 !important; }
html[data-theme="day"] .ai-card-sep    { background: linear-gradient(90deg,rgba(21,96,160,0.25),transparent 80%) !important; }
html[data-theme="day"] .ai-card-body   { color: #36526e !important; }
html[data-theme="day"] .ai-card-body .ai-line-ok   { color: #1a7a50 !important; }
html[data-theme="day"] .ai-card-body .ai-line-warn { color: #a86000 !important; }
html[data-theme="day"] .ai-card-body .ai-line-crit { color: #b82030 !important; }
html[data-theme="day"] .ai-card-body .ai-line-hl   { color: #1c1914 !important; }
html[data-theme="day"] .ai-card-actions { border-top-color: rgba(120,100,70,0.1) !important; }
html[data-theme="day"] .ai-cursor     { background: #1560a0 !important; }
html[data-theme="day"] .ai-bar-track  { background: rgba(120,100,70,0.12) !important; }
html[data-theme="day"] .ai-bar-fill   { background: linear-gradient(90deg,#1560a0,rgba(21,96,160,0.4)) !important; }
html[data-theme="day"] .ai-bar-label  { color: #7a6e5e !important; }
html[data-theme="day"] .ai-bar-pct    { color: #1560a0 !important; }
