/* ==========================================================
   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)}

/* 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;
}
/* 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:calc(100% + 8px);
  left:0;
  min-width:240px;
  background:#fff;
  border:1px solid rgba(0,0,0,.12);
  border-radius:10px;
  padding:8px;
  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;
}
