/* ==========================================================================
   AIO Vend — Inline Overrides (extracted from index.html)
   Purpose: preserve exact behavior previously provided by inline <style> tags
   Load this LAST in <head> after all other CSS so it can override when needed.
   ========================================================================== */

/* == Feature Flags ======================================================= */
/* Hide Industry News when the flag is off */
html[data-show-news="false"] #industryNews { display: none !important; }

/* == Maintenance Mode ==================================================== */
/* Show only the maintenance notice when data-maintenance is present */
html[data-maintenance="true"] body > * { display: none !important; }
#maintenanceNotice { display: none; }

html[data-maintenance="true"] #maintenanceNotice {
  display: flex !important;
}

/* Full-bleed centered card */
#maintenanceNotice {
  position: fixed; inset: 0;
  align-items: center; justify-content: center;
  padding: 2rem;
  background: var(--clr-bg, #0f141b);
  color: var(--clr-fg, #e5e7eb);
  z-index: 999999;
}
#maintenanceNotice .card {
  max-width: 680px; width: 100%;
  border-radius: var(--radius-lg, 16px);
  border: 1px solid var(--clr-border, #374151);
  background: var(--clr-surface, #111827);
  box-shadow: var(--shadow-lg, 0 10px 30px rgba(0,0,0,.35));
  padding: 1.5rem 1.25rem;
  text-align: center;
}
#maintenanceNotice h1 {
  margin: 0 0 .5rem; font: 700 1.5rem/1.2 Inter, system-ui, sans-serif;
}
#maintenanceNotice p { margin: .4rem 0; line-height: 1.5; }
#maintenanceNotice .muted { opacity: .8; }
#maintenanceNotice .btn {
  display: inline-block; margin-top: 1rem; padding: .7rem 1rem;
  border-radius: 10px; border: 1px solid var(--clr-border, #374151);
  text-decoration: none; color: inherit;
}

/* Light theme fallbacks */
:root,[data-theme="light"]{
  --clr-bg:#ffffff; --clr-surface:#ffffff; --clr-fg:#111827; --clr-border:#e5e7eb;
}
[data-theme="dark"]{
  --clr-bg:#0f141b; --clr-surface:#111827; --clr-fg:#e5e7eb; --clr-border:#374151;
}

/* == Inline PDF Viewer Styling & Micro-interactions ====================== */
#acceptorManual {
  background-color: var(--clr-bg);
  padding: 0;
}
#acceptorManual .section__title {
  text-align: center;
  margin-bottom: 2rem;
}
#pdf-viewer-wrapper {
  width: 100%;
  max-width: 100%;
  margin-inline: auto;
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}
#pdf-viewer-wrapper iframe {
  width: 100%;
  height: 80vh;
  border: none;
}

/* ===== Micro-interactions (subtle, opt-in) ===== */
:root{
  --ease-smooth: cubic-bezier(.22,.61,.36,1);
  --dur-1: 160ms;
  --dur-2: 260ms;
}
@media (prefers-reduced-motion: reduce){
  [data-ux="enhanced"] * { animation: none !important; transition: none !important; }
}

/* 2A. Scroll-reveal (applies when JS adds .is-visible) */
[data-ux="enhanced"] [data-reveal]{
  opacity: 0;
  transform: translateY(14px) scale(.985);
  transition: opacity var(--dur-2) var(--ease-smooth), transform var(--dur-2) var(--ease-smooth);
  will-change: opacity, transform;
}
[data-ux="enhanced"] .is-visible[data-reveal]{
  opacity: 1;
  transform: none;
}

/* 2B. Card hover lift (super subtle) */
[data-ux="enhanced"] :is(.service-card,.vlaunch__card,.vlaunch__calc.card,.guide-promo__wrap.card,.manuals-toolbar.card,.card){
  transition: transform var(--dur-2) var(--ease-smooth), box-shadow var(--dur-2) var(--ease-smooth);
}
[data-ux="enhanced"] :is(.service-card,.vlaunch__card,.vlaunch__calc.card,.guide-promo__wrap.card,.manuals-toolbar.card,.card):hover{
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(0,0,0,.10);
}

/* 2C. Buttons: hover float + press */
[data-ux="enhanced"] .btn{
  transition: transform var(--dur-1) var(--ease-smooth), box-shadow var(--dur-1) var(--ease-smooth);
}
[data-ux="enhanced"] .btn:hover{ transform: translateY(-1px); box-shadow: 0 6px 16px rgba(0,0,0,.08); }
[data-ux="enhanced"] .btn:active{ transform: translateY(0); box-shadow: inset 0 0 0 9999px rgba(0,0,0,.03); }

/* 2D. Nav/link underline sweep */
[data-ux="enhanced"] .nav__links a,
[data-ux="enhanced"] .peek-link,
[data-ux="enhanced"] .section__subtitle a{
  background-image: linear-gradient(currentColor,currentColor);
  background-size: 0% 2px; background-repeat: no-repeat; background-position: 0 100%;
  transition: background-size var(--dur-1) var(--ease-smooth), color var(--dur-1) var(--ease-smooth);
}
[data-ux="enhanced"] .nav__links a:hover,
[data-ux="enhanced"] .nav__links a:focus,
[data-ux="enhanced"] .peek-link:hover{ background-size: 100% 2px; }

/* 2E. Progress bar: gentle animated sheen */
[data-ux="enhanced"] .progress__bar{
  background-image: linear-gradient(90deg, var(--brand-1,#6366f1), var(--brand-2,#0ea5e9), var(--brand-1,#6366f1));
  background-size: 200% 100%;
  animation: progressSheen 3s linear infinite;
}
@keyframes progressSheen{ to{ background-position: -200% 0; } }

/* 2F. Rails: fade edges hint (no layout changes) */
[data-ux="enhanced"] .install-showcase__viewport,
[data-ux="enhanced"] .mini-ms-preview{
  -webkit-mask-image: linear-gradient(to right, transparent, #000 24px, #000 calc(100% - 24px), transparent);
          mask-image: linear-gradient(to right, transparent, #000 24px, #000 calc(100% - 24px), transparent);
}

/* 2G. Details/accordion: smoother open/close + rotating caret */
[data-ux="enhanced"] .vlaunch-step summary{
  transition: background-color var(--dur-1) var(--ease-smooth);
}
[data-ux="enhanced"] .vlaunch-step[open] summary{ background-color: color-mix(in srgb, currentColor 6%, transparent); }
[data-ux="enhanced"] .vlaunch-step summary i.fa-solid.fa-angle-down{
  transition: transform var(--dur-2) var(--ease-smooth);
}
[data-ux="enhanced"] .vlaunch-step[open] summary i.fa-solid.fa-angle-down{ transform: rotate(180deg); }
[data-ux="enhanced"] .vlaunch-step__content{ overflow: clip; }

/* 2H. Hash-target flash when jumping within page (e.g., to #services) */
[data-ux="enhanced"] [id]:target{
  animation: targetFlash 1200ms var(--ease-smooth);
  outline: 2px solid color-mix(in srgb, currentColor 35%, transparent);
  outline-offset: 4px;
}
@keyframes targetFlash{
  0%{ background-color: color-mix(in srgb, currentColor 10%, transparent); }
  100%{ background-color: transparent; }
}

/* 2I. Site alert: soft slide-in and nicer dismiss */
[data-ux="enhanced"] .site-alert{ animation: siteAlertIn .4s var(--ease-smooth) both; }
@keyframes siteAlertIn{ from{ transform: translateY(-6px); opacity: 0 } to{ transform:none; opacity:1 } }

/* Hero primary button hover (exact override) */
.hero .btn.btn--primary:hover,
.hero .btn.btn--primary:focus-visible {
  background: #10b981 !important;
  border-color: #10b981 !important;
  color: #fff !important;
}

/* == Marketplace CTA (index.html only) =================================== */
/* Styles the "View Full Marketplace" button in #equipmentMarketPreview */
#equipmentMarketPreview .market-cta-wrapper{
  display:flex; justify-content:center; margin-top:1rem;
}
#equipmentMarketPreview .market-cta-btn{
  --cta-1: var(--brand-1, #10b981);
  --cta-2: var(--brand-2, #2563eb);
  --cta-border: color-mix(in srgb, var(--cta-1) 45%, transparent);
  /* Sheen tuning */
  --sheen-alpha: .22; /* default light-mode intensity */
  --sheen-start: -55%; /* start position (fixes “way off left”) */
  --sheen-end: 55%;
  position: relative; isolation: isolate; overflow: hidden;
  display: inline-flex; align-items: center; gap: .6rem;
  padding: .95rem 1.25rem; border-radius: 999px;
  background-image: linear-gradient(90deg, var(--cta-1), var(--cta-2));
  color: #fff !important; border: 1px solid var(--cta-border);
  box-shadow: 0 8px 24px rgba(0,0,0,.12), 0 0 0 1px color-mix(in srgb, #fff 10%, transparent);
  font-weight: 700; letter-spacing: .02em; line-height: 1; text-decoration: none;
}
/* Soft sheen that sweeps on hover/focus */
#equipmentMarketPreview .market-cta-btn::before{
  content: ""; position: absolute; inset: 0; border-radius: inherit;
  /* Narrower, centered band so it doesn’t feel offset */
  background: linear-gradient(120deg, transparent 32%, rgba(255,255,255,var(--sheen-alpha)) 50%, transparent 68%);
  transform: translateX(var(--sheen-start));
  transition: transform 600ms var(--ease-smooth, cubic-bezier(.22,.61,.36,1));
  pointer-events: none; z-index: -1; /* under content */
}
/* Arrow nudge */
#equipmentMarketPreview .market-cta-btn::after{
  content: "→";
  transition: transform var(--dur-1,160ms) var(--ease-smooth, cubic-bezier(.22,.61,.36,1));
  will-change: transform;
}
/* Hover / focus polish */
#equipmentMarketPreview .market-cta-btn:hover,
#equipmentMarketPreview .market-cta-btn:focus-visible{
  box-shadow: 0 10px 28px rgba(0,0,0,.14), 0 0 0 2px color-mix(in srgb, var(--cta-2) 45%, transparent);
}
#equipmentMarketPreview .market-cta-btn:hover::before,
#equipmentMarketPreview .market-cta-btn:focus-visible::before{
  transform: translateX(var(--sheen-end));
}
#equipmentMarketPreview .market-cta-btn:hover::after,
#equipmentMarketPreview .market-cta-btn:focus-visible::after{
  transform: translateX(3px);
}
/* Accessible focus ring */
#equipmentMarketPreview .market-cta-btn:focus-visible{
  outline: 3px solid color-mix(in srgb, var(--cta-2) 60%, #ffffff);
  outline-offset: 2px;
}
/* Pressed state */
#equipmentMarketPreview .market-cta-btn:active{
  transform: translateY(0);
  box-shadow: 0 4px 14px rgba(0,0,0,.16), 0 0 0 1px color-mix(in srgb, var(--cta-1) 30%, transparent);
}
/* Mobile */
@media (max-width: 640px){
  #equipmentMarketPreview .market-cta-btn{
    width: 100%; justify-content: center; padding: 1.05rem 1.15rem; font-size: 1rem;
  }
}
/* Dark mode adjustments */
@media (prefers-color-scheme: dark){
  #equipmentMarketPreview .market-cta-btn{
    --sheen-alpha: .14;
    --sheen-start: -40%;
    --sheen-end: 40%;
    box-shadow: 0 8px 22px rgba(0,0,0,.35), 0 0 0 1px color-mix(in srgb, #fff 6%, transparent);
  }
  #equipmentMarketPreview .market-cta-btn:hover,
  #equipmentMarketPreview .market-cta-btn:focus-visible{
    box-shadow: 0 10px 26px rgba(0,0,0,.38), 0 0 0 2px color-mix(in srgb, var(--cta-2) 35%, transparent);
  }
  #equipmentMarketPreview .market-cta-btn:focus-visible{
    outline: 3px solid color-mix(in srgb, var(--cta-2) 55%, #ffffff);
  }
}
/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  #equipmentMarketPreview .market-cta-btn,
  #equipmentMarketPreview .market-cta-btn::before,
  #equipmentMarketPreview .market-cta-btn::after{
    transition: none !important;
  }
}

/* == Guide & Glossary Promo (scoped) ===================================== */
/* Theme tokens (Light default) */
:root,
:root[data-theme="light"],
[data-theme="light"] {
  --clr-border: #e5e7eb;
  --clr-surface: #ffffff;
  --chip-bg: #f3f4f6;
}
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    --clr-border: #374151;
    --clr-surface: #0f141b;
    --chip-bg: #1f2937;
  }
}
:root[data-theme="dark"],
[data-theme="dark"] {
  --clr-border: #374151;
  --clr-surface: #0f141b;
  --chip-bg: #1f2937;
}

/* Original design (unchanged) */
.guide-promo .card {
  display: grid; gap: 2rem;
  grid-template-columns: 1.35fr 1fr; align-items: center;
}
.guide-promo__copy .section__title { margin-bottom: .25rem; }
.guide-promo__search { display: flex; gap: .75rem; margin: .75rem 0; }
.guide-promo__search input {
  flex: 1; padding: .8rem 1rem;
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: var(--radius-md, 10px);
  background: var(--clr-surface, #fff);
  color: inherit;
}
.guide-promo__help { display: block; opacity: .8; }
.guide-promo__chips {
  display: flex; flex-wrap: wrap; gap: .5rem; margin-top: .75rem;
}
.guide-promo__chips .chip {
  display: inline-flex; align-items: center; gap: .4rem;
  padding: .4rem .7rem; border-radius: 999px;
  background: var(--chip-bg, #f3f4f6);
  border: 1px solid var(--clr-border, #e5e7eb);
  font-size: .9rem; color: inherit;
}
.guide-promo__peek { display: flex; flex-direction: column; gap: 1rem; }
.peek-list { list-style: none; padding: 0; margin: 0; display: grid; gap: .5rem; }
.peek-link {
  display: flex; gap: .6rem; align-items: center; padding: .6rem .75rem;
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: var(--radius-md, 10px);
  background: var(--clr-surface, #fff);
  color: inherit;
}
.guide-promo__cta { align-self: flex-start; }
@media (max-width: 960px) {
  .guide-promo .card { grid-template-columns: 1fr; }
}
