/* ==========================================================================
   premium.css — Synbar premium design enhancements
   Implements micro-interactions and visual polish per premium.md guidelines
   ========================================================================== */

/* ── TYPOGRAPHY: Inter ── */
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400&display=swap');

body {
  font-family: 'Inter', 'Plus Jakarta Sans', Arial, sans-serif !important;
}
.pm-item {
  font-family: 'Inter', 'Plus Jakarta Sans', Arial, sans-serif !important;
}

/* ── BUTTONS: scale(1.02), 150ms (§3) ── */
.btn {
  transition:
    background 150ms ease,
    transform 150ms cubic-bezier(.34,1.56,.64,1),
    box-shadow 150ms ease,
    border-color 150ms ease !important;
}
.btn:hover {
  transform: scale(1.02) !important;
}
.btn-blue:hover {
  transform: scale(1.02) !important;
  box-shadow: 0 8px 28px rgba(29,78,216,.44) !important;
}
.btn-blue:active,
.ccp-submit:active {
  transform: scale(0.98) !important;
}
.btn-outline:hover {
  transform: scale(1.02) !important;
}
.btn-ghost:hover {
  transform: scale(1.02) !important;
}
.ccp-submit:not(:disabled):hover {
  transform: scale(1.02) !important;
  box-shadow: 0 6px 24px rgba(29,78,216,.48) !important;
}

/* ── SERVICE CARDS: translateY(-4px) + blue border (§3) ── */
.svc-card:hover {
  transform: translateY(-4px) !important;
  border-color: #1D4ED8 !important;
  box-shadow:
    0 20px 60px rgba(29,78,216,.12),
    0 4px 16px rgba(15,23,42,.06) !important;
}

/* ── COMPARE CARDS: translateY(-4px) on hover ── */
.compare-card {
  transition:
    transform .25s cubic-bezier(.34,1.56,.64,1),
    box-shadow .25s ease,
    border-color .25s ease;
}
.compare-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 48px rgba(15,23,42,.1);
}

/* ── CASE CARDS: blue border on hover ── */
.case-card {
  border: 1.5px solid transparent;
  transition:
    border-color .25s ease,
    transform .25s cubic-bezier(.34,1.56,.64,1) !important;
}
.case-card:hover {
  border-color: #1D4ED8 !important;
}

/* ── FAQ TRIGGER: blue text on hover ── */
.faq-trigger:hover h3 {
  color: #1D4ED8;
  transition: color 150ms ease;
}

/* ── LINK UNDERLINE ANIMATION (§3) ── */
.footer-col a {
  position: relative;
  display: inline-block;
}
.footer-col a::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 100%;
  height: 1px;
  background: rgba(255,255,255,.5);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 200ms ease;
}
.footer-col a:hover::after {
  transform: scaleX(1);
}

/* ── INPUT FOCUS: blue border + glow (§3) ── */
.form-input:focus {
  border-color: rgba(29,78,216,.65) !important;
  background: rgba(255,255,255,.07) !important;
  box-shadow: 0 0 0 3px rgba(29,78,216,.18) !important;
}
.ccp-input:focus {
  border-color: rgba(96,165,250,.65) !important;
  background: rgba(255,255,255,.09) !important;
  box-shadow: 0 0 0 3px rgba(29,78,216,.2) !important;
}

/* ── SCROLL ANIMATIONS: smooth pop-in (§9) ── */
.fi {
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity .52s cubic-bezier(0, 0, 0.2, 1),
    transform .52s cubic-bezier(0, 0, 0.2, 1) !important;
  will-change: opacity, transform;
}
.fi.visible {
  opacity: 1 !important;
  transform: translateY(0) !important;
}
/* Stagger classes — 75ms per step */
.fi.d1 { transition-delay: 75ms  !important; }
.fi.d2 { transition-delay: 150ms !important; }
.fi.d3 { transition-delay: 225ms !important; }
.fi.d4 { transition-delay: 300ms !important; }
.fi.d5 { transition-delay: 375ms !important; }
.fi.d6 { transition-delay: 450ms !important; }

/* ── INDUSTRY PILLS: tight timing ── */
.ind-pill {
  transition:
    border-color 150ms ease,
    background 150ms ease,
    color 150ms ease,
    transform 150ms cubic-bezier(.34,1.56,.64,1),
    box-shadow 150ms ease !important;
}

/* ── CASES ARROWS: tight timing ── */
.cases-arrow {
  transition:
    background 150ms ease,
    border-color 150ms ease,
    color 150ms ease,
    transform 150ms cubic-bezier(.34,1.56,.64,1) !important;
}

/* ══════════════════════════════════════════════════════════════════
   SCORE RING COMPONENT (§4)
   Usage: <div class="score-ring" data-score="81" data-color="sr-green">
══════════════════════════════════════════════════════════════════ */

.score-rings-row {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 16px;
  width: 100%;
  align-items: start;
}

.score-ring-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 0;
}

.score-ring {
  position: relative;
  width: 108px;
  height: 108px;
  flex-shrink: 0;
}

.score-ring svg {
  transform: rotate(-90deg);
  width: 108px;
  height: 108px;
}

.sr-track {
  fill: none;
  stroke: rgba(255,255,255,.1);
  stroke-width: 7;
}

.sr-fill {
  fill: none;
  stroke-width: 7;
  stroke-linecap: round;
  stroke-dasharray: 301.6; /* 2π × 48 */
  stroke-dashoffset: 301.6;
  transition: stroke-dashoffset 1.6s cubic-bezier(.4,0,.2,1);
}

.sr-green { stroke: #22c55e; }
.sr-amber { stroke: #f59e0b; }
.sr-red   { stroke: #ef4444; }

.score-ring-num {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1px;
}

.sr-val {
  font-size: 26px;
  font-weight: 800;
  line-height: 1;
  color: #fff;
  font-variant-numeric: tabular-nums;
  letter-spacing: -.035em;
}

.sr-max {
  font-size: 11px;
  color: rgba(255,255,255,.38);
  font-weight: 500;
}

.score-ring-card-label {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 500;
  color: rgba(255,255,255,.62);
  text-align: center;
  letter-spacing: .01em;
}

/* ══════════════════════════════════════════════════════════════════
   PLATFORM LOGO BADGES (§4) — cleaner SVG-driven badges
══════════════════════════════════════════════════════════════════ */

.plat-logo-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.plat-logo-badge {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 8px 13px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 10px;
  cursor: default;
  transition:
    background 150ms ease,
    border-color 150ms ease,
    transform 150ms cubic-bezier(.34,1.56,.64,1);
}

.plat-logo-badge:hover {
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.22);
  transform: translateY(-2px);
}

.plat-logo-icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
}

.plat-logo-name {
  font-size: 12.5px;
  font-weight: 600;
  color: rgba(255,255,255,.78);
}

.plat-status-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
  margin-left: 4px;
}
.plat-dot-green { background: #22c55e; }
.plat-dot-amber { background: #f59e0b; }
.plat-dot-red   { background: #ef4444; }

/* ══════════════════════════════════════════════════════════════════
   VIS-BANNER LAYOUT UPGRADE
══════════════════════════════════════════════════════════════════ */

.vis-banner-upgraded {
  display: flex;
  flex-direction: column;
  gap: 28px;
  position: relative;
  z-index: 1;
  width: 100%;
}

/* Text row at top */
.vis-banner-top {
  width: 100%;
}

/* Rings row: CSS grid — equal columns, no flex quirks */
.score-rings-row {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 12px;
  width: 100%;
}

.score-ring {
  width: 96px;
  height: 96px;
}

.score-ring svg {
  width: 96px;
  height: 96px;
}

.sr-val {
  font-size: 23px;
}

.vis-banner-bottom {
  width: 100%;
}

@media (max-width: 900px) {
  .score-rings-row { grid-template-columns: repeat(3, 1fr); gap: 16px; }
}

@media (max-width: 540px) {
  .score-rings-row { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .score-ring { width: 80px; height: 80px; }
  .score-ring svg { width: 80px; height: 80px; }
  .sr-val { font-size: 20px; }
}

@media (max-width: 380px) {
  .score-ring { width: 70px; height: 70px; }
  .score-ring svg { width: 70px; height: 70px; }
  .sr-val { font-size: 18px; }
  .score-ring-card-label { font-size: 12px; }
}

/* ══════════════════════════════════════════════════════════════════
   FLOATING LABELS — contact form (§3)
══════════════════════════════════════════════════════════════════ */

.float-wrap {
  position: relative;
}

.float-label {
  position: absolute;
  left: 18px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 14px;
  font-weight: 500;
  color: var(--muted, #94a3b8);
  pointer-events: none;
  transition:
    top 150ms ease,
    font-size 150ms ease,
    color 150ms ease,
    transform 150ms ease;
  background: white;
  padding: 0 4px;
  border-radius: 3px;
  line-height: 1;
}

.float-label-ta {
  top: 20px;
  transform: none;
}

.float-input:focus ~ .float-label,
.float-input:not(:placeholder-shown) ~ .float-label {
  top: -1px;
  font-size: 11px;
  color: #1D4ED8;
  transform: translateY(-50%);
}

.float-label-ta:has(~ .float-textarea:focus),
.float-input.float-textarea:focus ~ .float-label-ta,
.float-input.float-textarea:not(:placeholder-shown) ~ .float-label-ta {
  top: -1px;
  font-size: 11px;
  color: #1D4ED8;
  transform: none;
}

.float-input:focus ~ .float-label-ta,
.float-input:not(:placeholder-shown) ~ .float-label-ta {
  top: -1px;
  font-size: 11px;
  color: #1D4ED8;
  transform: none;
}

.float-input {
  padding-top: 14px !important;
  padding-bottom: 14px !important;
}

.float-input:focus,
.float-input:not(:placeholder-shown) {
  padding-top: 20px !important;
  padding-bottom: 8px !important;
}

.float-textarea {
  padding-top: 20px !important;
}

.float-textarea:not(:placeholder-shown) {
  padding-top: 22px !important;
}

/* Dark mode: label background matches card bg */
[data-theme="dark"] .float-label {
  background: #1e293b;
  color: rgba(255,255,255,.4);
}

/* ══════════════════════════════════════════════════════════════════
   PERFORMANCE (§8–9 from performance.md)
══════════════════════════════════════════════════════════════════ */

/* Prevent horizontal scroll on every page */
body {
  overflow-x: hidden !important;
}

/* CSS containment on static section shells — tells browser these don't
   affect layout outside themselves, enabling paint/style optimisations */
.section,
.stats-band,
.cta-section,
.pm-section,
.cases-section,
.ts-section,
.page-hero {
  contain: layout style;
}

/* GPU-promote elements that animate or transform */
.ai-window,
.hero-sticker,
.ccp-inner,
.pill-cursor,
.sw-thumb,
.chat-typing,
.case-img {
  will-change: transform;
}

/* Ensure images never cause horizontal overflow */
img {
  max-width: 100%;
  height: auto;
}

/* ── MOBILE: disable hover transforms ── */
@media (hover: none) {
  .btn:hover,
  .svc-card:hover,
  .ind-pill:hover,
  .plat-logo-badge:hover {
    transform: none !important;
  }
}

/* ── PREFERS-REDUCED-MOTION ── */
@media (prefers-reduced-motion: reduce) {
  .fi {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
  .btn {
    transition: background 150ms ease !important;
  }
  .sr-fill {
    transition: none !important;
  }
}
