/* ==========================================================
   Stackpole Europe Limited - Global Styles (2025)
   Enhanced Maroon Edition
   ========================================================== */
:root{
  --brand:#1e3a8a;
  --brand-dark:#142960;
  --accent:#660000;        /* deep maroon */
  --accent-dark:#4d0000;
  --accent-light:#8b0000;
  --text:#111827;
  --muted:#6b7280;
  --bg:#f9fafb;
  --panel:#ffffff;
  --line:#e5e7eb;
  --radius:12px;
  --shadow:0 2px 10px rgba(0,0,0,.05);
  --font:"Inter","Segoe UI",Roboto,Arial,sans-serif;
}

/* Base */
html,body{margin:0;padding:0;font-family:var(--font);color:var(--text);background:var(--bg);min-height:100%;overflow-y:auto;scroll-behavior:smooth}
h1,h2,h3,h4{margin:0 0 .5em;line-height:1.2}
p{margin:0 0 1em}
a{color:var(--accent);text-decoration:none;transition:color .3s ease}
a:hover{color:var(--accent-light);text-decoration:underline}
img{max-width:100%;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 20px}
.container.narrow{max-width:900px}
.section{padding:60px 0}
.section.alt{background:#fff}

/* Header */
.header{background:rgba(255,255,255,.95);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:999;backdrop-filter:blur(6px);transition:box-shadow .3s ease}
.header.scrolled{box-shadow:0 2px 8px rgba(0,0,0,.08)}
.header .bar{display:flex;justify-content:space-between;align-items:center;padding:10px 0}
.brand{display:flex;align-items:center;gap:10px;font-weight:700}
.brand img{height:40px}
nav a{margin-left:20px;font-weight:500;color:var(--text)}
nav a:hover,nav a[aria-current="page"]{color:var(--accent)}

/* Hero */
.hero{background:linear-gradient(135deg,rgba(102,0,0,.4) 0%,var(--brand) 60%,var(--brand-dark) 100%);color:#fff;padding:90px 0;text-align:left}
.hero h1{font-size:2.6rem;margin-bottom:.5em;text-shadow:0 2px 6px rgba(0,0,0,.2)}
.hero p{color:#e5e7eb;max-width:60ch}
.hero .actions{display:flex;gap:12px;flex-wrap:wrap}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:10px 20px;font-weight:500;border:none;cursor:pointer;transition:all .25s ease;text-decoration:none}
.btn.primary{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;box-shadow:0 3px 10px rgba(102,0,0,.3)}
.btn.primary:hover{background:linear-gradient(135deg,var(--accent-light),var(--accent));transform:translateY(-2px);box-shadow:0 5px 14px rgba(102,0,0,.45)}
.btn.ghost{background:#fff;color:var(--accent);border:1px solid var(--accent)}
.btn.ghost:hover{background:var(--accent);color:#fff;box-shadow:0 4px 10px rgba(102,0,0,.25);transform:translateY(-2px)}
.btn.ghost-inv{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.5)}
.btn.ghost-inv:hover{background:rgba(255,255,255,.15);border-color:#fff;transform:translateY(-2px)}

/* Focus Products */
.focus-grid{display:grid;gap:20px;margin-top:30px}
@media(min-width:768px){.focus-grid{grid-template-columns:repeat(3,1fr)}}
.focus-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;transition:all .3s ease}
.focus-card:hover{transform:translateY(-4px);box-shadow:0 6px 20px rgba(102,0,0,.25)}
.focus-card h3{color:var(--text);font-size:18px;margin:10px 0 6px}
.focus-card p{color:var(--muted);font-size:15px}

/* BOM */
.bom-form{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-top:20px}
.bom-form input[type=file]{border:1px solid var(--line);border-radius:var(--radius);padding:10px;background:#fff;flex:1}
.bom p{font-size:14px;color:var(--muted)}

/* Footer */
.footer{background:#fff;border-top:1px solid var(--line);color:var(--muted);padding:20px 0;text-align:center;font-size:14px}
.legal-links{font-size:13px;margin-top:10px}
.legal-links a{color:var(--muted);text-decoration:none;margin:0 5px;transition:color .2s ease}
.legal-links a:hover{color:var(--accent)}

/* Reveal animation (JS-safe) */
[data-reveal]{transform:translateY(10px);transition:all .6s ease} /* visible by default */
.js [data-reveal]{opacity:0}                                     /* only hide if JS is present */
.js .fade{opacity:1 !important;transform:translateY(0) !important}

/* ====== Global card/grid fallback for all product pages ====== */
.grid,.product-grid,.series-grid,.grid-3{display:grid;gap:16px}
@media(min-width:680px){.grid,.product-grid,.series-grid,.grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(min-width:1024px){.grid,.product-grid,.series-grid,.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}}

.card,.product-card,.series-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px;display:flex;flex-direction:column;gap:12px;transition:transform .25s ease,box-shadow .25s ease}
.card:hover,.product-card:hover,.series-card:hover{transform:translateY(-4px);box-shadow:0 6px 20px rgba(102,0,0,.25)}

.thumb{height:140px;border:1px solid var(--line);border-radius:10px;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden}
.thumb img{max-width:92%;max-height:92%;object-fit:contain;display:block}

.card h2,.product-card h2,.series-card h2,.card h3,.product-card h3,.series-card h3{margin:0;font-size:18px;line-height:1.25}
.meta{display:flex;flex-wrap:wrap;gap:8px}
.badge{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:999px;padding:4px 10px;background:#fff;font-size:12px;color:var(--muted);transition:all .3s ease}
.badge.aec{color:var(--accent);border-color:var(--accent)}
.badge.aec:hover{background:var(--accent);color:#fff}

.specs{margin:0;display:grid;grid-template-columns:auto 1fr;gap:6px 12px;font-size:14px}
.specs dt{color:var(--muted)}
.specs dd{margin:0}
.actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:auto}

/* Optional list variant */
.card-list{display:grid;gap:10px}
.card-list .row{display:grid;gap:10px;grid-template-columns:1.2fr .8fr .8fr .8fr .8fr auto;align-items:center;background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px}
@media(max-width:880px){.card-list .row{grid-template-columns:1fr 1fr}}

/* ==== Focus Products Carousel ==== */
.focus-container {
  position: relative;
  display: flex;
  align-items: center;
}

.focus-scroll {
  display: flex;
  overflow-x: auto;
  scroll-behavior: smooth;
  gap: 1rem;
  padding: 1rem 0;
  scroll-snap-type: x mandatory;
}

.focus-scroll::-webkit-scrollbar {
  height: 8px;
}
.focus-scroll::-webkit-scrollbar-thumb {
  background: #660000;
  border-radius: 4px;
}
.focus-scroll::-webkit-scrollbar-track {
  background: #f5f5f5;
}

.product-card {
  flex: 0 0 300px;
  scroll-snap-align: start;
  background: #fff;
  border: 1px solid #eee;
  border-radius: 12px;
  padding: 1rem;
  box-shadow: 0 1px 3px rgba(0,0,0,0.05);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.product-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 3px 8px rgba(102,0,0,0.15);
}

.thumb img {
  width: 100%;
  height: 140px;
  object-fit: contain;
  background: #fafafa;
  border-radius: 8px;
  margin-bottom: 0.5rem;
}

.scroll-btn {
  background: #660000;
  color: #fff;
  border: none;
  border-radius: 50%;
  width: 36px;
  height: 36px;
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  transition: background 0.2s ease;
  flex-shrink: 0;
}
.scroll-btn:hover {
  background: #990000;
}

.scroll-btn.left {
  margin-right: 0.5rem;
}
.scroll-btn.right {
  margin-left: 0.5rem;
}


/* ===== Cookie Banner & Preferences Modal ===== */
.cookie-banner{position:fixed;inset:auto 0 0 0;z-index:9999;background:#fff;border-top:1px solid var(--line);box-shadow:0 -6px 20px rgba(0,0,0,.08);font-size:14px}
.cookie-banner .wrap{max-width:1100px;margin:0 auto;padding:14px 16px;display:grid;gap:10px;align-items:center}
@media(min-width:820px){.cookie-banner .wrap{grid-template-columns:1fr auto}}
.cookie-banner p{margin:0;color:var(--text)}
.cookie-banner .actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}
.cookie-banner .btn{border:1px solid var(--line)}
.cookie-banner .btn.primary{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;border:none}
.cookie-banner .btn.ghost{background:#fff;color:var(--accent);border:1px solid var(--accent)}
.cookie-banner a{color:var(--accent)}

/* Modal overlay */
.cookie-modal{position:fixed;inset:0;z-index:10000;display:none;background:rgba(0,0,0,.45)}
.cookie-modal[open]{display:grid;place-items:center}
.cookie-modal .panel{width:min(680px,94vw);background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.25);padding:16px}
.cookie-modal h2{margin:0 0 6px}
.cookie-modal p{color:var(--muted);margin-bottom:12px}
.cookie-modal .opt{display:flex;align-items:center;justify-content:space-between;border:1px solid var(--line);border-radius:10px;padding:10px 12px;margin:10px 0}
.cookie-modal .opt label{font-weight:600}
.cookie-modal .opt small{display:block;color:var(--muted)}
.cookie-modal .row{display:flex;gap:10px;justify-content:flex-end;margin-top:12px}



/* ----- Upload BOM (Card-styled dropzone) ----- */
.dropzone {
  position: relative;
  border: 2px dashed rgba(102,0,0,0.25); /* #660000 */
  border-radius: 12px;
  background: #fafafa;
  min-height: 140px;
  display: grid;
  place-items: center;
  padding: 18px;
  transition: border-color .2s ease, background .2s ease, box-shadow .2s ease;
  outline: none;
}
.dropzone:hover,
.dropzone:focus-visible {
  border-color: #660000;
  background: #fef9f9;
  box-shadow: 0 0 0 3px rgba(102,0,0,0.08) inset;
}
.dropzone.is-hover {
  border-color: #660000;
  background: #fff4f4;
  box-shadow: 0 0 0 3px rgba(102,0,0,0.15) inset;
}
.dropzone input[type="file"] {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
}
.dz-inner {
  text-align: center;
  pointer-events: none; /* clickable is the hidden input */
}
.dz-icon {
  font-size: 32px;
  line-height: 1;
  margin-bottom: 8px;
  opacity: .7;
}
.dz-text {
  font-size: 0.95rem;
  margin-bottom: 6px;
}
.table-wrap {
  overflow-x: auto;
}
.table.is-compact td,
.table.is-compact th {
  padding: 6px 8px;
}
/* ===== Nav search icon & social links ===== */
.nav-search-icon {
  display:inline-flex;
  align-items:center;
  font-size:1.1rem;
  padding:4px 8px;
  border-radius:8px;
  transition:background .2s;
  text-decoration:none !important;
  color:var(--text) !important;
}
.nav-search-icon:hover { background:rgba(102,0,0,.08); color:var(--accent) !important; }

.social-links { font-size:13px; margin-top:6px; }
.social-links a { color:var(--muted); text-decoration:none; transition:color .2s; }
.social-links a:hover { color:var(--accent); text-decoration:underline; }
.social-link { font-weight:600; }

/* ===== Parametric filter toolbar ===== */
.filter-toolbar {
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  padding:12px 16px;
  margin-bottom:24px;
}
.filter-toolbar .f-field {
  display:flex;
  align-items:center;
  gap:8px;
  border:1px solid var(--line);
  border-radius:999px;
  padding:7px 14px;
  background:#fff;
  font-size:.9rem;
}
.filter-toolbar .f-field label { color:var(--muted); font-size:.82rem; white-space:nowrap; }
.filter-toolbar select, .filter-toolbar input[type="search"] {
  border:0; outline:0; background:transparent; font-size:.9rem; min-width:120px;
}
.filter-toolbar .f-search { flex:1; min-width:180px; }
.filter-count { font-size:.82rem; color:var(--muted); margin-bottom:10px; }
.product-card[hidden] { display:none !important; }

/* ===== Newsletter section ===== */
.newsletter-band {
  background:linear-gradient(135deg,var(--brand),var(--brand-dark));
  color:#fff;
  border-radius:var(--radius);
  padding:36px 40px;
  text-align:center;
  margin-top:20px;
}
.newsletter-band h2 { color:#fff; margin-bottom:8px; }
.newsletter-band p { color:#e5e7eb; margin-bottom:20px; max-width:50ch; margin-left:auto; margin-right:auto; }
.newsletter-band form { display:flex; gap:10px; max-width:460px; margin:0 auto; flex-wrap:wrap; justify-content:center; }
.newsletter-band input[type="email"] {
  flex:1; min-width:200px; padding:12px 16px; border-radius:8px; border:none;
  font-size:1rem; background:rgba(255,255,255,.15); color:#fff;
}
.newsletter-band input[type="email"]::placeholder { color:rgba(255,255,255,.6); }
.newsletter-band input[type="email"]:focus { outline:2px solid rgba(255,255,255,.5); background:rgba(255,255,255,.25); }
.newsletter-band button {
  padding:12px 24px; background:var(--accent); color:#fff; border:none;
  border-radius:8px; font-weight:600; cursor:pointer; transition:background .2s;
}
.newsletter-band button:hover { background:var(--accent-light); }
.newsletter-band .fine { font-size:.75rem; color:rgba(255,255,255,.5); margin-top:12px; }
.newsletter-band .fine a { color:rgba(255,255,255,.6); }

/* Top nav dropdown */
.topnav { display:flex; gap:16px; align-items:center; }

.nav-dd { position:relative; display:inline-block; }
.nav-dd__trigger { display:inline-flex; gap:6px; align-items:center; }

.nav-dd__menu{
  position:absolute;
  top:100%;           /* flush with trigger — no gap for mouse to fall through */
  left:0;
  min-width:240px;
  background:#fff;
  border:1px solid rgba(0,0,0,.12);
  border-radius:10px;
  padding:8px;
  padding-top:14px;   /* visual breathing room replaces the old 8px positional gap */
  box-shadow:0 10px 25px rgba(0,0,0,.10);
  display:none;
  z-index:9999;
}

.nav-dd__menu a{
  display:block;
  padding:10px 10px;
  border-radius:8px;
  white-space:nowrap;
}

.nav-dd__menu a:hover{ background:rgba(0,0,0,.05); }

.nav-dd:hover .nav-dd__menu,
.nav-dd:focus-within .nav-dd__menu{
  display:block;
}

/* ═══════════════════════════════════════════════
   PRODUCT PAGE ENHANCEMENTS
   ═══════════════════════════════════════════════ */

/* Hero grid background */
.hero { position:relative; overflow:hidden; }
.hero-bg { position:absolute; inset:0; opacity:.07; pointer-events:none;
  background-image:
    repeating-linear-gradient(0deg,transparent,transparent 39px,rgba(255,255,255,.6) 39px,rgba(255,255,255,.6) 40px),
    repeating-linear-gradient(90deg,transparent,transparent 39px,rgba(255,255,255,.6) 39px,rgba(255,255,255,.6) 40px);
  background-size:40px 40px; }
.hero-app-tags { display:flex; gap:8px; flex-wrap:wrap; margin-top:18px; }
.hero-app-tag { background:rgba(255,255,255,.15); border:1px solid rgba(255,255,255,.3); border-radius:999px; padding:4px 12px; font-size:.75rem; color:rgba(255,255,255,.9); }

/* Technology strip */
.tech-strip { background:#fff; border-bottom:2px solid var(--line); }
.tech-strip-inner { display:grid; grid-template-columns:repeat(2,1fr); }
@media(min-width:560px){ .tech-strip-inner { grid-template-columns:repeat(3,1fr); } }
@media(min-width:900px){ .tech-strip-inner { grid-template-columns:repeat(5,1fr); } }
.tech-strip-inner.cols-3 { grid-template-columns:repeat(2,1fr); }
@media(min-width:560px){ .tech-strip-inner.cols-3 { grid-template-columns:repeat(3,1fr); } }
.tech-strip-inner.cols-4 { grid-template-columns:repeat(2,1fr); }
@media(min-width:700px){ .tech-strip-inner.cols-4 { grid-template-columns:repeat(4,1fr); } }
.tech-item { padding:18px 14px; border-right:1px solid var(--line); cursor:pointer; transition:background .15s; text-decoration:none; display:block; }
.tech-item:hover { background:#fdf2f2; }
.tech-item:last-child { border-right:0; }
.tech-icon { font-size:1.4rem; margin-bottom:6px; display:block; }
.tech-name { font-size:.82rem; font-weight:700; color:var(--accent); display:block; margin-bottom:3px; }
.tech-stat { font-size:.72rem; color:var(--muted); display:block; margin-bottom:3px; }
.tech-desc { font-size:.71rem; color:var(--muted); line-height:1.4; display:block; }

/* AEC-Q200 badge on product cards */
.product-card { position:relative; }
.aec-badge { position:absolute; top:10px; right:10px; font-size:.65rem; font-weight:700; padding:3px 8px; border-radius:999px; letter-spacing:.03em; text-transform:uppercase; z-index:1; }
.aec-yes  { background:#f0fdf4; color:#16a34a; border:1px solid #bbf7d0; }
.aec-partial { background:#fffbeb; color:#d97706; border:1px solid #fde68a; }
.aec-no   { background:#f9fafb; color:#9ca3af; border:1px solid #e5e7eb; }

/* Best-for callout */
.best-for { margin-top:10px; padding:8px 10px; background:#f8fafc; border-left:3px solid var(--accent); border-radius:0 6px 6px 0; font-size:.75rem; color:#374151; line-height:1.4; }
.best-for strong { color:var(--accent); display:block; font-size:.68rem; text-transform:uppercase; letter-spacing:.04em; margin-bottom:2px; }

/* Key spec pills */
.key-spec { display:inline-block; margin:6px 4px 0 0; background:#eff6ff; color:#1e40af; border-radius:4px; padding:2px 7px; font-size:.7rem; font-weight:600; }

/* Bottom page CTA */
.page-cta { background:#1e3a8a; padding:48px 0; margin-top:0; }
.page-cta-grid { display:grid; gap:16px; }
@media(min-width:640px){ .page-cta-grid { grid-template-columns:repeat(3,1fr); } }
.cta-card { background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.15); border-radius:14px; padding:22px 18px; text-align:center; }
.cta-card-icon { font-size:1.8rem; margin-bottom:10px; display:block; }
.cta-card h3 { color:#fff; font-size:.93rem; margin:0 0 6px; }
.cta-card p { color:rgba(255,255,255,.7); font-size:.78rem; margin:0 0 14px; line-height:1.5; }

/* =========================================================================
   BOM Upload card (homepage) — posts to the VTM Group quotation system.
   Self-contained dark card so it reads correctly on the light main section.
   ========================================================================= */
.bom-quote-card{
  background:linear-gradient(160deg,#1e3a8a,#142960);
  border:1px solid #1e3a8a;border-radius:16px;padding:28px 26px;
  color:#eaf1fb;box-shadow:0 10px 30px rgba(20,41,96,.25);
}
.bom-quote-card .bom-eyebrow{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#fbbf24;margin-bottom:8px}
.bom-quote-card .bom-title{margin:0 0 6px;font-size:clamp(1.3rem,2.4vw,1.7rem);color:#fff;line-height:1.2}
.bom-quote-card .bom-sub{margin:0 0 22px;color:#cfe0f3;font-size:.92rem;max-width:60ch}

.bom-form-section{margin-bottom:22px}
.bom-form-section:last-of-type{margin-bottom:14px}
.bom-form-label{display:flex;align-items:center;gap:8px;font-weight:700;color:#fff;margin-bottom:6px;font-size:.95rem}
.bom-step{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:#fbbf24;color:#142960;font-size:.78rem;font-weight:800}
.bom-form-help{font-size:.82rem;color:#cfe0f3;margin:0 0 10px;line-height:1.55}
.bom-template-link{color:#fbbf24;font-weight:600;text-decoration:none}
.bom-template-link:hover{color:#fde68a;text-decoration:underline}

.upload-area{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.upload-area input[type=file]{padding:10px;border:1px dashed rgba(255,255,255,.35);border-radius:10px;background:rgba(255,255,255,.08);color:#eaf1fb;flex:1;min-width:220px;font-family:inherit;font-size:.9rem}
.upload-area input[type=file]::file-selector-button{background:rgba(255,255,255,.15);color:#fff;border:0;border-radius:8px;padding:6px 12px;margin-right:10px;font-weight:600;cursor:pointer}
.upload-area input[type=file]::file-selector-button:hover{background:rgba(255,255,255,.25)}

.bom-info{color:#cfe0f3;font-size:.85rem;margin-top:8px}
.bom-preview{overflow:auto;border:1px solid rgba(255,255,255,.18);border-radius:10px;background:rgba(255,255,255,.04);max-height:240px;margin-top:8px}
.bom-preview table{width:100%;border-collapse:collapse}
.bom-preview th,.bom-preview td{padding:8px 10px;border-bottom:1px solid rgba(255,255,255,.08);font-size:.82rem;color:#eaf1fb;text-align:left}
.bom-preview th{background:rgba(255,255,255,.06);color:#fff;font-weight:700;position:sticky;top:0}

.bom-mapping{margin-top:14px;padding:16px;border:1px solid rgba(255,255,255,.16);border-radius:12px;background:rgba(255,255,255,.04)}
.bom-mapping-title{font-weight:700;color:#fff;margin-bottom:4px}
.bom-mapping-help{font-size:.8rem;color:#cfe0f3;margin:0 0 12px;line-height:1.5}
.bom-mapping-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}
.bom-map-field{display:flex;flex-direction:column;gap:4px;font-size:.8rem;color:#cfe0f3}
.bom-map-field>span{font-weight:600}
.bom-map-field .req{color:#ff9c9c}
.bom-map-field select{padding:9px 10px;border:1px solid rgba(255,255,255,.25);border-radius:8px;background:rgba(255,255,255,.95);color:#0f172a;font-family:inherit;font-size:.86rem}
.bom-map-field select:focus{outline:none;border-color:#93c5fd;box-shadow:0 0 0 3px rgba(147,197,253,.3)}
.bom-mapping-warn{margin-top:10px;font-size:.8rem;color:#ffd9d9;background:rgba(220,38,38,.18);border:1px solid rgba(248,113,113,.4);border-radius:8px;padding:8px 10px}

.bom-analysis{margin-top:14px}
.bom-analysis-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:10px}
.ba-stat{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:10px;padding:12px;text-align:center}
.ba-stat-num{font-size:1.5rem;font-weight:800;color:#fff;line-height:1}
.ba-stat-label{font-size:.72rem;color:#cfe0f3;margin-top:4px}
.ba-stat.in .ba-stat-num{color:#6cf2a3}.ba-stat.on .ba-stat-num{color:#ffcf6c}.ba-stat.quote .ba-stat-num{color:#ff9fae}
.ba-stat.total .ba-stat-sub{color:#9bc7e1;font-size:.7rem;margin-top:4px}
.bom-analysis-details{margin-top:10px;font-size:.85rem;color:#cfe0f3}
.bom-analysis-details summary{cursor:pointer;color:#cfe0f3}
.bom-analysis-table-wrap{overflow:auto;max-height:260px;margin-top:8px;border:1px solid rgba(255,255,255,.14);border-radius:8px}
.bom-analysis-table{width:100%;border-collapse:collapse}
.bom-analysis-table th,.bom-analysis-table td{padding:7px 9px;border-bottom:1px solid rgba(255,255,255,.08);font-size:.8rem;color:#eaf1fb;text-align:left}
.bom-analysis-table th{background:rgba(255,255,255,.06);color:#fff;font-weight:700}
.bom-analysis-table td.mono{font-family:ui-monospace,Menlo,Consolas,monospace}
.bom-analysis-table td.num{text-align:right;font-variant-numeric:tabular-nums}
.ba-status{display:inline-block;padding:2px 8px;border-radius:999px;font-size:.72rem;font-weight:600}
.ba-status.in{background:rgba(108,242,163,.2);color:#d8fae5}.ba-status.on{background:rgba(255,207,108,.2);color:#ffe8b5}.ba-status.quote{background:rgba(255,159,174,.2);color:#ffd4dc}
.bom-analysis-help{margin:8px 0 0;font-size:.76rem;color:#9bc7e1}

.bom-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.bom-field{display:flex;flex-direction:column;gap:4px}
.bom-field-full{grid-column:1/-1}
.bom-field label{font-size:.82rem;color:#cfe0f3;font-weight:600}
.bom-field .req{color:#ff9c9c}
.bom-field input,.bom-field textarea{padding:10px 12px;border:1px solid rgba(255,255,255,.25);border-radius:8px;background:rgba(255,255,255,.95);color:#0f172a;font-family:inherit;font-size:.9rem;width:100%}
.bom-field input::placeholder,.bom-field textarea::placeholder{color:#94a3b8}
.bom-field input:focus,.bom-field textarea:focus{outline:none;border-color:#93c5fd;box-shadow:0 0 0 3px rgba(147,197,253,.3)}
.bom-field textarea{resize:vertical;min-height:70px}

.bom-honeypot{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}

.bom-form-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.bom-form-actions .btn[disabled]{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none}

.bom-status{display:none;margin-top:14px;padding:12px 14px;border-radius:10px;font-size:.88rem;line-height:1.5}
.bom-status.show{display:block}
.bom-status.info{background:rgba(147,197,253,.15);border:1px solid rgba(147,197,253,.4);color:#dbeafe}
.bom-status.success{background:rgba(108,242,163,.15);border:1px solid rgba(108,242,163,.4);color:#dcfce7}
.bom-status.warn{background:rgba(255,207,108,.15);border:1px solid rgba(255,207,108,.4);color:#fef3c7}
.bom-status.error{background:rgba(248,113,113,.15);border:1px solid rgba(248,113,113,.45);color:#fee2e2}
.bom-status a{color:#fbbf24;text-decoration:underline}

@media(max-width:600px){.bom-quote-card{padding:22px 16px}}
