/* =========================================
   SERI ENGINEERING AG — DESIGN SYSTEM v2
   ========================================= */
@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=DM+Sans:wght@300;400;500&family=DM+Mono:wght@400;500&display=swap');

:root {
  --coal:   #09090b;
  --ink:    #111115;
  --iron:   #1a1a20;
  --steel:  #242430;
  --ash:    #363648;
  --mist:   #7a8098;
  --fog:    #b8bdd0;
  --white:  #ffffff;
  --amber:  #e09a18;
  --amber2: #f0b030;
  --adim:   rgba(224,154,24,.12);
  --green:  #22c55e;
  --max:    1400px;
  --pad:    64px;
  --hh:     72px; /* header height */
  --fd: 'Syne', sans-serif;
  --fb: 'DM Sans', sans-serif;
  --fm: 'DM Mono', monospace;
  --ease: 0.22s ease;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; }
body {
  background: var(--coal);
  color: var(--fog);
  font-family: var(--fb);
  font-weight: 300;
  line-height: 1.7;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { cursor: pointer; font-family: inherit; border: none; background: none; }

/* ─── LAYOUT ─── */
.container { max-width: var(--max); margin: 0 auto; padding: 0 var(--pad); }
.section { padding: 96px 0; }
.section--dark  { background: var(--ink); }
.section--iron  { background: var(--iron); }

/* ─── TYPE ─── */
.eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--fm); font-size: 10px;
  letter-spacing: 2.5px; text-transform: uppercase; color: var(--amber);
  margin-bottom: 16px;
}
.eyebrow::before { content: ''; width: 24px; height: 1px; background: var(--amber); flex-shrink: 0; }
.section-title {
  font-family: var(--fd); font-size: clamp(30px, 3.5vw, 52px);
  font-weight: 800; color: var(--white); letter-spacing: -1.5px; line-height: 1.06; margin-bottom: 16px;
}
.section-sub { font-size: 15px; color: var(--mist); line-height: 1.85; max-width: 540px; }
.sep { width: 40px; height: 2px; background: var(--amber); margin: 18px 0 26px; }
.body-para { font-size: 15px; color: var(--mist); line-height: 1.85; margin-bottom: 18px; }

/* ─── BUTTONS ─── */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--fd); font-size: 12px; font-weight: 600;
  letter-spacing: 1.2px; text-transform: uppercase;
  padding: 13px 28px; transition: all var(--ease);
  border: 1px solid transparent; white-space: nowrap;
}
.btn--primary { background: var(--amber); color: var(--coal); border-color: var(--amber); }
.btn--primary:hover { background: transparent; color: var(--amber); }
.btn--ghost { background: transparent; color: var(--fog); border-color: var(--ash); }
.btn--ghost:hover { border-color: var(--fog); color: var(--white); }
.btn--dark { background: var(--coal); color: var(--white); border-color: var(--coal); }
.btn--dark:hover { background: transparent; color: var(--coal); }
.btn--outline-amber { background: transparent; color: var(--coal); border: 1px solid rgba(9,9,11,.35); }
.btn--outline-amber:hover { background: rgba(9,9,11,.08); }

/* ─── STATS ─── */
.stats-row {
  display: grid; grid-template-columns: repeat(4,1fr);
  gap: 1px; background: rgba(255,255,255,.05);
}
.stat-block { background: var(--ink); padding: 28px 22px; }
.stat-block__num { font-family: var(--fd); font-size: 34px; font-weight: 800; color: var(--white); letter-spacing: -1.5px; line-height: 1; margin-bottom: 6px; }
.stat-block__num em { color: var(--amber); font-style: normal; }
.stat-block__label { font-family: var(--fm); font-size: 10px; letter-spacing: 1px; text-transform: uppercase; color: var(--ash); }
.tag { display: inline-block; font-family: var(--fm); font-size: 9px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--amber); background: var(--adim); padding: 4px 9px; margin-bottom: 10px; }

/* ========================================
   HEADER & MEGA MENU
   ======================================== */
.header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 500;
  height: var(--hh);
  background: rgba(9,9,11,.92);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.header__row {
  max-width: var(--max); margin: 0 auto; padding: 0 var(--pad);
  height: var(--hh); display: flex; align-items: center; gap: 32px;
}

/* Brand */
.brand { display: flex; align-items: center; gap: 13px; flex-shrink: 0; }
.brand__logo {
  width: 38px; height: 38px; background: var(--amber);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--fd); font-weight: 800; font-size: 18px; color: var(--coal);
}
.brand__name { font-family: var(--fd); font-weight: 700; font-size: 15px; color: var(--white); line-height: 1; }
.brand__tag  { font-family: var(--fm); font-size: 9px; color: var(--amber); letter-spacing: 1.5px; text-transform: uppercase; }

/* Desktop nav */
.nav--desktop { display: flex; align-items: center; gap: 0; list-style: none; margin-left: auto; }
.nav--desktop > li { position: relative; }
.dd { position: relative; }
.nav--desktop > li > a,
.nav--desktop > li > button.dd__btn {
  display: flex; align-items: center; gap: 4px;
  font-size: 13px; color: var(--mist); padding: 8px 13px;
  transition: color var(--ease); background: none; border: none;
  cursor: pointer; font-family: var(--fb); font-weight: 400;
  white-space: nowrap;
}
.nav--desktop > li > a:hover,
.nav--desktop > li > button.dd__btn:hover { color: var(--white); }
.nav--desktop > li > a.active { color: var(--white); }
.chev { font-size: 10px; transition: transform .2s; }
.dd--mega:hover .chev,
.dd--mega.is-open .chev { transform: rotate(180deg); }

/* Mega dropdown */
.dd__menu--mega {
  display: none;
  position: absolute; top: calc(var(--hh) - 2px); left: 0;
  min-width: 680px;
  background: rgba(13,13,18,.98);
  border: 1px solid rgba(255,255,255,.08);
  border-top: 2px solid var(--amber);
  box-shadow: 0 32px 64px rgba(0,0,0,.5);
  padding: 28px;
}
.dd--mega:hover .dd__menu--mega,
.dd--mega.is-open .dd__menu--mega { display: block; }
.mega { display: grid; grid-template-columns: repeat(3,1fr) 200px; gap: 24px; }
.mega__col { display: flex; flex-direction: column; gap: 4px; }
.mega__eyebrow { font-family: var(--fm); font-size: 9px; letter-spacing: 2px; text-transform: uppercase; color: var(--amber); margin-bottom: 10px; padding-bottom: 8px; border-bottom: 1px solid rgba(255,255,255,.06); }
.mega__link { display: block; padding: 8px 10px; transition: background var(--ease); border-radius: 2px; }
.mega__link:hover { background: rgba(255,255,255,.04); }
.mega__link strong { display: block; font-size: 13px; font-weight: 600; color: var(--white); margin-bottom: 2px; font-family: var(--fd); }
.mega__link small { display: block; font-size: 11px; color: var(--mist); line-height: 1.5; }
.mega__card {
  background: var(--iron); border: 1px solid rgba(255,255,255,.06);
  padding: 20px; display: flex; flex-direction: column; gap: 10px;
}
.mega__card h4 { font-family: var(--fd); font-size: 15px; font-weight: 700; color: var(--white); }
.mega__card p { font-size: 12px; color: var(--mist); line-height: 1.65; }
.mega__tags { display: flex; flex-wrap: wrap; gap: 5px; }
.mega__tags span { font-family: var(--fm); font-size: 9px; letter-spacing: 1px; color: var(--ash); border: 1px solid rgba(255,255,255,.07); padding: 3px 8px; }

/* Simple dropdown (global/lang) */
.dd__menu--simple {
  display: none;
  position: absolute; top: calc(var(--hh) - 2px); right: 0;
  min-width: 200px;
  background: rgba(13,13,18,.98);
  border: 1px solid rgba(255,255,255,.08);
  border-top: 2px solid var(--amber);
  padding: 10px;
  box-shadow: 0 20px 40px rgba(0,0,0,.4);
}
.dd--simple:hover .dd__menu--simple,
.dd--simple.is-open .dd__menu--simple { display: block; }
.dd__menu--simple a { display: block; padding: 9px 12px; font-size: 13px; color: var(--mist); transition: color var(--ease); }
.dd__menu--simple a:hover { color: var(--white); background: rgba(255,255,255,.04); }
.dd__menu--simple .dd__divider { height: 1px; background: rgba(255,255,255,.06); margin: 6px 0; }
.dd__menu--simple .dd__label { font-family: var(--fm); font-size: 9px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--ash); padding: 4px 12px; }

/* Language picker */
.lang-pick { position: relative; }
.lang-pick__btn {
  font-family: var(--fm); font-size: 10px; letter-spacing: 1px;
  color: var(--mist); background: none; border: 1px solid var(--ash);
  padding: 6px 12px; transition: all var(--ease); cursor: pointer;
  display: flex; align-items: center; gap: 5px;
}
.lang-pick__btn:hover { color: var(--white); border-color: var(--fog); }
.lang-pick__menu {
  display: none;
  position: absolute; top: calc(100% + 4px); right: 0;
  background: rgba(13,13,18,.98); border: 1px solid rgba(255,255,255,.08);
  border-top: 2px solid var(--amber); min-width: 120px; padding: 8px;
  box-shadow: 0 20px 40px rgba(0,0,0,.4);
}
.lang-pick.is-open .lang-pick__menu { display: block; }
.lang-pick__menu a {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 12px; font-size: 13px; color: var(--mist); transition: color var(--ease);
  font-family: var(--fm); letter-spacing: 1px;
}
.lang-pick__menu a:hover { color: var(--white); background: rgba(255,255,255,.04); }
.lang-pick__menu a.active { color: var(--amber); }
.lang-pick__menu a .lang-name { font-family: var(--fb); font-size: 12px; color: var(--ash); }

/* Header end */
.header__end { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }

/* Burger */
.burger {
  display: none; flex-direction: column; align-items: center; justify-content: center;
  gap: 5px; width: 44px; height: 44px;
  border: 1px solid var(--ash); background: none; cursor: pointer;
}
.burger span { display: block; width: 18px; height: 1.5px; background: var(--white); transition: all .2s; }
.burger.is-open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.burger.is-open span:nth-child(2) { opacity: 0; }
.burger.is-open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* Mobile drawer */
.drawer {
  position: fixed; inset: 0; z-index: 400;
  display: none; pointer-events: none;
}
.drawer.is-open { display: block; pointer-events: all; }
.drawer__backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.6); }
.drawer__panel {
  position: absolute; right: 0; top: 0; bottom: 0;
  width: min(380px, 92vw);
  background: rgba(13,13,18,.99); border-left: 1px solid rgba(255,255,255,.08);
  padding: 0; display: flex; flex-direction: column; overflow-y: auto;
}
.drawer__head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 20px 24px; border-bottom: 1px solid rgba(255,255,255,.06);
  position: sticky; top: 0; background: rgba(13,13,18,.99); z-index: 1;
}
.drawer__head-brand { font-family: var(--fd); font-size: 14px; font-weight: 700; color: var(--white); }
.drawer__close-btn {
  width: 36px; height: 36px; border: 1px solid var(--ash);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; color: var(--fog); cursor: pointer; background: none;
}
.drawer__nav { padding: 16px 24px; flex-grow: 1; }
.drawer__item { display: block; padding: 13px 0; border-bottom: 1px solid rgba(255,255,255,.06); font-size: 15px; color: var(--fog); font-weight: 400; transition: color var(--ease); }
.drawer__item:hover { color: var(--white); }
.drawer__group { margin-bottom: 4px; }
.drawer__group-title {
  display: flex; justify-content: space-between; align-items: center;
  padding: 13px 0; border-bottom: 1px solid rgba(255,255,255,.06);
  font-size: 15px; color: var(--fog); cursor: pointer; background: none;
  font-family: var(--fb); width: 100%; text-align: left;
}
.drawer__group-title .chev { color: var(--amber); }
.drawer__sub { display: none; padding: 8px 0 8px 16px; }
.drawer__sub.is-open { display: block; }
.drawer__sub a { display: block; padding: 8px 0; font-size: 13px; color: var(--mist); transition: color var(--ease); border-bottom: 1px solid rgba(255,255,255,.04); }
.drawer__sub a:hover { color: var(--white); }
.drawer__foot { padding: 20px 24px; border-top: 1px solid rgba(255,255,255,.06); display: flex; gap: 10px; }
.drawer__foot .btn { flex: 1; justify-content: center; }
.drawer__lang { padding: 12px 24px; border-top: 1px solid rgba(255,255,255,.06); display: flex; gap: 8px; }
.drawer__lang a { font-family: var(--fm); font-size: 11px; letter-spacing: 1px; color: var(--ash); padding: 6px 12px; border: 1px solid rgba(255,255,255,.07); transition: all var(--ease); }
.drawer__lang a:hover, .drawer__lang a.active { color: var(--amber); border-color: var(--amber); }

/* ─── FOOTER ─── */
.footer { background: var(--ink); border-top: 1px solid rgba(255,255,255,.05); }
.footer__grid { padding: 80px 0 56px; display: grid; grid-template-columns: 2fr 1fr 1fr 1.4fr; gap: 56px; }
.footer__logo { width: 34px; height: 34px; background: var(--amber); display: flex; align-items: center; justify-content: center; font-family: var(--fd); font-weight: 800; font-size: 17px; color: var(--coal); }
.footer__brand-row { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.footer__brand-name { font-family: var(--fd); font-weight: 700; font-size: 14px; color: var(--white); }
.footer__brand-tag  { font-family: var(--fm); font-size: 9px; color: var(--amber); letter-spacing: 1.5px; text-transform: uppercase; }
.footer__desc { font-size: 13px; color: var(--ash); line-height: 1.8; max-width: 300px; margin-bottom: 20px; }
.footer__chips { display: flex; flex-wrap: wrap; gap: 6px; }
.footer__chip { font-family: var(--fm); font-size: 9px; letter-spacing: 1px; text-transform: uppercase; color: var(--ash); border: 1px solid rgba(255,255,255,.06); padding: 4px 9px; }
.footer__col-title { font-family: var(--fd); font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--white); margin-bottom: 18px; }
.footer__links { display: flex; flex-direction: column; gap: 10px; }
.footer__links a { font-size: 13px; color: var(--ash); transition: color var(--ease); }
.footer__links a:hover { color: var(--white); }
.footer__office-city { font-family: var(--fd); font-size: 13px; font-weight: 600; color: var(--white); margin-bottom: 3px; }
.footer__office-addr { font-size: 12px; color: var(--ash); line-height: 1.65; }
.footer__offices { display: flex; flex-direction: column; gap: 14px; }
.footer__bottom { padding: 20px 0; border-top: 1px solid rgba(255,255,255,.05); display: flex; justify-content: space-between; align-items: center; }
.footer__copy { font-family: var(--fm); font-size: 11px; color: var(--ash); }
.footer__legal { display: flex; gap: 24px; }
.footer__legal a { font-family: var(--fm); font-size: 11px; color: var(--ash); transition: color var(--ease); }
.footer__legal a:hover { color: var(--amber); }

/* ─── INNER HERO ─── */
.inner-hero {
  padding-top: var(--hh); position: relative; overflow: hidden;
  min-height: 60vh; display: flex; align-items: flex-end;
}
.inner-hero__bg { position: absolute; inset: 0; }
.inner-hero__bg img { width: 100%; height: 100%; object-fit: cover; }
.inner-hero__overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(9,9,11,.96) 0%, rgba(9,9,11,.5) 60%, rgba(9,9,11,.25) 100%); }
.inner-hero__grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(224,154,24,.05) 1px,transparent 1px), linear-gradient(90deg,rgba(224,154,24,.05) 1px,transparent 1px); background-size: 60px 60px; }
.inner-hero__inner { position: relative; z-index: 2; padding: 60px 0 72px; max-width: 800px; }
.inner-hero__title { font-family: var(--fd); font-size: clamp(36px,5vw,70px); font-weight: 800; color: var(--white); letter-spacing: -2.5px; line-height: 1.0; margin-bottom: 18px; }
.inner-hero__desc { font-size: 15px; color: var(--mist); line-height: 1.85; max-width: 580px; margin-bottom: 30px; }
.inner-hero__actions { display: flex; gap: 12px; flex-wrap: wrap; }

/* ─── INNER CONTENT ─── */
.content-split { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: start; }
.photo-side { overflow: hidden; }
.photo-side img { width: 100%; height: 440px; object-fit: cover; }
.scope-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: rgba(255,255,255,.05); margin-top: 44px; }
.scope-item { background: var(--coal); padding: 18px 22px; display: flex; align-items: flex-start; gap: 12px; font-size: 13px; color: var(--fog); line-height: 1.6; transition: background var(--ease); }
.scope-item:hover { background: var(--iron); }
.scope-dot { color: var(--amber); font-size: 8px; flex-shrink: 0; margin-top: 4px; }
.feat-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: rgba(255,255,255,.05); margin-top: 44px; }
.feat-card { background: var(--iron); padding: 34px 26px; transition: background var(--ease); position: relative; overflow: hidden; }
.feat-card::after { content: ''; position: absolute; bottom: 0; left: 0; width: 0; height: 2px; background: var(--amber); transition: width .45s; }
.feat-card:hover { background: var(--steel); }
.feat-card:hover::after { width: 100%; }
.feat-card__icon { font-size: 30px; margin-bottom: 14px; display: block; }
.feat-card__title { font-family: var(--fd); font-size: 15px; font-weight: 700; color: var(--white); letter-spacing: -.2px; margin-bottom: 8px; line-height: 1.25; }
.feat-card__desc { font-size: 13px; color: var(--mist); line-height: 1.7; }
.photo-banner { position: relative; height: 340px; overflow: hidden; }
.photo-banner img { width: 100%; height: 100%; object-fit: cover; }
.photo-banner__overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(9,9,11,.88) 0%, rgba(9,9,11,.2) 100%); }
.photo-banner__text { position: absolute; bottom: 44px; left: 0; padding: 0 var(--pad); }
.photo-banner__title { font-family: var(--fd); font-size: clamp(26px,3vw,46px); font-weight: 800; color: var(--white); letter-spacing: -1.5px; margin-top: 8px; }
.cta-amber { background: var(--amber); position: relative; overflow: hidden; }
.cta-amber::before { content: ''; position: absolute; inset: 0; background-image: linear-gradient(rgba(9,9,11,.07) 1px,transparent 1px), linear-gradient(90deg,rgba(9,9,11,.07) 1px,transparent 1px); background-size: 44px 44px; }
.cta-amber__inner { padding: 64px 0; display: flex; justify-content: space-between; align-items: center; gap: 48px; position: relative; z-index: 1; }
.cta-amber__title { font-family: var(--fd); font-size: clamp(20px,2.5vw,34px); font-weight: 800; color: var(--coal); letter-spacing: -.8px; max-width: 560px; }
.cta-amber__actions { display: flex; gap: 12px; flex-shrink: 0; }

/* ─── TRUST MARQUEE ─── */
.trust { background: var(--iron); border-top: 1px solid rgba(255,255,255,.05); border-bottom: 1px solid rgba(255,255,255,.05); padding: 18px 0; overflow: hidden; }
.trust__track { display: flex; width: max-content; animation: marquee 30s linear infinite; }
.trust__item { display: flex; align-items: center; gap: 10px; padding: 0 44px; border-right: 1px solid rgba(255,255,255,.06); white-space: nowrap; }
.trust__item::before { content: '◆'; color: var(--amber); font-size: 7px; }
.trust__item span { font-family: var(--fm); font-size: 10px; letter-spacing: 1.8px; text-transform: uppercase; color: var(--ash); }

/* ─── PHOTO CARD ─── */
.photo-card { position: relative; overflow: hidden; background: var(--iron); }
.photo-card img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s; }
.photo-card:hover img { transform: scale(1.04); }
.photo-card__overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(9,9,11,.88) 0%, transparent 55%); }
.photo-card__body { position: absolute; bottom: 0; left: 0; right: 0; padding: 24px; }
.photo-card__title { font-family: var(--fd); font-size: 17px; font-weight: 700; color: var(--white); letter-spacing: -.3px; }
.photo-card__desc { font-size: 12px; color: var(--fog); line-height: 1.55; margin-top: 4px; }

/* ─── ANIMATIONS ─── */
@keyframes fadeUp   { from { opacity:0; transform:translateY(24px); } to { opacity:1; transform:none; } }
@keyframes slideIn  { from { opacity:0; transform:translateX(28px); } to { opacity:1; transform:none; } }
@keyframes marquee  { to { transform: translateX(-50%); } }
@keyframes pulse    { 0%,100% { opacity:1; transform:scale(1); } 50% { opacity:.3; transform:scale(.5); } }
.anim-up  { animation: fadeUp .7s ease both; }
.anim-up1 { animation: fadeUp .7s .1s ease both; }
.anim-up2 { animation: fadeUp .7s .2s ease both; }
.anim-up3 { animation: fadeUp .7s .35s ease both; }
.anim-up4 { animation: fadeUp .7s .5s ease both; }

/* ─── RESPONSIVE ─── */
@media (max-width: 1100px) {
  :root { --pad: 36px; }
  .nav--desktop { display: none; }
  .burger { display: flex; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .stats-row { grid-template-columns: repeat(2,1fr); }
  .content-split, .feat-grid { grid-template-columns: 1fr; }
  .scope-grid { grid-template-columns: 1fr; }
  .cta-amber__inner { flex-direction: column; gap: 24px; }
  .dd__menu--mega { min-width: 100vw; left: calc(-1 * var(--pad)); }
}
@media (max-width: 700px) {
  :root { --pad: 20px; }
  .section { padding: 60px 0; }
  .footer__grid { grid-template-columns: 1fr; }
  .stats-row { grid-template-columns: 1fr; }
  .inner-hero { min-height: 50vh; }
}


/* menu stability patch */
.dd--mega::after,
.dd--simple::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:100%;
  height:96px;
}
.dd__menu--mega,
.dd__menu--simple,
.lang-pick__menu{ z-index: 1200; }



/* Global language system quote page styles */
.rfq-hero-clean{position:relative;overflow:hidden;background:#0a0f1a;min-height:580px;padding:130px 0 60px}
.rfq-hero-clean__bg{position:absolute;inset:0;background:radial-gradient(circle at 82% 18%, rgba(255,157,46,.18), transparent 22%),radial-gradient(circle at 74% 38%, rgba(255,255,255,.06), transparent 18%),linear-gradient(180deg, #111827 0%, #0a0f1a 100%)}
.rfq-hero-clean__overlay{position:absolute;inset:0;background:linear-gradient(90deg, rgba(10,15,26,.12) 0%, rgba(10,15,26,.04) 100%)}
.rfq-hero-clean__inner{position:relative;z-index:2;max-width:1380px;margin:0 auto;padding:0 28px;display:grid;grid-template-columns:1.08fr .92fr;gap:28px;align-items:center}
.rfq-eyebrow{display:inline-block;margin-bottom:16px;padding:8px 12px;border-radius:999px;background:rgba(255,157,46,.12);border:1px solid rgba(255,157,46,.22);color:#ffb45b;font-size:12px;font-weight:700;letter-spacing:.14em}
.rfq-title{margin:0 0 18px;max-width:820px;font-family:Inter,Arial,Helvetica,sans-serif;font-size:clamp(34px,4vw,58px);line-height:1.08;letter-spacing:-0.035em;font-weight:700;color:#fff;text-wrap:balance}
.rfq-subtitle{max-width:760px;margin:0 0 28px;font-size:17px;line-height:1.78;color:rgba(255,255,255,.84)}
.rfq-meta{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;max-width:900px}
.rfq-meta-card{padding:18px;border-radius:18px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);backdrop-filter:blur(6px)}
.rfq-meta-card strong{display:block;margin-bottom:8px;font-size:16px;color:#fff}.rfq-meta-card span{display:block;font-size:14px;line-height:1.65;color:rgba(255,255,255,.72)}
.rfq-info-panel{padding:26px;border-radius:24px;background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.04));border:1px solid rgba(255,255,255,.08);box-shadow:0 22px 60px rgba(0,0,0,.18)}
.rfq-panel-label{display:inline-block;margin-bottom:14px;color:#ffb45b;font-size:12px;font-weight:700;letter-spacing:.12em}.rfq-info-panel h3{margin:0 0 18px;font-size:28px;line-height:1.15;color:#fff}
.rfq-steps{display:grid;gap:14px}.rfq-step{display:grid;grid-template-columns:54px 1fr;gap:14px;align-items:start;padding:16px;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06)}
.rfq-step strong{display:flex;align-items:center;justify-content:center;width:54px;height:54px;border-radius:14px;background:#ff9d2e;color:#111;font-size:18px;font-weight:800}.rfq-step p{margin:0;font-size:15px;line-height:1.7;color:rgba(255,255,255,.8)}
.rfq-direct-contact{margin-top:18px;padding-top:18px;border-top:1px solid rgba(255,255,255,.08)}.rfq-direct-contact span{display:block;margin-bottom:8px;font-size:12px;letter-spacing:.08em;color:#ffb45b;text-transform:uppercase}.rfq-direct-contact a{color:#fff;text-decoration:none;font-weight:600}
.rfq-form-shell{position:relative;margin-top:-30px;z-index:3;padding:0 0 72px;background:#0a0f1a}.rfq-form-shell__inner{max-width:1380px;margin:0 auto;padding:0 28px}
.rfq-form-card{background:#fff;color:#111827;border-radius:28px;box-shadow:0 24px 80px rgba(0,0,0,.16);overflow:hidden}.rfq-form-card__head{padding:30px 32px 18px;border-bottom:1px solid rgba(17,24,39,.08)}
.rfq-form-kicker{display:inline-block;margin-bottom:10px;color:#b86910;font-size:12px;font-weight:700;letter-spacing:.12em}.rfq-form-card__head h2{margin:0 0 10px;font-size:32px;line-height:1.14;font-weight:700;letter-spacing:-0.03em}.rfq-form-card__head p{max-width:860px;margin:0;color:#4b5563;font-size:16px;line-height:1.72}
.rfq-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;padding:28px 32px 32px}.rfq-field{display:flex;flex-direction:column}.rfq-field--full{grid-column:1 / -1}
.rfq-field label{margin-bottom:8px;font-size:13px;font-weight:600;color:#111827}.rfq-field input,.rfq-field select,.rfq-field textarea{width:100%;min-height:50px;padding:12px 14px;border:1px solid rgba(17,24,39,.14);border-radius:12px;background:#fff;font-size:15px;color:#111827;outline:none}
.rfq-field textarea{min-height:160px;resize:vertical}.rfq-checkbox-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 18px;padding:6px 0 2px}
.rfq-checkbox-grid label{display:flex;align-items:flex-start;gap:10px;font-size:14px;line-height:1.6;color:#374151}.rfq-checkbox-grid input[type="checkbox"]{margin-top:3px}
.rfq-submit-row{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between;gap:18px;padding-top:8px}.rfq-check{display:flex;align-items:flex-start;gap:10px;font-size:14px;line-height:1.6;color:#374151}.rfq-submit-btn{min-height:50px;padding:12px 22px;border:0;border-radius:12px;background:#ff9d2e;color:#111;font-size:15px;font-weight:700;cursor:pointer}
@media (max-width:1100px){.rfq-hero-clean__inner{grid-template-columns:1fr}.rfq-meta{grid-template-columns:1fr}}
@media (max-width:768px){.rfq-hero-clean{padding:110px 0 40px;min-height:auto}.rfq-hero-clean__inner,.rfq-form-shell__inner{padding:0 16px}.rfq-title{font-size:34px;line-height:1.12}.rfq-subtitle{font-size:15px;line-height:1.7}.rfq-form-card__head{padding:24px 20px 16px}.rfq-form-card__head h2{font-size:26px}.rfq-form-grid{grid-template-columns:1fr;padding:22px 20px 24px}.rfq-submit-row{flex-direction:column;align-items:stretch}.rfq-submit-btn{width:100%}.rfq-checkbox-grid{grid-template-columns:1fr}}


/* ===== RFQ CLEAN REDESIGN ===== */
.rfq-hero-clean{position:relative;overflow:hidden;background:#0a0f1a;min-height:580px;padding:130px 0 60px}
.rfq-hero-clean__bg{position:absolute;inset:0;background:radial-gradient(circle at 82% 18%, rgba(255,157,46,.18), transparent 22%),radial-gradient(circle at 74% 38%, rgba(255,255,255,.06), transparent 18%),linear-gradient(180deg, #111827 0%, #0a0f1a 100%)}
.rfq-hero-clean__overlay{position:absolute;inset:0;background:linear-gradient(90deg, rgba(10,15,26,.12) 0%, rgba(10,15,26,.04) 100%)}
.rfq-hero-clean__inner{position:relative;z-index:2;max-width:1380px;margin:0 auto;padding:0 28px;display:grid;grid-template-columns:1.08fr .92fr;gap:28px;align-items:center}
.rfq-eyebrow{display:inline-block;margin-bottom:16px;padding:8px 12px;border-radius:999px;background:rgba(255,157,46,.12);border:1px solid rgba(255,157,46,.22);color:#ffb45b;font-size:12px;font-weight:700;letter-spacing:.14em}
.rfq-title{margin:0 0 18px;max-width:820px;font-family:Inter,Arial,Helvetica,sans-serif;font-size:clamp(34px,4vw,58px);line-height:1.08;letter-spacing:-.035em;font-weight:700;color:#fff;text-wrap:balance}
.rfq-subtitle{max-width:760px;margin:0 0 28px;font-size:17px;line-height:1.78;color:rgba(255,255,255,.84)}
.rfq-meta{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;max-width:900px}
.rfq-meta-card{padding:18px;border-radius:18px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);backdrop-filter:blur(6px)}
.rfq-meta-card strong{display:block;margin-bottom:8px;font-size:16px;color:#fff}.rfq-meta-card span{display:block;font-size:14px;line-height:1.65;color:rgba(255,255,255,.72)}
.rfq-info-panel{padding:26px;border-radius:24px;background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.04));border:1px solid rgba(255,255,255,.08);box-shadow:0 22px 60px rgba(0,0,0,.18)}
.rfq-panel-label{display:inline-block;margin-bottom:14px;color:#ffb45b;font-size:12px;font-weight:700;letter-spacing:.12em}.rfq-info-panel h3{margin:0 0 18px;font-size:28px;line-height:1.15;color:#fff}
.rfq-steps{display:grid;gap:14px}.rfq-step{display:grid;grid-template-columns:54px 1fr;gap:14px;align-items:start;padding:16px;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06)}
.rfq-step strong{display:flex;align-items:center;justify-content:center;width:54px;height:54px;border-radius:14px;background:#ff9d2e;color:#111;font-size:18px;font-weight:800}.rfq-step p{margin:0;font-size:15px;line-height:1.7;color:rgba(255,255,255,.8)}
.rfq-direct-contact{margin-top:18px;padding-top:18px;border-top:1px solid rgba(255,255,255,.08)}.rfq-direct-contact span{display:block;margin-bottom:8px;font-size:12px;letter-spacing:.08em;color:#ffb45b;text-transform:uppercase}.rfq-direct-contact a{color:#fff;text-decoration:none;font-weight:600}
.rfq-form-shell{position:relative;margin-top:-30px;z-index:3;padding:0 0 72px;background:#0a0f1a}.rfq-form-shell__inner{max-width:1380px;margin:0 auto;padding:0 28px}
.rfq-form-card{background:#fff;color:#111827;border-radius:28px;box-shadow:0 24px 80px rgba(0,0,0,.16);overflow:hidden}
.rfq-form-card__head{padding:30px 32px 18px;border-bottom:1px solid rgba(17,24,39,.08)}.rfq-form-kicker{display:inline-block;margin-bottom:10px;color:#b86910;font-size:12px;font-weight:700;letter-spacing:.12em}
.rfq-form-card__head h2{margin:0 0 10px;font-size:32px;line-height:1.14;font-weight:700;letter-spacing:-.03em}.rfq-form-card__head p{max-width:860px;margin:0;color:#4b5563;font-size:16px;line-height:1.72}
.rfq-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;padding:28px 32px 32px}.rfq-field{display:flex;flex-direction:column}.rfq-field--full{grid-column:1 / -1}
.rfq-field label{margin-bottom:8px;font-size:13px;font-weight:600;color:#111827}.rfq-field input,.rfq-field select,.rfq-field textarea{width:100%;min-height:50px;padding:12px 14px;border:1px solid rgba(17,24,39,.14);border-radius:12px;background:#fff;font-size:15px;color:#111827;outline:none}
.rfq-field textarea{min-height:160px;resize:vertical}.rfq-checkbox-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 18px;padding:6px 0 2px}.rfq-checkbox-grid label{display:flex;align-items:flex-start;gap:10px;font-size:14px;line-height:1.6;color:#374151}.rfq-checkbox-grid input[type="checkbox"]{margin-top:3px}
.rfq-submit-row{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between;gap:18px;padding-top:8px}.rfq-check{display:flex;align-items:flex-start;gap:10px;font-size:14px;line-height:1.6;color:#374151}.rfq-submit-btn{min-height:50px;padding:12px 22px;border:0;border-radius:12px;background:#ff9d2e;color:#111;font-size:15px;font-weight:700;cursor:pointer}.rfq-submit-btn:hover{background:#ffac47}
@media (max-width:1100px){.rfq-hero-clean__inner{grid-template-columns:1fr}.rfq-meta{grid-template-columns:1fr}}
@media (max-width:768px){.rfq-hero-clean{padding:110px 0 40px;min-height:auto}.rfq-hero-clean__inner,.rfq-form-shell__inner{padding:0 16px}.rfq-title{font-size:34px;line-height:1.12}.rfq-subtitle{font-size:15px;line-height:1.7}.rfq-form-card__head{padding:24px 20px 16px}.rfq-form-card__head h2{font-size:26px}.rfq-form-grid{grid-template-columns:1fr;padding:22px 20px 24px}.rfq-submit-row{flex-direction:column;align-items:stretch}.rfq-submit-btn{width:100%}.rfq-checkbox-grid{grid-template-columns:1fr}}


/* Ultra RFQ polish */
.ultra-rfq{padding-top:150px;min-height:640px}
.ultra-rfq .rfq-title{max-width:840px;font-size:clamp(32px,3.7vw,54px);line-height:1.08;letter-spacing:-0.035em;font-weight:700;text-wrap:balance}
.ultra-rfq .rfq-subtitle{max-width:760px;font-size:17px;line-height:1.78;color:rgba(255,255,255,.84)}
.ultra-rfq .rfq-meta-card{min-height:126px}
.ultra-rfq .rfq-info-panel{background:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.04));box-shadow:0 28px 70px rgba(0,0,0,.18)}
.ultra-rfq-shell .rfq-form-card{border-radius:30px;box-shadow:0 26px 90px rgba(0,0,0,.18)}
.ultra-rfq-shell .rfq-form-card__head{padding:34px 36px 20px}
.ultra-rfq-shell .rfq-form-card__head h2{font-size:34px;line-height:1.12;letter-spacing:-0.03em}
.ultra-rfq-shell .rfq-form-card__head p{max-width:880px}
.ultra-rfq-shell .rfq-form-grid{padding:30px 36px 36px;gap:18px 20px}
.ultra-rfq-shell .rfq-field label{font-size:13px;font-weight:700;letter-spacing:.01em}
.ultra-rfq-shell .rfq-field input,
.ultra-rfq-shell .rfq-field select,
.ultra-rfq-shell .rfq-field textarea{min-height:52px;border-radius:14px;border:1px solid rgba(17,24,39,.14);padding:13px 15px;font-size:15px}
.ultra-rfq-shell .rfq-field textarea{min-height:170px}
.ultra-rfq-shell .rfq-checkbox-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 18px;padding-top:6px}
.ultra-rfq-shell .rfq-checkbox-grid label{display:flex;align-items:flex-start;gap:10px;font-size:14px;line-height:1.6;color:#374151}
.ultra-rfq-shell .rfq-checkbox-grid input[type='checkbox']{margin-top:3px}
.ultra-rfq-shell .rfq-submit-row{padding-top:10px;align-items:center}
.ultra-rfq-shell .rfq-submit-btn{min-height:52px;padding:12px 24px;border-radius:14px;font-size:15px;font-weight:800}
@media (max-width:1100px){
  .ultra-rfq{padding-top:130px}
}
@media (max-width:768px){
  .ultra-rfq{padding-top:118px;min-height:auto}
  .ultra-rfq .rfq-title{font-size:34px;line-height:1.12}
  .ultra-rfq .rfq-subtitle{font-size:15px;line-height:1.72}
  .ultra-rfq-shell .rfq-form-card__head{padding:24px 20px 16px}
  .ultra-rfq-shell .rfq-form-card__head h2{font-size:26px}
  .ultra-rfq-shell .rfq-form-grid{padding:22px 20px 24px;grid-template-columns:1fr}
  .ultra-rfq-shell .rfq-checkbox-grid{grid-template-columns:1fr}
}

/* ===== Enterprise content upgrade ===== */
.brand__logo,.footer__logo{display:none !important;}
.brand,.footer__brand-row{gap:.9rem !important;align-items:center;}
.brand__name{font-size:1.02rem;}
.brand__tag{margin-top:2px;}
.brand{grid-template-columns:none !important;}
.media-strip{padding:0 0 88px;background:#0d1420;}
.media-strip__grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px;}
.media-card{position:relative;min-height:260px;border-radius:22px;overflow:hidden;background:#101a29;border:1px solid rgba(255,255,255,.08);box-shadow:0 18px 50px rgba(0,0,0,.18)}
.media-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.62) saturate(.95);}
.media-card::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,12,20,.10),rgba(7,12,20,.72));}
.media-card::after{content:"";position:absolute;inset:-40% -20%;background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.16) 48%,transparent 54%);transform:translateX(-120%);animation:mediaSweep 5.6s ease-in-out infinite;}
@keyframes mediaSweep{0%,35%{transform:translateX(-120%)}65%,100%{transform:translateX(120%)}}
.media-card__body{position:relative;z-index:2;height:100%;padding:22px;display:flex;flex-direction:column;justify-content:flex-end;}
.media-card__kicker{display:inline-flex;align-items:center;gap:8px;margin-bottom:12px;padding:7px 12px;border-radius:999px;background:rgba(255,255,255,.08);font-size:12px;letter-spacing:.11em;text-transform:uppercase;color:#f8bc62;width:max-content}
.media-card__kicker::before{content:"";width:8px;height:8px;border-radius:50%;background:#ffb145;box-shadow:0 0 0 0 rgba(255,177,69,.7);animation:pulseDot 2s infinite;}
@keyframes pulseDot{0%{box-shadow:0 0 0 0 rgba(255,177,69,.7)}70%{box-shadow:0 0 0 10px rgba(255,177,69,0)}100%{box-shadow:0 0 0 0 rgba(255,177,69,0)}}
.media-card__title{font-size:26px;line-height:1.12;font-weight:700;margin:0 0 10px;color:#fff;}
.media-card__desc{margin:0;color:rgba(255,255,255,.86);line-height:1.65;font-size:15px;max-width:90%;}
.detail-hero{padding:88px 0 18px;background:#0d1420;}
.detail-shell{display:grid;grid-template-columns:1.08fr .92fr;gap:28px;align-items:center;}
.detail-shell__media img{width:100%;height:100%;min-height:340px;object-fit:cover;border-radius:24px;display:block;box-shadow:0 18px 50px rgba(0,0,0,.2)}
.detail-intro{padding:22px 0 10px;}
.detail-intro .eyebrow{margin-bottom:14px;}
.detail-intro h2{font-size:clamp(32px,3.2vw,52px);line-height:1.06;letter-spacing:-.03em;margin:0 0 16px;color:#fff;}
.detail-intro p{font-size:17px;line-height:1.82;color:rgba(255,255,255,.86);max-width:760px;margin:0 0 14px;}
.detail-section{padding:78px 0;}
.detail-section--dark{background:#0d1420;}
.detail-section--iron{background:#121b29;}
.detail-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:start;}
.detail-block{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:22px;padding:24px;}
.detail-block h3{margin:0 0 12px;font-size:24px;line-height:1.16;color:#fff;}
.detail-block p{margin:0 0 12px;color:rgba(255,255,255,.82);line-height:1.8;font-size:15px;}
.detail-list{display:grid;gap:12px;list-style:none;padding:0;margin:0;}
.detail-list li{display:grid;grid-template-columns:16px 1fr;gap:10px;align-items:start;color:rgba(255,255,255,.88);line-height:1.7;font-size:15px;}
.detail-list li::before{content:"◆";color:#ffb145;font-size:11px;padding-top:6px;}
.detail-cap-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;}
.detail-cap{padding:22px;border-radius:20px;background:#101a29;border:1px solid rgba(255,255,255,.08);}
.detail-cap h4{margin:0 0 8px;color:#fff;font-size:20px;line-height:1.2;}
.detail-cap p{margin:0;color:rgba(255,255,255,.78);font-size:15px;line-height:1.72;}
.detail-photo-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:18px;align-items:stretch;}
.detail-photo-grid img{width:100%;height:100%;min-height:220px;object-fit:cover;border-radius:20px;display:block;}
.detail-photo-grid__stack{display:grid;grid-template-rows:1fr 1fr;gap:18px;}
.detail-process{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;}
.detail-step{padding:22px;border-radius:20px;background:#101a29;border:1px solid rgba(255,255,255,.08);}
.detail-step strong{display:inline-flex;width:46px;height:46px;align-items:center;justify-content:center;border-radius:12px;background:#ffb145;color:#111;font-size:16px;font-weight:800;margin-bottom:14px;}
.detail-step h4{margin:0 0 8px;color:#fff;font-size:18px;}
.detail-step p{margin:0;color:rgba(255,255,255,.78);font-size:14px;line-height:1.7;}
.detail-cta{margin-top:28px;padding:24px;border-radius:22px;background:linear-gradient(135deg,#ffb145 0%,#f0a533 100%);display:flex;justify-content:space-between;gap:20px;align-items:center;}
.detail-cta__text{color:#111;max-width:760px;}
.detail-cta__text h3{margin:0 0 6px;font-size:30px;line-height:1.1;color:#111;}
.detail-cta__text p{margin:0;color:rgba(17,17,17,.84);line-height:1.7;}
.home-cap-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;}
.home-cap-card{padding:24px;border-radius:20px;background:#101a29;border:1px solid rgba(255,255,255,.08);}
.home-cap-card h3{margin:0 0 10px;color:#fff;font-size:22px;line-height:1.18;}
.home-cap-card p{margin:0;color:rgba(255,255,255,.8);font-size:15px;line-height:1.78;}
@media (max-width: 1024px){.media-strip__grid,.detail-cap-grid,.home-cap-grid,.detail-process{grid-template-columns:1fr 1fr;}.detail-shell,.detail-grid-2,.detail-photo-grid{grid-template-columns:1fr;}.detail-photo-grid__stack{grid-template-columns:1fr 1fr;grid-template-rows:none;}}
@media (max-width: 720px){.media-strip__grid,.detail-cap-grid,.home-cap-grid,.detail-process,.detail-photo-grid__stack{grid-template-columns:1fr;}.detail-cta{flex-direction:column;align-items:flex-start;}.detail-intro h2{font-size:34px;}.media-card{min-height:220px;}}


/* menu hover tolerance patch */
.dd--mega, .dd--simple, .lang-pick{ position: relative; }
.dd__menu--mega, .dd__menu--simple, .lang-pick__menu{ margin-top: 0; }
.dd--mega::after, .dd--simple::after, .lang-pick::after{ pointer-events:auto; }
@media (min-width: 1101px){
  .dd__menu--mega, .dd__menu--simple, .lang-pick__menu{ transform: translateY(0); }
}

/* stronger desktop hover stability */
@media (min-width: 1101px){
  .dd--mega::after, .dd--simple::after, .lang-pick::after{height:96px; left:-18px; right:-18px;}
  .dd__menu--mega, .dd__menu--simple, .lang-pick__menu{padding-top:6px;}
}


/* ===== FINAL MOBILE BURGER FIX ===== */
@media (max-width: 991px) {
  .nav--desktop { display: none !important; }
  .header__end .lang-pick,
  .header__end > .btn.btn--primary { display: none !important; }

  .header__row {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    min-height: 72px;
    padding: 0 12px !important;
    gap: 10px;
  }

  .brand { flex: 1 1 auto; min-width: 0; }
  .brand__logo { display: none !important; }
  .brand__name { font-size: 16px !important; line-height: 1.1 !important; }
  .brand__tag { font-size: 10px !important; letter-spacing: .12em !important; }

  .burger {
    display: inline-flex !important;
    width: 44px !important;
    height: 44px !important;
    align-items: center !important;
    justify-content: center !important;
    flex-direction: column !important;
    gap: 5px !important;
    border: 1px solid rgba(255,255,255,.15) !important;
    background: rgba(255,255,255,.05) !important;
    border-radius: 10px !important;
    cursor: pointer !important;
    padding: 0 !important;
    flex: 0 0 44px !important;
    z-index: 9999 !important;
  }

  .burger span {
    display: block !important;
    width: 20px !important;
    height: 2px !important;
    background: #fff !important;
    border-radius: 2px !important;
  }

  .drawer {
    z-index: 99999 !important;
    display: block !important;
    pointer-events: none;
  }
  .drawer.is-open { pointer-events: auto; }

  .drawer__backdrop {
    position: fixed !important;
    inset: 0 !important;
    background: rgba(0,0,0,.55) !important;
    opacity: 0;
    transition: opacity .25s ease;
  }
  .drawer__panel {
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: min(88vw, 340px) !important;
    transform: translateX(100%);
    transition: transform .28s ease;
    overflow-y: auto;
  }
  .drawer.is-open .drawer__backdrop { opacity: 1; }
  .drawer.is-open .drawer__panel { transform: translateX(0); }

  body.drawer-open { overflow: hidden !important; }
}
