/* ============================================================
   MED TECH SWEDEN — shared stylesheet
   ============================================================ */

:root{
  --ink:        #1A2E50;
  --ink-soft:   #2A4470;
  --blue:       #025094;
  --blue-deep:  #1A2E50;
  --blue-faint: #EFEFEF;
  --gold:       #FF7C01;
  --gold-deep:  #CC6300;
  --gold-soft:  #FFEDB3;
  --paper:      #FFFFFF;
  --paper-2:    #EFEFEF;
  --bone:       #FFFFFF;
  --rule:       #CCCCCC;
  --rule-soft:  #EFEFEF;
  --red:        #D13628;
  --green:      #4ADE80;
  --shadow-1:   0 1px 0 rgba(26,46,80,.05), 0 8px 24px -16px rgba(26,46,80,.20);
  --shadow-2:   0 1px 0 rgba(26,46,80,.06), 0 30px 60px -30px rgba(26,46,80,.35);
  --maxw:       1440px;
  --gutter:     clamp(20px, 4vw, 56px);
  --display:    "Merriweather","sans-serif",serif;
  --sans:       "Manrope",-apple-system,BlinkMacSystemFont,sans-serif;
  --mono:       "JetBrains Mono",ui-monospace,monospace;
}

/* ---- reset/base ---- */
*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  font-family:var(--sans);
  font-size:16px; line-height:1.55;
  color:var(--ink); background:var(--paper);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; border:0; background:none; color:inherit; }
::selection{ background:var(--gold); color:var(--ink); }
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 var(--gutter); }
.eyebrow{ font-family:var(--mono); font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--ink-soft); font-weight:500; }
.eyebrow .dot{ color:var(--gold-deep); margin:0 .55em; }
.display{ font-family:var(--display); font-weight:340; letter-spacing:-.025em; line-height:.98; font-variation-settings:"opsz" 96,"SOFT" 50; }
.italic{ font-style:italic; font-variation-settings:"opsz" 144,"SOFT" 90; }

/* ---- buttons ---- */
.btn{ display:inline-flex; align-items:center; gap:.6em; padding:14px 22px; border-radius:999px; font-weight:600; font-size:14px; letter-spacing:.01em;
  transition:transform .25s ease, background .25s ease, color .25s ease, box-shadow .25s ease, border-color .25s ease; white-space:nowrap; }
.btn .arr{ transition:transform .3s ease; }
.btn:hover .arr{ transform:translateX(4px); }
.btn-primary{ background:var(--ink); color:var(--paper); }
.btn-primary:hover{ background:var(--blue-deep); }
.btn-gold{ background:var(--gold); color:var(--ink); box-shadow:0 8px 20px -10px rgba(255,124,1,.6); }
.btn-gold:hover{ background:var(--gold-deep); color:var(--paper); }
.btn-ghost{ background:transparent; color:var(--ink); border:1px solid var(--ink); }
.btn-ghost:hover{ background:var(--ink); color:var(--paper); }
.btn-link{ display:inline-flex; align-items:center; gap:.5em; font-weight:600; font-size:14px; border-bottom:1px solid currentColor; padding-bottom:2px; }
.btn-link:hover .arr{ transform:translateX(4px); }
.btn-on-ink{ background:var(--gold); color:var(--ink); }
.btn-on-ink:hover{ background:var(--paper); color:var(--ink); }
.btn-on-ink-ghost{ border:1px solid rgba(255,255,255,.4); color:var(--paper); }
.btn-on-ink-ghost:hover{ background:var(--paper); color:var(--ink); border-color:var(--paper); }

/* ---- utility bar ---- */
.utility{ background:var(--ink); color:var(--paper); font-size:12.5px; letter-spacing:.02em; }
.utility .wrap{ display:flex; align-items:center; justify-content:space-between; height:38px; }
.util-left,.util-right{ display:flex; align-items:center; gap:22px; }
.util-pill{ display:inline-flex; border:1px solid rgba(255,255,255,.2); border-radius:999px; overflow:hidden; font-family:var(--mono); font-size:11px; letter-spacing:.12em; }
.util-pill button{ padding:4px 12px; color:var(--paper); transition:background .2s ease, color .2s ease; }
.util-pill button.on{ background:var(--gold); color:var(--ink); }
.util-pill button:hover:not(.on){ background:rgba(255,255,255,.08); }
.util-link{ opacity:.8; transition:opacity .2s ease; }
.util-link:hover{ opacity:1; color:var(--gold); }
.util-status{ display:inline-flex; align-items:center; gap:8px; font-family:var(--mono); font-size:11px; letter-spacing:.14em; opacity:.75; }
.util-status::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--green); box-shadow:0 0 0 3px rgba(74,222,128,.18); }

/* ---- nav ---- */
.nav{ position:sticky; top:0; z-index:50; background:rgba(255,255,255,.88); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); border-bottom:1px solid var(--rule-soft); }
.nav .wrap{ display:flex; align-items:center; justify-content:space-between; height:78px; }
.brand{ display:flex; align-items:center; gap:14px; }
.brand-mark{ font-family:var(--display); font-style:italic; font-weight:600; font-size:26px; letter-spacing:-.01em; color:var(--blue); line-height:1; font-variation-settings:"opsz" 144,"SOFT" 30; }
.brand-mark::after{ content:""; display:inline-block; width:34px; height:3px; background:var(--gold); vertical-align:middle; margin-left:8px; transform:translateY(-4px); }
.brand-sub{ display:block; font-family:var(--mono); font-size:10px; letter-spacing:.22em; color:var(--ink-soft); margin-top:3px; }
.nav-links{ display:flex; gap:36px; align-items:center; font-size:14.5px; font-weight:500; }
.nav-links a{ position:relative; padding:6px 0; }
.nav-links a::after{ content:""; position:absolute; left:0; right:0; bottom:-2px; height:2px; background:var(--gold); transform:scaleX(0); transform-origin:left; transition:transform .3s ease; }
.nav-links a:hover::after, .nav-links a.active::after{ transform:scaleX(1); }
.nav-links a.active{ color:var(--blue); }
.nav-cta{ display:flex; gap:14px; align-items:center; }
.icon-btn{ position:relative; width:40px; height:40px; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; border:1px solid var(--rule); transition:border-color .2s ease, background .2s ease; }
.icon-btn:hover{ border-color:var(--ink); background:var(--bone); }
.icon-btn svg{ width:18px; height:18px; }
.cart-dot{ position:absolute; top:-3px; right:-3px; min-width:18px; height:18px; padding:0 5px; border-radius:9px; background:var(--gold); color:var(--ink); font-family:var(--mono); font-size:10px; font-weight:600; display:inline-flex; align-items:center; justify-content:center; }
.cart-dot.empty{ display:none; }
.hamburger{ display:none; }

/* mobile menu drawer */
.mobile-menu{ position:fixed; inset:0; background:var(--ink); color:var(--paper); padding:90px 28px 28px; z-index:60; transform:translateY(-100%); transition:transform .35s ease; overflow-y:auto; }
.mobile-menu.open{ transform:none; }
.mobile-menu a{ display:block; padding:18px 0; font-family:var(--display); font-size:32px; font-weight:340; letter-spacing:-.02em; border-bottom:1px solid rgba(255,255,255,.12); }
.mobile-menu a em{ font-style:italic; color:var(--gold); }
.mobile-close{ position:absolute; top:24px; right:24px; width:42px; height:42px; border:1px solid rgba(255,255,255,.3); border-radius:50%; color:var(--paper); display:flex; align-items:center; justify-content:center; }

/* ---- footer ---- */
footer.foot{ background:var(--ink); color:var(--paper); padding:80px 0 32px; position:relative; overflow:hidden; }
footer.foot::before{ content:""; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg, transparent, var(--gold), transparent); }
.foot-top{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr 1fr; gap:40px; padding-bottom:56px; border-bottom:1px solid rgba(255,255,255,.12); }
.foot-brand .brand-mark{ color:var(--gold); font-size:34px; }
.foot-brand .brand-mark::after{ background:var(--paper); }
.foot-brand p{ color:rgba(255,255,255,.7); font-size:14.5px; max-width:34ch; margin:16px 0 24px; }
.foot-newsletter{ display:flex; border:1px solid rgba(255,255,255,.25); border-radius:999px; overflow:hidden; padding:4px 4px 4px 18px; max-width:340px; }
.foot-newsletter input{ flex:1; background:transparent; border:0; outline:0; color:var(--paper); font-size:14px; }
.foot-newsletter input::placeholder{ color:rgba(255,255,255,.5); }
.foot-newsletter button{ background:var(--gold); color:var(--ink); border-radius:999px; padding:10px 18px; font-weight:600; font-size:13px; transition:background .2s ease; }
.foot-newsletter button:hover{ background:var(--paper); }
.foot-col h4{ font-family:var(--mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin:0 0 18px; font-weight:500; }
.foot-col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px; }
.foot-col a{ color:rgba(255,255,255,.8); font-size:14px; transition:color .2s ease; }
.foot-col a:hover{ color:var(--gold); }
.foot-bottom{ padding-top:32px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:18px; font-family:var(--mono); font-size:11px; letter-spacing:.14em; color:rgba(255,255,255,.6); }
.foot-social{ display:flex; gap:14px; }
.foot-social a{ width:36px; height:36px; border-radius:50%; border:1px solid rgba(255,255,255,.2); display:inline-flex; align-items:center; justify-content:center; color:rgba(255,255,255,.7); transition:border-color .2s ease, color .2s ease; }
.foot-social a:hover{ border-color:var(--gold); color:var(--gold); }
.foot-social svg{ width:16px; height:16px; }
.foot-legal{ display:flex; gap:22px; }
.foot-legal a{ color:rgba(255,255,255,.6); text-transform:none; letter-spacing:.04em; }
.foot-legal a:hover{ color:var(--gold); }
.foot-mark{ font-family:var(--display); font-style:italic; font-weight:300; font-size:clamp(80px,14vw,220px); line-height:.85; letter-spacing:-.04em; color:rgba(255,255,255,.04); text-align:center; margin-top:60px; font-variation-settings:"opsz" 144,"SOFT" 100; pointer-events:none; user-select:none; }

/* ---- section scaffolds ---- */
section.section{ padding:120px 0; position:relative; }
section.section.compact{ padding:80px 0; }
.section-head{ display:grid; grid-template-columns:1fr 1.4fr; gap:48px; margin-bottom:64px; align-items:end; }
.section-head .h2{ font-family:var(--display); font-weight:330; font-size:clamp(40px,5.4vw,76px); line-height:.96; letter-spacing:-.03em; margin:14px 0 0; font-variation-settings:"opsz" 144,"SOFT" 40; }
.section-head .h2 em{ font-style:italic; color:var(--blue); font-variation-settings:"opsz" 144,"SOFT" 100; }
.section-head p{ font-size:16.5px; color:var(--ink-soft); max-width:48ch; margin:0; }
.section-num{ font-family:var(--mono); font-size:12px; letter-spacing:.2em; color:var(--gold-deep); }

/* ---- page header ---- */
.page-head{ padding:64px 0 48px; background:var(--paper); border-bottom:1px solid var(--rule); position:relative; overflow:hidden; }
.page-head::before{ content:""; position:absolute; inset:0; background:radial-gradient(800px 400px at 90% -20%,rgba(2,80,148,.06),transparent 60%); pointer-events:none; }
.page-head .wrap{ position:relative; }
.crumbs{ display:flex; gap:8px; align-items:center; font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:20px; }
.crumbs a:hover{ color:var(--gold-deep); }
.crumbs span{ opacity:.5; }
.page-title{ font-family:var(--display); font-weight:330; font-size:clamp(48px,7vw,108px); line-height:1.20; letter-spacing:-.03em; margin:0 0 18px; font-variation-settings:"opsz" 144,"SOFT" 40; max-width:18ch; }
.page-title em{ font-style:italic; color:var(--blue); }
.page-sub{ font-size:18px; color:var(--ink-soft); max-width:60ch; margin:0; }
.page-meta{ display:flex; gap:24px; margin-top:36px; font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); }
.page-meta span::before{ content:"·  "; color:var(--gold-deep); }
.page-meta span:first-child::before{ display:none; }

/* ---- reveal ---- */
.reveal{ opacity:0; transform:translateY(18px); transition:opacity .8s ease, transform .8s ease; }
.reveal.in{ opacity:1; transform:none; }

/* ---- responsive base ---- */
@media (max-width:980px){
  .nav-links, .util-left .util-link.hide-md{ display:none; }
  .hamburger{ display:inline-flex; }
  .section-head{ grid-template-columns:1fr; gap:14px; margin-bottom:40px; }
  section.section{ padding:80px 0; }
  .foot-top{ grid-template-columns:1fr 1fr; gap:32px; padding-bottom:36px; }
  .foot-brand{ grid-column:span 2; }
  .foot-bottom{ flex-direction:column; align-items:flex-start; }
}
@media (max-width:560px){
  .utility .util-status, .util-left .sep{ display:none; }
  .brand-mark::after{ display:none; }
}

/* ============================================================
   HOMEPAGE — hero, ticker, trust, products, why, industries, story, dist, quote
   ============================================================ */
.hero{ position:relative; padding:64px 0 0; overflow:hidden;
  background:radial-gradient(1200px 600px at 85% -10%,rgba(2,80,148,.06),transparent 60%),
             radial-gradient(800px 400px at -10% 80%,rgba(255,124,1,.08),transparent 60%),
             var(--paper); }
.hero::before{ content:""; position:absolute; inset:0;
  background-image:linear-gradient(to right,rgba(26,46,80,.04) 1px,transparent 1px),linear-gradient(to bottom,rgba(26,46,80,.04) 1px,transparent 1px);
  background-size:80px 80px; mask-image:linear-gradient(to bottom,black 0%,black 50%,transparent 100%); pointer-events:none; }
.hero .wrap{ position:relative; }
.hero-grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:56px; align-items:end; min-height:78vh; padding-bottom:48px; }
.hero-copy{ position:relative; }
.hero-label{ display:inline-flex; align-items:center; gap:14px; margin-bottom:36px; }
.hero-label .bar{ width:36px; height:1px; background:var(--ink); }
.hero-h1{ font-family:var(--display); font-weight:330; font-size:clamp(48px,7.4vw,90px); line-height:1.10; letter-spacing:-.035em; margin:0 0 32px; font-variation-settings:"opsz" 144,"SOFT" 40; }
.hero-h1 em{ font-style:italic; color:var(--blue); font-variation-settings:"opsz" 144,"SOFT" 100; }
.hero-h1 .ink-stroke{ display:inline-block; position:relative; }
.hero-h1 .ink-stroke::after{ content:""; position:absolute; left:-2%; right:-2%; bottom:.12em; height:.18em; background:var(--gold); z-index:-1; transform:skewX(-8deg); }
.hero-lede{ font-size:clamp(16px,1.25vw,18.5px); max-width:52ch; color:var(--ink-soft); margin:0 0 40px; }
.hero-actions{ display:flex; gap:14px; flex-wrap:wrap; margin-bottom:56px; }
.hero-specs{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border-top:1px solid var(--rule); padding-top:24px; }
.spec{ padding-right:18px; }
.spec + .spec{ border-left:1px solid var(--rule); padding-left:18px; }
.spec-num{ font-family:var(--display); font-weight:340; font-size:34px; line-height:1; letter-spacing:-.02em; }
.spec-num sup{ font-size:.5em; vertical-align:.55em; color:var(--gold-deep); margin-left:2px; }
.spec-label{ font-family:var(--mono); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); margin-top:8px; }
.hero-visual{ position:relative; align-self:stretch; display:flex; flex-direction:column; gap:14px; }
/* .hero-photo{ position:relative; flex:1; min-height:520px; border-radius:6px; overflow:hidden;
  background:radial-gradient(circle at 30% 25%,rgba(255,124,1,.22),transparent 55%),radial-gradient(circle at 80% 80%,rgba(2,80,148,.4),transparent 55%),linear-gradient(140deg,#1A2E50 0%,#1A2E50 60%,#0B1A33 100%);
  box-shadow:var(--shadow-2); } */
.hero-photo img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.92; filter:contrast(1.05) saturate(.9); }
.hero-photo::before{ content:""; position:absolute; inset:0;
  background-image:linear-gradient(rgba(255,124,1,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(255,124,1,.08) 1px,transparent 1px),radial-gradient(circle,rgba(255,255,255,.08) 1px,transparent 1.4px);
  background-size:60px 60px,60px 60px,20px 20px; background-position:0 0,0 0,10px 10px; pointer-events:none; z-index:1; }
.hero-photo::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 40%,rgba(26,46,80,.55) 100%); z-index:1; }
.hero-photo .blueprint{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; z-index:1; pointer-events:none; }
.hero-photo .blueprint svg{ width:78%; max-width:520px; height:auto; opacity:.9; }
.hero-photo .blueprint text{ font-family:var(--mono); font-size:11px; letter-spacing:.18em; fill:#FF7C01; }
.hero-photo-caption{ position:absolute; left:20px; right:20px; bottom:18px; color:var(--paper); font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; display:flex; justify-content:space-between; align-items:end; z-index:2; }
.hero-photo-caption .field{ font-family:var(--display); font-style:italic; font-size:18px; letter-spacing:0; text-transform:none; font-weight:340; }
.hero-badge{ position:absolute; top:0; right:0; transform:translate(36%,-36%) rotate(-8deg); width:128px; height:128px; background:var(--gold); color:var(--ink); border-radius:50%; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; font-family:var(--display); font-style:italic; font-weight:500; font-size:16px; line-height:1.05; box-shadow:var(--shadow-1); z-index:5; }
.hero-badge small{ display:block; font-family:var(--mono); font-style:normal; font-size:9px; letter-spacing:.18em; margin-top:4px; font-weight:500; }
.hero-rotate-marquee{ font-family:var(--mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-soft); display:flex; justify-content:space-between; }
.hero-rotate-marquee b{ color:var(--gold-deep); font-weight:500; }

.ticker{ background:var(--ink); color:var(--paper); padding:18px 0; overflow:hidden; border-top:1px solid #2A4470; }
.ticker-track{ display:flex; gap:64px; animation:scroll 38s linear infinite; white-space:nowrap; }
.ticker-item{ display:inline-flex; align-items:center; gap:14px; font-family:var(--display); font-style:italic; font-size:22px; font-weight:300; letter-spacing:-.005em; }
.ticker-item .star{ color:var(--gold); font-style:normal; font-family:var(--sans); }
@keyframes scroll{ to{ transform:translateX(-50%); } }

.trust{ padding:56px 0 64px; background:var(--paper); border-bottom:1px solid var(--rule); }
.trust-row{ display:flex; align-items:center; gap:48px; flex-wrap:wrap; justify-content:space-between; }
.trust-lead{ flex:0 0 auto; max-width:300px; font-family:var(--display); font-style:italic; font-weight:340; font-size:22px; line-height:1.2; letter-spacing:-.01em; color:var(--ink); }
.trust-lead em{ color:var(--gold-deep); font-style:normal; font-family:var(--mono); font-size:12px; letter-spacing:.18em; text-transform:uppercase; display:block; margin-bottom:8px; }
.trust-marks{ display:flex; gap:36px; flex-wrap:wrap; align-items:center; flex:1; justify-content:flex-end; }
.mark{ display:inline-flex; flex-direction:column; align-items:center; gap:6px; color:var(--ink); opacity:.78; transition:opacity .2s ease; }
.mark:hover{ opacity:1; }
.mark-glyph{ font-family:var(--display); font-weight:500; font-style:italic; font-size:30px; line-height:1; letter-spacing:-.02em; border:1.5px solid currentColor; border-radius:999px; padding:10px 18px; }
.mark-glyph.mono{ font-family:var(--mono); font-style:normal; font-weight:500; font-size:16px; letter-spacing:.1em; padding:14px 18px; }
.mark-label{ font-family:var(--mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase; }

.products-grid{ display:grid; grid-template-columns:1.3fr 1fr 1fr; grid-template-rows:auto auto; gap:18px; }
.product-card{ position:relative; background:var(--bone); border:1px solid var(--rule-soft); border-radius:8px; padding:28px; overflow:hidden; transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease; min-height:340px; display:flex; flex-direction:column; justify-content:space-between; }
.product-card:hover{ transform:translateY(-4px); border-color:var(--ink); box-shadow:var(--shadow-2); }
.product-card.feature{ grid-row:span 2; background:linear-gradient(160deg,var(--ink) 0%,#1A2E50 100%); color:var(--paper); border-color:var(--ink); min-height:auto; }
.product-card.feature::before{ content:""; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,var(--gold),transparent); }
.product-card.feature .pc-cat{ color:var(--gold); }
.product-card.feature .pc-meta{ color:rgba(255,255,255,.6); border-color:rgba(255,255,255,.15); }
.product-card.feature .pc-cta{ color:var(--gold); border-color:var(--gold); }
.pc-cat{ font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:14px; display:flex; justify-content:space-between; align-items:center; }
.pc-cat .pc-count{ opacity:.7; }
.pc-title{ font-family:var(--display); font-weight:340; font-size:34px; line-height:1; letter-spacing:-.02em; margin:0 0 14px; font-variation-settings:"opsz" 144,"SOFT" 40; }
.product-card.feature .pc-title{ font-size:46px; }
.pc-title em{ font-style:italic; }
.pc-desc{ font-size:14.5px; color:var(--ink-soft); margin:0 0 22px; }
.product-card.feature .pc-desc{ color:rgba(255,255,255,.78); font-size:15.5px; max-width:34ch; }
.pc-visual{ position:relative; margin:8px 0 20px; aspect-ratio:16/10; border-radius:4px; background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.4),transparent 50%),repeating-linear-gradient(135deg,#EFEFEF 0 8px,#EFEFEF 8px 16px); overflow:hidden; }
.product-card.feature .pc-visual{ aspect-ratio:auto; flex:1; min-height:240px; background:radial-gradient(circle at 70% 30%,rgba(255,124,1,.18),transparent 55%),repeating-linear-gradient(135deg,#0F1F3A 0 8px,#1A2E50 8px 16px); margin:22px 0; }
.pc-visual svg{ position:absolute; inset:0; width:100%; height:100%; }
.pc-meta{ display:flex; justify-content:space-between; gap:16px; border-top:1px solid var(--rule); padding-top:14px; font-family:var(--mono); font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); }
.pc-cta{ display:inline-flex; align-items:center; gap:.4em; font-weight:600; font-size:14px; color:var(--ink); border-bottom:1px solid var(--ink); padding-bottom:3px; align-self:flex-start; transition:gap .25s ease; }
.pc-cta:hover{ gap:.8em; }
@media (max-width:980px){
  .hero-grid{ grid-template-columns:1fr; gap:40px; min-height:auto; padding-bottom:32px; }
  .hero-visual{ order:-1; }
  .hero-photo{ min-height:380px; }
  .hero-badge{ width:96px; height:96px; font-size:13px; }
  .hero-specs{ grid-template-columns:repeat(2,1fr); gap:18px 0; }
  .spec + .spec:nth-child(3){ border-left:none; padding-left:0; }
  .trust-row{ gap:28px; }
  .trust-marks{ justify-content:flex-start; }
  .products-grid{ grid-template-columns:1fr 1fr; }
  .product-card.feature{ grid-column:span 2; grid-row:auto; }
  .product-card.feature .pc-title{ font-size:34px; }
}
@media (max-width:560px){
  .hero-photo{ min-height:300px; }
  .hero-specs{ grid-template-columns:1fr 1fr; }
  .products-grid{ grid-template-columns:1fr; }
  .product-card.feature{ grid-column:auto; }
}

/* --- why medtech --- */
.why{ background:var(--ink); color:var(--paper); position:relative; overflow:hidden; }
.why::before{ content:""; position:absolute; inset:0; background:radial-gradient(800px 400px at 90% 10%,rgba(255,124,1,.10),transparent 60%),radial-gradient(600px 300px at 10% 100%,rgba(2,80,148,.18),transparent 60%); pointer-events:none; }
.why .section-head .h2 em{ color:var(--gold); }
.why .section-head p{ color:rgba(255,255,255,.7); }
.why .section-num{ color:var(--gold); }
.why .wrap{ position:relative; }
.why-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; border-top:1px solid rgba(255,255,255,.12); }
.why-item{ padding:48px 36px 56px 0; border-bottom:1px solid rgba(255,255,255,.12); position:relative; }
.why-item + .why-item{ padding-left:36px; border-left:1px solid rgba(255,255,255,.12); }
.why-num{ font-family:var(--mono); font-size:11px; letter-spacing:.2em; color:var(--gold); margin-bottom:24px; display:flex; align-items:center; gap:14px; }
.why-num::after{ content:""; flex:1; height:1px; background:rgba(255,124,1,.3); }
.why-icon{ width:54px; height:54px; margin-bottom:24px; display:inline-flex; align-items:center; justify-content:center; border:1px solid rgba(255,124,1,.5); border-radius:50%; color:var(--gold); }
.why-icon svg{ width:24px; height:24px; }
.why-h3{ font-family:var(--display); font-weight:340; font-size:30px; line-height:1.05; letter-spacing:-.02em; margin:0 0 16px; font-variation-settings:"opsz" 144,"SOFT" 60; }
.why-h3 em{ font-style:italic; color:var(--gold); }
.why-p{ color:rgba(255,255,255,.72); font-size:15px; line-height:1.6; margin:0 0 24px; }
.why-stat{ font-family:var(--display); font-style:italic; font-size:18px; font-weight:400; color:var(--gold); padding-top:18px; border-top:1px dashed rgba(255,124,1,.3); }
.why-stat strong{ display:block; font-family:var(--display); font-style:normal; font-size:42px; line-height:1; letter-spacing:-.02em; color:var(--paper); margin-bottom:4px; font-weight:340; }
@media (max-width:980px){ .why-grid{ grid-template-columns:1fr; } .why-item, .why-item + .why-item{ padding:36px 0; border-left:none; } }

/* --- industries list --- */
.industries-shell{ display:grid; grid-template-columns:1fr 1.4fr; gap:64px; align-items:start; }
.ind-aside{ position:sticky; top:120px; }
.ind-aside .h2{ margin-top:8px; }
.ind-aside p{ color:var(--ink-soft); margin:16px 0 28px; max-width:38ch; }
.ind-list{ border-top:1px solid var(--rule); }
.ind-row{ display:grid; grid-template-columns:64px 1fr auto; gap:24px; padding:34px 0; border-bottom:1px solid var(--rule); align-items:center; cursor:pointer; transition:padding .3s ease; }
.ind-row:hover{ padding-left:8px; }
.ind-row:hover .ind-title{ color:var(--blue); }
.ind-row:hover .ind-go{ background:var(--ink); color:var(--paper); transform:rotate(-45deg); }
.ind-num{ font-family:var(--mono); font-size:12px; letter-spacing:.2em; color:var(--gold-deep); }
.ind-title{ font-family:var(--display); font-weight:340; font-size:42px; line-height:1; letter-spacing:-.025em; margin:0 0 8px; transition:color .3s ease; font-variation-settings:"opsz" 144,"SOFT" 40; }
.ind-title em{ font-style:italic; }
.ind-tags{ display:flex; gap:18px; flex-wrap:wrap; font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); }
.ind-tags span::before{ content:"·  "; color:var(--gold-deep); }
.ind-tags span:first-child::before{ display:none; }
.ind-go{ width:54px; height:54px; border-radius:50%; border:1px solid var(--ink); display:inline-flex; align-items:center; justify-content:center; transition:background .3s ease, color .3s ease, transform .3s ease; }
.ind-go svg{ width:18px; height:18px; }
@media (max-width:980px){ .industries-shell{ grid-template-columns:1fr; gap:32px; } .ind-aside{ position:static; } .ind-title{ font-size:32px; } .ind-row{ grid-template-columns:48px 1fr auto; padding:24px 0; } .ind-go{ width:44px; height:44px; } }

/* --- story --- */
.story{ background:var(--paper-2); position:relative; overflow:hidden; }
.story::before{ content:"\201C"; position:absolute; font-family:var(--display); font-style:italic; font-weight:300; font-size:520px; line-height:.7; color:rgba(2,80,148,.05); top:30px; left:-30px; font-variation-settings:"opsz" 144,"SOFT" 100; pointer-events:none; user-select:none; }
.story-grid{ display:grid; grid-template-columns:1fr 1.6fr; gap:60px; align-items:start; position:relative; }
.story-meta .section-num{ display:block; margin-bottom:14px; }
.story-photo{ aspect-ratio:3/4; border-radius:6px; background:radial-gradient(circle at 30% 20%,rgba(255,124,1,.18),transparent 60%),linear-gradient(160deg,#1A2E50 0%,#1A2E50 100%); position:relative; overflow:hidden; box-shadow:var(--shadow-2); }
.story-photo img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.85; mix-blend-mode:luminosity; }
.story-photo::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 40%,rgba(26,46,80,.6) 100%); }
.story-stamp{ position:absolute; left:18px; bottom:18px; right:18px; color:var(--paper); z-index:2; display:flex; justify-content:space-between; font-family:var(--mono); font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; }
.story-quote{ font-family:var(--display); font-weight:340; font-size:clamp(28px,3.4vw,46px); line-height:1.12; letter-spacing:-.02em; margin:0 0 36px; font-variation-settings:"opsz" 144,"SOFT" 50; }
.story-quote em{ font-style:italic; color:var(--blue); }
.story-attrib{ display:flex; align-items:center; gap:18px; padding-top:24px; border-top:1px solid var(--rule); }
.attrib-avatar{ width:54px; height:54px; border-radius:50%; background:linear-gradient(135deg,var(--blue) 0%,var(--blue-deep) 100%); display:flex; align-items:center; justify-content:center; color:var(--paper); font-family:var(--display); font-style:italic; font-weight:500; font-size:22px; }
.attrib-name{ font-weight:600; font-size:15px; }
.attrib-role{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); margin-top:2px; }
.attrib-sep{ flex:1; height:1px; background:var(--rule); margin:0 8px; }
.attrib-logo{ font-family:var(--display); font-style:italic; font-weight:500; font-size:18px; color:var(--ink-soft); }
.story-metrics{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; margin-top:48px; }
.story-metric{ padding:24px 20px; border-left:1px solid var(--rule); }
.story-metric:first-child{ border-left:none; padding-left:0; }
.story-metric .n{ font-family:var(--display); font-size:46px; line-height:1; font-weight:340; letter-spacing:-.025em; font-variation-settings:"opsz" 144,"SOFT" 40; }
.story-metric .n em{ font-style:italic; color:var(--blue); }
.story-metric .l{ font-family:var(--mono); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); margin-top:10px; }
@media (max-width:980px){ .story-grid{ grid-template-columns:1fr; gap:32px; } .story-photo{ aspect-ratio:4/3; } .story-metrics{ grid-template-columns:1fr 1fr; gap:0; } .story-metric:nth-child(3){ border-left:none; padding-left:0; padding-top:24px; border-top:1px solid var(--rule); grid-column:span 2; } }

/* --- distributors map --- */
.dist{ background:var(--paper); }
.dist-shell{ position:relative; background:var(--ink); color:var(--paper); border-radius:14px; padding:64px clamp(28px,5vw,80px); overflow:hidden; }
.dist-shell::before{ content:""; position:absolute; inset:0; background:radial-gradient(900px 500px at 20% 0%,rgba(2,80,148,.22),transparent 60%),radial-gradient(700px 400px at 90% 100%,rgba(255,124,1,.10),transparent 60%); pointer-events:none; }
.dist-shell::after{ content:""; position:absolute; inset:0; background-image:radial-gradient(rgba(255,255,255,.07) 1px,transparent 1.2px); background-size:22px 22px; pointer-events:none; mask-image:radial-gradient(ellipse at center,black 0%,transparent 75%); }
.dist-shell > *{ position:relative; z-index:1; }
.dist-head{ display:grid; grid-template-columns:1fr auto; gap:32px; align-items:end; margin-bottom:48px; }
.dist-head .section-num{ color:var(--gold); }
.dist-head .h2{ color:var(--paper); margin-top:8px; }
.dist-head .h2 em{ color:var(--gold); }
.dist-cta-wrap{ display:flex; gap:14px; }
.constellation{ position:relative; aspect-ratio:16/8; margin-bottom:48px; background:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px) 0 0/100% 12.5%,linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px) 0 0/8.33% 100%; border:1px solid rgba(255,255,255,.12); border-radius:8px; }
.constellation::before, .constellation::after{ content:""; position:absolute; font-family:var(--mono); font-size:9px; letter-spacing:.2em; color:rgba(255,255,255,.4); }
.constellation::before{ content:"60°N"; top:18px; left:18px; }
.constellation::after{ content:"0° EQ"; top:50%; left:18px; transform:translateY(-50%); }
.const-svg{ position:absolute; inset:0; width:100%; height:100%; }
.const-line{ stroke:rgba(255,124,1,.25); stroke-width:.6; fill:none; }
.const-line-key{ stroke:var(--gold); stroke-width:1; fill:none; stroke-dasharray:3 3; opacity:.6; }
.const-dot{ fill:var(--paper); }
.const-dot.gold, .const-dot.hub{ fill:var(--gold); }
.const-label{ font-family:var(--mono); font-size:9.5px; letter-spacing:.16em; fill:rgba(255,255,255,.85); text-transform:uppercase; }
.const-label.hub{ fill:var(--gold); font-weight:500; }
.const-pulse{ fill:var(--gold); opacity:.35; animation:pulse 2.4s ease-out infinite; }
@keyframes pulse{ 0%{ r:5; opacity:.45; } 100%{ r:18; opacity:0; } }
.dist-stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border-top:1px solid rgba(255,255,255,.15); border-bottom:1px solid rgba(255,255,255,.15); }
.dist-stat{ padding:32px 24px; border-left:1px solid rgba(255,255,255,.15); }
.dist-stat:first-child{ border-left:none; padding-left:0; }
.dist-stat .n{ font-family:var(--display); font-size:54px; line-height:1; font-weight:340; letter-spacing:-.025em; font-variation-settings:"opsz" 144,"SOFT" 40; }
.dist-stat .n em{ font-style:italic; color:var(--gold); }
.dist-stat .l{ font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.65); margin-top:10px; }
.dist-countries{ margin-top:40px; display:flex; flex-wrap:wrap; gap:10px; }
.country-pill{ display:inline-flex; align-items:center; gap:8px; padding:7px 14px; border:1px solid rgba(255,255,255,.2); border-radius:999px; font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.78); transition:border-color .2s ease, color .2s ease; cursor:pointer; }
.country-pill:hover{ border-color:var(--gold); color:var(--gold); }
.country-pill .flag{ width:14px; height:10px; border-radius:1px; background:var(--gold-deep); }
@media (max-width:980px){ .dist-head{ grid-template-columns:1fr; } .dist-stats{ grid-template-columns:1fr 1fr; } .dist-stat{ border-left:none; padding-left:0; } .dist-stat:nth-child(2n){ border-left:1px solid rgba(255,255,255,.15); padding-left:24px; } .dist-stat:nth-child(n+3){ border-top:1px solid rgba(255,255,255,.15); } .constellation{ aspect-ratio:4/3; } }

/* --- quote form --- */
.quote{ background:radial-gradient(800px 400px at 20% 0%,rgba(2,80,148,.06),transparent 60%),var(--paper); }
.quote-shell{ display:grid; grid-template-columns:1fr 1.1fr; gap:60px; align-items:start; }
.quote-copy .section-num{ margin-bottom:18px; display:block; }
.quote-copy .h2{ font-family:var(--display); font-weight:330; font-size:clamp(40px,5.4vw,76px); line-height:.96; letter-spacing:-.03em; margin:0 0 28px; font-variation-settings:"opsz" 144,"SOFT" 40; }
.quote-copy .h2 em{ font-style:italic; color:var(--blue); }
.quote-copy p{ font-size:16px; color:var(--ink-soft); margin:0 0 28px; max-width:46ch; }
.contact-blocks{ display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:36px; }
.contact-block{ background:var(--bone); border:1px solid var(--rule-soft); border-radius:8px; padding:24px; }
.contact-block .ttl{ font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:14px; display:flex; align-items:center; gap:10px; }
.contact-block .ttl::before{ content:""; width:10px; height:10px; border-radius:50%; background:var(--gold); }
.contact-block address{ font-style:normal; font-size:14.5px; line-height:1.55; color:var(--ink); }
.contact-block address strong{ display:block; margin-bottom:8px; font-size:15.5px; }
.contact-block a{ color:var(--blue); border-bottom:1px solid currentColor; padding-bottom:1px; }
.form-card{ background:var(--bone); border:1px solid var(--rule-soft); border-radius:14px; padding:40px; box-shadow:var(--shadow-1); position:relative; }
.form-card::before{ content:""; position:absolute; top:0; left:24px; right:24px; height:3px; background:var(--gold); border-radius:0 0 6px 6px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-bottom:18px; }
.form-row.full{ grid-template-columns:1fr; }
.field{ display:flex; flex-direction:column; gap:6px; }
.field label{ font-family:var(--mono); font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-soft); }
.field label .req{ color:var(--red); margin-left:4px; }
.field input, .field select, .field textarea{ font-family:var(--sans); font-size:15px; border:0; border-bottom:1.5px solid var(--rule); padding:10px 0; background:transparent; color:var(--ink); outline:none; transition:border-color .2s ease; }
.field input:focus, .field select:focus, .field textarea:focus{ border-color:var(--ink); }
.field textarea{ min-height:88px; resize:vertical; }
.chip-row{ display:flex; gap:8px; flex-wrap:wrap; }
.chip{ display:inline-flex; align-items:center; gap:6px; padding:8px 14px; border-radius:999px; border:1px solid var(--rule); font-size:13px; font-weight:500; background:transparent; color:var(--ink); cursor:pointer; transition:all .2s ease; }
.chip:hover{ border-color:var(--ink); }
.chip.on{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.form-footer{ display:flex; justify-content:space-between; align-items:center; margin-top:28px; padding-top:24px; border-top:1px solid var(--rule); flex-wrap:wrap; gap:14px; }
.form-note{ font-family:var(--mono); font-size:11px; letter-spacing:.12em; color:var(--ink-soft); display:flex; align-items:center; gap:8px; }
.form-note .pulse{ width:8px; height:8px; border-radius:50%; background:var(--green); box-shadow:0 0 0 4px rgba(74,222,128,.18); }
@media (max-width:980px){ .quote-shell{ grid-template-columns:1fr; gap:40px; } .form-card{ padding:28px; } .form-row{ grid-template-columns:1fr; } .contact-blocks{ grid-template-columns:1fr; } }

/* ============================================================
   CATALOG / PRODUCT DETAIL / CART / CHECKOUT
   ============================================================ */

/* --- catalog --- */
.catalog{ padding:64px 0 120px; }
.cat-toolbar{ display:flex; justify-content:space-between; align-items:center; gap:18px; padding:18px 0; border-top:1px solid var(--rule); border-bottom:1px solid var(--rule); margin-bottom:48px; flex-wrap:wrap; font-family:var(--mono); font-size:11.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); }
.cat-toolbar .filters{ display:flex; gap:8px; flex-wrap:wrap; }
.cat-toolbar .filter{ padding:7px 14px; border:1px solid var(--rule); border-radius:999px; background:transparent; color:var(--ink-soft); cursor:pointer; font-family:var(--mono); font-size:11px; letter-spacing:.14em; transition:all .2s ease; }
.cat-toolbar .filter:hover{ border-color:var(--ink); color:var(--ink); }
.cat-toolbar .filter.on{ background:var(--ink); color:var(--paper); border-color:var(--ink); }

.cat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.cat-card{ background:var(--bone); border:1px solid var(--rule-soft); border-radius:8px; overflow:hidden; display:flex; flex-direction:column; transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease; }
.cat-card:hover{ transform:translateY(-4px); border-color:var(--ink); box-shadow:var(--shadow-2); }
.cat-card .img{ aspect-ratio:4/3; background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.4),transparent 50%),repeating-linear-gradient(135deg,#EFEFEF 0 8px,#EFEFEF 8px 16px); position:relative; overflow:hidden; }
.cat-card .img svg{ position:absolute; inset:0; width:100%; height:100%; }
.cat-card .img .badge{ position:absolute; top:14px; left:14px; padding:5px 10px; background:var(--ink); color:var(--paper); font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; border-radius:999px; }
.cat-card .body{ padding:24px; flex:1; display:flex; flex-direction:column; }
.cat-card .cat{ font-family:var(--mono); font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:10px; }
.cat-card .ttl{ font-family:var(--display); font-weight:340; font-size:26px; line-height:1.05; letter-spacing:-.02em; margin:0 0 8px; font-variation-settings:"opsz" 144,"SOFT" 40; }
.cat-card .ttl em{ font-style:italic; }
.cat-card .desc{ font-size:14px; color:var(--ink-soft); margin:0 0 18px; }
.cat-card .foot{ margin-top:auto; display:flex; justify-content:space-between; align-items:center; padding-top:16px; border-top:1px solid var(--rule); }
.cat-card .price{ font-family:var(--display); font-size:22px; font-weight:340; letter-spacing:-.01em; }
.cat-card .price small{ font-family:var(--mono); font-size:10px; letter-spacing:.16em; color:var(--ink-soft); text-transform:uppercase; display:block; margin-top:2px; }
.cat-card .add{ padding:10px 16px; background:var(--ink); color:var(--paper); border-radius:999px; font-size:13px; font-weight:600; transition:background .2s ease; }
.cat-card .add:hover{ background:var(--blue-deep); }
.cat-card .add.added{ background:var(--gold); color:var(--ink); }
@media (max-width:980px){ .cat-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .cat-grid{ grid-template-columns:1fr; } }

/* --- product detail --- */
.pdp{ padding:48px 0 100px; }
.pdp-shell{ display:grid; grid-template-columns:1.1fr 1fr; gap:64px; align-items:start; }
.pdp-gallery{ position:sticky; top:120px; display:flex; flex-direction:column; gap:14px; }
.pdp-main-img{ aspect-ratio:1/1; border-radius:8px; background:radial-gradient(circle at 30% 25%,rgba(255,124,1,.18),transparent 55%),linear-gradient(160deg,#1A2E50 0%,#1A2E50 100%); position:relative; overflow:hidden; box-shadow:var(--shadow-2); }
.pdp-main-img svg{ position:absolute; inset:0; width:100%; height:100%; padding:8% }
.pdp-main-img .corner{ position:absolute; bottom:18px; left:18px; right:18px; color:var(--paper); font-family:var(--mono); font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; display:flex; justify-content:space-between; }
.pdp-thumbs{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.pdp-thumb{ aspect-ratio:1/1; border-radius:6px; background:repeating-linear-gradient(135deg,#EFEFEF 0 6px,#EFEFEF 6px 12px); border:1.5px solid var(--rule); cursor:pointer; }
.pdp-thumb.on{ border-color:var(--ink); }

.pdp-info .cat{ font-family:var(--mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:18px; display:flex; align-items:center; gap:14px; }
.pdp-info .cat::after{ content:""; flex:1; height:1px; background:var(--rule); }
.pdp-info .ttl{ font-family:var(--display); font-weight:330; font-size:clamp(38px,5vw,64px); line-height:1.20; letter-spacing:-.028em; margin:0 0 18px; font-variation-settings:"opsz" 144,"SOFT" 40; }
.pdp-info .ttl em{ font-style:italic; color:var(--blue); }
.pdp-info .lede{ font-size:17px; color:var(--ink-soft); margin:0 0 30px; line-height:1.55; }
.pdp-pricecard{ display:flex; align-items:flex-end; gap:22px; padding:22px 0; border-top:1px solid var(--rule); border-bottom:1px solid var(--rule); margin-bottom:28px; }
.pdp-price{ font-family:var(--display); font-size:46px; font-weight:340; line-height:1; letter-spacing:-.02em; }
.pdp-price small{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); display:block; margin-top:6px; }
.pdp-stock{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--green); display:inline-flex; align-items:center; gap:8px; margin-bottom:6px; }
.pdp-stock::before{ content:""; width:8px; height:8px; border-radius:50%; background:currentColor; }
.pdp-actions{ display:flex; gap:14px; align-items:stretch; margin-bottom:32px; flex-wrap:wrap; }
.qty-stepper{ display:flex; align-items:center; border:1px solid var(--ink); border-radius:999px; overflow:hidden; }
.qty-stepper button{ width:44px; height:48px; background:transparent; color:var(--ink); font-size:20px; transition:background .2s ease; }
.qty-stepper button:hover{ background:var(--ink); color:var(--paper); }
.qty-stepper input{ width:54px; height:48px; text-align:center; border:0; background:transparent; font-family:var(--mono); font-size:14px; font-weight:600; outline:none; color:var(--ink); }
.pdp-add{ flex:1; min-width:200px; padding:14px 26px; background:var(--gold); color:var(--ink); border-radius:999px; font-weight:600; font-size:14px; letter-spacing:.02em; transition:background .25s ease, color .25s ease; }
.pdp-add:hover{ background:var(--ink); color:var(--paper); }
.pdp-add.added{ background:var(--green); color:var(--ink); }
.pdp-quote{ padding:14px 22px; background:transparent; color:var(--ink); border:1px solid var(--ink); border-radius:999px; font-weight:600; font-size:14px; }
.pdp-quote:hover{ background:var(--ink); color:var(--paper); }

.pdp-bullets{ list-style:none; margin:0 0 32px; padding:0; display:grid; grid-template-columns:1fr 1fr; gap:14px 24px; }
.pdp-bullets li{ font-size:14.5px; color:var(--ink); padding-left:22px; position:relative; }
.pdp-bullets li::before{ content:""; position:absolute; left:0; top:9px; width:10px; height:10px; border:1.5px solid var(--gold-deep); border-radius:50%; }

.pdp-tabs{ margin-top:24px; }
.pdp-tab-btns{ display:flex; gap:0; border-bottom:1px solid var(--rule); margin-bottom:24px; }
.pdp-tab-btns button{ padding:14px 22px 12px; font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-soft); border-bottom:2px solid transparent; margin-bottom:-1px; transition:color .2s ease, border-color .2s ease; }
.pdp-tab-btns button.on{ color:var(--ink); border-color:var(--ink); }
.pdp-tab-panel{ display:none; font-size:15px; color:var(--ink); line-height:1.65; }
.pdp-tab-panel.on{ display:block; }
.spec-table{ width:100%; border-collapse:collapse; font-size:14px; }
.spec-table tr{ border-bottom:1px solid var(--rule-soft); }
.spec-table th{ text-align:left; padding:12px 0; width:38%; font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); font-weight:500; }
.spec-table td{ padding:12px 0; }

/* related products strip */
.related{ padding:96px 0 120px; background:var(--paper-2); border-top:1px solid var(--rule); }

@media (max-width:980px){ .pdp-shell{ grid-template-columns:1fr; gap:40px; } .pdp-gallery{ position:static; } .pdp-bullets{ grid-template-columns:1fr; } }

/* --- cart page --- */
.cart-shell{ display:grid; grid-template-columns:1.5fr 1fr; gap:48px; padding:48px 0 120px; align-items:start; }
.cart-list{ background:var(--bone); border:1px solid var(--rule-soft); border-radius:10px; overflow:hidden; }
.cart-empty{ padding:80px 30px; text-align:center; }
.cart-empty .h2{ font-family:var(--display); font-size:42px; font-weight:340; margin:0 0 14px; letter-spacing:-.02em; }
.cart-empty p{ color:var(--ink-soft); margin:0 0 24px; }
.cart-row{ display:grid; grid-template-columns:88px 1fr auto auto auto; gap:22px; align-items:center; padding:22px; border-bottom:1px solid var(--rule-soft); }
.cart-row:last-child{ border-bottom:0; }
.cart-thumb{ width:88px; height:88px; border-radius:6px; background:repeating-linear-gradient(135deg,#EFEFEF 0 6px,#EFEFEF 6px 12px); position:relative; overflow:hidden; }
.cart-thumb svg{ position:absolute; inset:0; padding:10px; width:100%; height:100%; }
.cart-info .ttl{ font-family:var(--display); font-size:22px; font-weight:340; line-height:1.1; margin:0 0 4px; letter-spacing:-.015em; }
.cart-info .sku{ font-family:var(--mono); font-size:10.5px; letter-spacing:.14em; color:var(--ink-soft); text-transform:uppercase; }
.cart-price{ font-family:var(--display); font-size:18px; font-weight:340; text-align:right; min-width:90px; }
.cart-price small{ font-family:var(--mono); font-size:10px; letter-spacing:.14em; color:var(--ink-soft); display:block; text-transform:uppercase; margin-top:2px; }
.cart-qty{ display:flex; align-items:center; border:1px solid var(--rule); border-radius:999px; }
.cart-qty button{ width:32px; height:34px; color:var(--ink); transition:background .2s ease; }
.cart-qty button:hover{ background:var(--paper-2); border-radius:999px; }
.cart-qty input{ width:36px; text-align:center; border:0; background:transparent; font-family:var(--mono); font-size:13px; font-weight:600; outline:none; }
.cart-remove{ color:var(--ink-soft); font-size:12px; font-family:var(--mono); letter-spacing:.14em; text-transform:uppercase; transition:color .2s ease; }
.cart-remove:hover{ color:var(--red); }

.cart-summary{ background:var(--ink); color:var(--paper); border-radius:10px; padding:32px; position:sticky; top:120px; }
.cart-summary h3{ font-family:var(--mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin:0 0 22px; font-weight:500; }
.cart-summary .ln{ display:flex; justify-content:space-between; padding:12px 0; border-bottom:1px solid rgba(255,255,255,.12); font-size:14px; }
.cart-summary .ln .val{ font-family:var(--mono); font-size:13px; letter-spacing:.06em; }
.cart-summary .ln.total{ font-family:var(--display); font-size:28px; font-weight:340; margin-top:14px; padding-top:18px; border-top:1px solid rgba(255,255,255,.3); border-bottom:0; align-items:baseline; }
.cart-summary .ln.total .val{ font-family:var(--display); font-size:28px; color:var(--gold); letter-spacing:-.01em; }
.cart-summary .checkout-btn{ display:block; width:100%; margin-top:24px; padding:16px; background:var(--gold); color:var(--ink); border-radius:999px; font-weight:600; font-size:14px; letter-spacing:.02em; text-align:center; transition:background .2s ease; }
.cart-summary .checkout-btn:hover{ background:var(--paper); }
.cart-summary .secure{ display:flex; align-items:center; justify-content:center; gap:8px; margin-top:16px; font-family:var(--mono); font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.6); }
@media (max-width:980px){ .cart-shell{ grid-template-columns:1fr; gap:32px; } .cart-summary{ position:static; } .cart-row{ grid-template-columns:64px 1fr; grid-template-rows:auto auto auto; gap:12px 16px; } .cart-thumb{ width:64px; height:64px; grid-row:span 3; } .cart-price, .cart-qty, .cart-remove{ grid-column:2; } }
/* ── WC cart: product image inside thumb cell ── */
.cart-thumb img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; border-radius:6px; }
/* ── WC cart: hide native number-input spinners ── */
.cart-qty input[type="number"]{ -moz-appearance:textfield; }
.cart-qty input[type="number"]::-webkit-inner-spin-button,.cart-qty input[type="number"]::-webkit-outer-spin-button{ -webkit-appearance:none; margin:0; }
/* ── WC cart: variation attributes ── */
.cart-variation{ font-size:11px; color:var(--ink-soft); font-family:var(--mono); letter-spacing:.1em; text-transform:uppercase; margin-top:3px; }
.cart-variation dl,.cart-variation dt,.cart-variation dd{ display:inline; margin:0; padding:0; font-weight:normal; }
.cart-variation dt::after{ content:': '; }
.cart-variation dd+dt::before{ content:' · '; }
.cart-info .ttl a{ color:inherit; text-decoration:none; }
.cart-info .ttl a:hover{ color:var(--blue); }

/* --- checkout --- */
.checkout-shell{ display:grid; grid-template-columns:1.4fr 1fr; gap:48px; padding:48px 0 120px; align-items:start; }
.checkout-form{ background:var(--bone); border:1px solid var(--rule-soft); border-radius:10px; padding:40px; }
.checkout-step{ margin-bottom:34px; }
.checkout-step h3{ display:flex; align-items:center; gap:14px; font-family:var(--display); font-size:26px; font-weight:340; margin:0 0 22px; letter-spacing:-.02em; }
.checkout-step h3 .n{ width:34px; height:34px; border-radius:50%; background:var(--ink); color:var(--paper); font-family:var(--mono); font-size:13px; display:inline-flex; align-items:center; justify-content:center; font-weight:600; }
.checkout-summary{ background:var(--paper-2); border:1px solid var(--rule-soft); border-radius:10px; padding:32px; position:sticky; top:120px; }
.checkout-summary h3{ font-family:var(--mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-deep); margin:0 0 20px; font-weight:500; }
.csum-row{ display:flex; justify-content:space-between; padding:10px 0; font-size:13.5px; border-bottom:1px dashed var(--rule); }
.csum-row.item{ display:grid; grid-template-columns:1fr auto; gap:6px 16px; font-size:13px; }
.csum-row.item .qty{ font-family:var(--mono); font-size:11px; color:var(--ink-soft); letter-spacing:.1em; }
.csum-total{ display:flex; justify-content:space-between; align-items:baseline; margin-top:16px; padding-top:14px; border-top:1.5px solid var(--ink); font-family:var(--display); font-size:24px; font-weight:340; }
.csum-total .val{ color:var(--blue); letter-spacing:-.01em; }
.place-order{ display:block; width:100%; margin-top:24px; padding:16px; background:var(--ink); color:var(--paper); border-radius:999px; font-weight:600; font-size:14px; letter-spacing:.02em; text-align:center; transition:background .2s ease; }
.place-order:hover{ background:var(--blue-deep); }
@media (max-width:980px){ .checkout-shell{ grid-template-columns:1fr; } .checkout-form{ padding:28px; } .checkout-summary{ position:static; } }

/* --- inquiry form additions --- */
/* Select field needs explicit height/appearance to match text input baseline */
.field select{ appearance:none; -webkit-appearance:none; background:transparent url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none' stroke='%231A2E50' stroke-width='1.5'%3E%3Cpath d='M1 1l4 4 4-4'/%3E%3C/svg%3E") no-repeat right 2px center; padding-right:20px; cursor:pointer; }
.inq-notice{ padding:12px 16px; border-radius:6px; font-size:14px; margin-top:8px; }
.inq-notice--error{ background:#fef2f2; border:1px solid #fecaca; color:#991b1b; }

/* --- hide prices site-wide --- */
.cat-card .price,
.pdp-price,
.cart-price,
.cart-summary .ln,
.csum-row.item > div:last-child,
#csumSub,
.csum-total .val,
.pc-meta > span:first-child,
#ototal,
.csum-row:not(.item),
.csum-total { display:none !important; }
/* Confirmation page: show inquiry ref (same shape as order-num) */
.confirm .inq-ref strong{ color:var(--gold); }

/* --- confirmation --- */
.confirm{ padding:96px 0 140px; text-align:center; }
.confirm-icon{ width:96px; height:96px; border-radius:50%; background:var(--gold); color:var(--ink); display:inline-flex; align-items:center; justify-content:center; margin-bottom:28px; box-shadow:0 20px 40px -20px rgba(255,124,1,.6); }
.confirm-icon svg{ width:44px; height:44px; }
.confirm h1{ font-family:var(--display); font-weight:330; font-size:clamp(40px,6vw,82px); line-height:.96; letter-spacing:-.03em; margin:0 0 18px; font-variation-settings:"opsz" 144,"SOFT" 40; }
.confirm h1 em{ font-style:italic; color:var(--blue); }
.confirm p{ font-size:17px; color:var(--ink-soft); max-width:50ch; margin:0 auto 32px; }
.confirm .order-num{ display:inline-flex; gap:10px; align-items:center; padding:10px 22px; background:var(--ink); color:var(--paper); border-radius:999px; font-family:var(--mono); font-size:12px; letter-spacing:.18em; text-transform:uppercase; margin-bottom:40px; }
.confirm .order-num strong{ color:var(--gold); }

/* ============================================================
   ABOUT / DISTRIBUTORS / RESOURCES / INDUSTRIES / CONTACT
   ============================================================ */

/* about */
.about-intro{ padding:80px 0; background:var(--paper); }
.about-intro-grid{ display:grid; grid-template-columns:1fr 1.2fr; gap:60px; align-items:start; }
.about-intro .label{ font-family:var(--mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:18px; }
.about-intro h2{ font-family:var(--display); font-weight:330; font-size:clamp(38px,5vw,68px); line-height:.98; letter-spacing:-.03em; margin:0 0 24px; font-variation-settings:"opsz" 144,"SOFT" 40; }
.about-intro h2 em{ font-style:italic; color:var(--blue); }
.about-intro .body{ font-size:17px; color:var(--ink); line-height:1.62; }
.about-intro .body p + p{ margin-top:18px; }

.timeline{ padding:96px 0; background:var(--paper-2); border-top:1px solid var(--rule); border-bottom:1px solid var(--rule); }
.timeline-list{ position:relative; padding-left:54px; }
.timeline-list::before{ content:""; position:absolute; left:14px; top:8px; bottom:8px; width:1px; background:var(--rule); }
.timeline-row{ position:relative; padding:24px 0; display:grid; grid-template-columns:140px 1fr; gap:32px; align-items:start; }
.timeline-row::before{ content:""; position:absolute; left:-46px; top:34px; width:14px; height:14px; border-radius:50%; background:var(--gold); border:3px solid var(--paper-2); box-shadow:0 0 0 1px var(--gold-deep); }
.timeline-year{ font-family:var(--display); font-style:italic; font-size:36px; font-weight:340; color:var(--blue); letter-spacing:-.02em; }
.timeline-content h4{ font-family:var(--display); font-weight:340; font-size:22px; margin:0 0 6px; letter-spacing:-.01em; }
.timeline-content p{ color:var(--ink-soft); font-size:14.5px; margin:0; max-width:60ch; }

.team{ padding:96px 0; background:var(--paper); }
.team-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:32px; }
.team-card{ background:var(--bone); border:1px solid var(--rule-soft); border-radius:10px; overflow:hidden; }
.team-photo{ aspect-ratio:4/5; background:linear-gradient(160deg,#1A2E50 0%,#1A2E50 100%); position:relative; }
.team-photo .initials{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.6); font-family:var(--display); font-style:italic; font-size:88px; font-weight:300; letter-spacing:-.02em; }
.team-body{ padding:22px 24px 26px; }
.team-body h4{ font-family:var(--display); font-weight:340; font-size:22px; margin:0 0 4px; }
.team-body .role{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:14px; }
.team-body p{ font-size:14px; color:var(--ink-soft); margin:0; }
@media (max-width:980px){ .about-intro-grid{ grid-template-columns:1fr; } .team-grid{ grid-template-columns:1fr 1fr; } .timeline-row{ grid-template-columns:80px 1fr; gap:18px; } .timeline-year{ font-size:24px; } }
@media (max-width:560px){ .team-grid{ grid-template-columns:1fr; } }

/* resources */
.res-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; padding:48px 0 120px; }
.res-card{ background:var(--bone); border:1px solid var(--rule-soft); border-radius:10px; padding:30px; display:flex; flex-direction:column; gap:14px; transition:transform .3s ease, border-color .3s ease, box-shadow .3s ease; }
.res-card:hover{ transform:translateY(-4px); border-color:var(--ink); box-shadow:var(--shadow-2); }
.res-card .type{ font-family:var(--mono); font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-deep); }
.res-card h3{ font-family:var(--display); font-weight:340; font-size:26px; line-height:1.1; letter-spacing:-.02em; margin:0; }
.res-card h3 em{ font-style:italic; color:var(--blue); }
.res-card p{ font-size:14px; color:var(--ink-soft); margin:0; }
.res-card .meta{ display:flex; gap:14px; font-family:var(--mono); font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft); padding-top:14px; border-top:1px solid var(--rule); margin-top:auto; }
.res-card .meta span::before{ content:"· "; color:var(--gold-deep); }
.res-card .meta span:first-child::before{ display:none; }
@media (max-width:980px){ .res-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .res-grid{ grid-template-columns:1fr; } }

/* contact */
.contact-shell{ display:grid; grid-template-columns:1fr 1.2fr; gap:60px; padding:48px 0 120px; align-items:start; }
.contact-aside h3{ font-family:var(--display); font-weight:340; font-size:34px; line-height:1.30; letter-spacing:-.02em; margin:0 0 16px; }
.contact-aside h3 em{ font-style:italic; color:var(--blue); }
.contact-aside p{ color:var(--ink-soft); margin:0 0 32px; max-width:38ch; }
.contact-card{ background:var(--bone); border:1px solid var(--rule-soft); border-radius:10px; padding:24px; margin-bottom:18px; }
.contact-card .ttl{ font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:14px; display:flex; align-items:center; gap:10px; }
.contact-card .ttl::before{ content:""; width:10px; height:10px; border-radius:50%; background:var(--gold); }
.contact-card address{ font-style:normal; font-size:14.5px; line-height:1.6; }
.contact-card address strong{ display:block; margin-bottom:6px; }
.contact-card a{ color:var(--blue); border-bottom:1px solid currentColor; }



/* =========================================================
   v2 ADDITIONS — real product photos, richer PDP, filterable
   ========================================================= */

/* product detail v2: real photo gallery */
.pdp-v2 .pdp-photo{
  position:relative; background:linear-gradient(160deg,#0F1F3A 0%,#1A2E50 100%);
  border-radius:12px; overflow:hidden; box-shadow:var(--shadow-2);
  aspect-ratio:1/1;
}
.pdp-v2 .pdp-photo img{ width:100%; height:100%; object-fit:contain; padding:6%; }
.pdp-v2 .pdp-photo .badge{
  position:absolute; top:18px; left:18px; z-index:2;
  background:var(--gold); color:var(--ink);
  font-family:var(--mono); font-size:10.5px; letter-spacing:.18em; text-transform:uppercase;
  padding:6px 12px; border-radius:999px; font-weight:600;
}
.pdp-v2 .pdp-photo figcaption{
  position:absolute; bottom:18px; left:18px; right:18px;
  color:rgba(255,255,255,.78); font-family:var(--mono);
  font-size:10.5px; letter-spacing:.18em; text-transform:uppercase;
  display:flex; justify-content:space-between; gap:12px;
}
.pdp-v2 .pdp-strip{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-top:14px; }
.pdp-v2 .strip-item{
  aspect-ratio:1/1; border-radius:8px; border:1.5px solid var(--rule);
  overflow:hidden; cursor:pointer; background:var(--paper-2);
  display:flex; align-items:center; justify-content:center; text-align:center;
  font-family:var(--mono); font-size:10px; letter-spacing:.12em; color:var(--ink-soft);
  padding:8px;
}
.pdp-v2 .strip-item img{ width:100%; height:100%; object-fit:cover; }
.pdp-v2 .strip-item.on{ border-color:var(--ink); }

/* richer info column */
.pdp-v2 .pdp-info .copy{
  font-size:15px; line-height:1.65; color:var(--ink-soft); margin:12px 0 22px;
}
.pdp-v2 .pdp-pricecard{
  display:flex; justify-content:space-between; align-items:flex-end; gap:24px;
  padding:22px; border-radius:12px; background:var(--paper-2);
  border:1px solid var(--rule-soft); margin:22px 0 18px;
}
.pdp-v2 .pdp-stock{ display:flex; align-items:center; gap:8px; font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-soft); }
.pdp-v2 .pdp-stock .dot{ width:8px; height:8px; border-radius:50%; background:var(--green); box-shadow:0 0 0 4px rgba(74,222,128,.18); }
.pdp-v2 .pdp-price{ font-family:var(--display); font-size:42px; line-height:1; color:var(--ink); margin-top:8px; }
.pdp-v2 .pdp-price small{ display:block; font-family:var(--sans); font-size:12px; font-weight:400; color:var(--ink-soft); margin-top:6px; letter-spacing:.02em; }
.pdp-v2 .pdp-cert{ display:flex; flex-direction:column; gap:4px; align-items:flex-end; }
.pdp-v2 .pdp-cert span{ font-family:var(--mono); font-size:11px; letter-spacing:.18em; color:var(--ink-soft); padding:4px 10px; border:1px solid var(--rule); border-radius:999px; }

.pdp-v2 .pdp-actions{ display:flex; flex-wrap:wrap; gap:12px; align-items:center; margin:8px 0 24px; }
.pdp-v2 .qty-stepper{ display:inline-flex; border:1px solid var(--ink); border-radius:999px; overflow:hidden; }
.pdp-v2 .qty-stepper button{ padding:0 16px; height:48px; background:var(--paper); color:var(--ink); font-size:18px; }
.pdp-v2 .qty-stepper button:hover{ background:var(--ink); color:var(--paper); }
.pdp-v2 .qty-stepper input{ width:50px; height:48px; border:0; text-align:center; font-family:var(--mono); font-size:14px; }
.pdp-v2 .pdp-add{ height:48px; padding:0 24px; border-radius:999px; background:var(--gold); color:var(--ink); font-weight:600; display:inline-flex; align-items:center; gap:8px; transition:background .2s ease, color .2s ease; }
.pdp-v2 .pdp-add:hover{ background:var(--ink); color:var(--paper); }
.pdp-v2 .pdp-add .arr{ transition:transform .25s ease; }
.pdp-v2 .pdp-add:hover .arr{ transform:translateX(4px); }
.pdp-v2 .pdp-quote{ height:48px; padding:0 22px; border-radius:999px; display:inline-flex; align-items:center; border:1px solid var(--ink); color:var(--ink); font-weight:600; }
.pdp-v2 .pdp-quote:hover{ background:var(--ink); color:var(--paper); }

/* highlight bullets — fact list (redesigned: full-width single column, generous text column) */
.pdp-bullets-v2{ display:block; grid-template-columns:none; list-style:none; padding:0; margin:8px 0 32px; border-top:1px solid var(--rule-soft); }
.pdp-bullets-v2 li{ display:grid; grid-template-columns:200px 1fr; gap:28px;
  padding:16px 0 16px 22px; border-bottom:1px solid var(--rule-soft); position:relative; }
.pdp-bullets-v2 li::before{ content:""; position:absolute; left:0; top:22px; width:9px; height:9px; border:1.5px solid var(--gold-deep); border-radius:50%; background:var(--paper); }
.pdp-bullets-v2 li strong{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--blue); align-self:start; padding-top:3px; line-height:1.45; }
.pdp-bullets-v2 li span{ font-size:14.5px; line-height:1.65; color:var(--ink); }
@media (max-width:720px){ .pdp-bullets-v2 li{ grid-template-columns:1fr; gap:6px; padding-left:22px; } .pdp-bullets-v2 li::before{ top:19px; } }

/* customer reviews block */
.pdp-reviews{ background:var(--paper); border-top:1px solid var(--rule); padding:64px 0 88px; }
/*.pdp-reviews .wrap{ max-width:1280px; }*/
.rev-head{ display:grid; grid-template-columns:1fr auto; gap:32px; align-items:end; margin-bottom:36px; padding-bottom:24px; border-bottom:1px solid var(--rule-soft); }
.rev-head .kicker{ font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:8px; }
.rev-head h2{ font-family:var(--serif); font-weight:400; font-size:clamp(34px, 4.4vw, 56px); line-height:1.02; letter-spacing:-.01em; color:var(--ink); margin:0; }
.rev-head h2 em{ font-style:italic; color:var(--blue); }
.rev-summary{ display:flex; align-items:center; gap:18px; padding:14px 20px; border:1px solid var(--rule); border-radius:14px; background:#fff; }
.rev-summary .rev-score{ font-family:var(--serif); font-size:42px; line-height:1; color:var(--blue); font-weight:500; }
.rev-summary .rev-score small{ font-size:18px; color:var(--ink-soft); margin-left:2px; }
.rev-summary .rev-meta{ display:flex; flex-direction:column; gap:4px; }
.rev-summary .rev-stars{ color:var(--gold-deep); letter-spacing:2px; font-size:16px; }
.rev-summary .rev-count{ font-family:var(--mono); font-size:11px; letter-spacing:.06em; color:var(--ink-soft); }
.rev-grid{ display:grid; grid-template-columns:repeat(auto-fit, minmax(280px, 1fr)); gap:18px; }
.rev-card{ background:#fff; border:1px solid var(--rule); border-radius:14px; padding:22px 22px 18px; display:flex; flex-direction:column; gap:10px; transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.rev-card:hover{ transform:translateY(-2px); border-color:var(--ink-soft); box-shadow:0 12px 28px -18px rgba(0,0,0,.18); }
.rev-card .rev-stars{ color:var(--gold-deep); letter-spacing:2px; font-size:14px; }
.rev-card h4{ font-family:var(--serif); font-weight:500; font-size:19px; line-height:1.25; letter-spacing:-.005em; color:var(--ink); margin:0; }
.rev-card p{ font-size:14px; line-height:1.6; color:var(--ink); margin:0; flex:1; }
.rev-card footer{ display:flex; justify-content:space-between; align-items:baseline; gap:12px; margin-top:8px; padding-top:12px; border-top:1px dashed var(--rule-soft); font-family:var(--mono); font-size:11px; letter-spacing:.04em; color:var(--ink-soft); }
.rev-card footer .who{ color:var(--ink); }
.rev-card footer .who em{ display:block; font-style:normal; font-size:10px; color:var(--ink-soft); letter-spacing:.06em; margin-top:2px; }
.rev-cta-row{ margin-top:32px; padding-top:24px; border-top:1px solid var(--rule-soft); display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:16px; }
.rev-cta-row p{ font-size:14px; color:var(--ink-soft); margin:0; max-width:520px; }
.rev-cta{ display:inline-flex; align-items:center; gap:10px; padding:0 22px; height:46px; border-radius:999px; background:var(--ink); color:var(--paper); font-weight:600; font-size:14px; letter-spacing:.01em; }
.rev-cta:hover{ background:var(--blue); color:var(--paper); }
@media (max-width:720px){ .rev-head{ grid-template-columns:1fr; align-items:start; } .rev-summary{ justify-content:flex-start; } }

/* tabs (override default) */
.pdp-v2 .pdp-tabs{ margin-top:6px; border-top:1px solid var(--rule); padding-top:24px; }
.pdp-v2 .pdp-tab-btns{ display:flex; gap:24px; border-bottom:1px solid var(--rule-soft); margin-bottom:16px; }
.pdp-v2 .pdp-tab-btns button{ padding:10px 0; font-size:13px; letter-spacing:.04em; color:var(--ink-soft); border-bottom:2px solid transparent; }
.pdp-v2 .pdp-tab-btns button.on{ color:var(--ink); border-bottom-color:var(--gold); }
.pdp-v2 .pdp-tab-panel{ display:none; font-size:14.5px; line-height:1.65; color:var(--ink); }
.pdp-v2 .pdp-tab-panel.on{ display:block; }
.pdp-v2 .spec-table{ width:100%; border-collapse:collapse; }
.pdp-v2 .spec-table th, .pdp-v2 .spec-table td{ text-align:left; padding:10px 0; border-bottom:1px solid var(--rule-soft); font-size:14px; }
.pdp-v2 .spec-table th{ width:42%; font-weight:600; color:var(--ink-soft); font-family:var(--mono); font-size:11.5px; letter-spacing:.1em; text-transform:uppercase; }

/* related products strip */
.rel{ padding:36px 0 96px; background:var(--paper-2); border-top:1px solid var(--rule-soft); }
.rel-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; margin-bottom:24px; }
.rel-head .h2{ font-family:var(--display); font-weight:340; font-size:clamp(28px,3.4vw,42px); line-height:1; letter-spacing:-.025em; margin:6px 0 0; }
.rel-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.rel-card{ background:var(--paper); border:1px solid var(--rule-soft); border-radius:10px; overflow:hidden; transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.rel-card:hover{ transform:translateY(-3px); border-color:var(--ink); box-shadow:var(--shadow-1); }
.rel-img{ aspect-ratio:1/1; background:linear-gradient(160deg,#1A2E50,#0F1F3A); }
.rel-img img{ width:100%; height:100%; object-fit:contain; padding:14%; }
.rel-meta{ padding:14px 16px 18px; }
.rel-cat{ font-family:var(--mono); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:6px; }
.rel-name{ font-size:14.5px; font-weight:600; color:var(--ink); }
@media (max-width:900px){ .rel-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .rel-grid{ grid-template-columns:1fr; } }

/* catalog v2 — real photo cards */
.cat-grid-v2{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
@media (max-width:980px){ .cat-grid-v2{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .cat-grid-v2{ grid-template-columns:1fr; } }
.cat-card-v2{ background:var(--paper); border:1px solid var(--rule-soft); border-radius:12px; overflow:hidden;
  display:flex; flex-direction:column; transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.cat-card-v2:hover{ transform:translateY(-4px); border-color:var(--ink); box-shadow:var(--shadow-2); }
.cat-card-v2 .img{ position:relative; aspect-ratio:4/3; background:linear-gradient(160deg,#0F1F3A,#1A2E50); display:block; overflow:hidden; }
.cat-card-v2 .img img{ width:100%; height:100%; object-fit:contain; padding:10%; transition:transform .4s ease; }
.cat-card-v2:hover .img img{ transform:scale(1.05); }
.cat-card-v2 .img .badge{ position:absolute; top:14px; left:14px; z-index:2; background:var(--gold); color:var(--ink); font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; padding:5px 10px; border-radius:999px; font-weight:600; }
.cat-card-v2 .body{ padding:18px 20px 20px; display:flex; flex-direction:column; flex:1; }
.cat-card-v2 .body .cat{ font-family:var(--mono); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:8px; }
.cat-card-v2 .body .ttl{ font-family:var(--display); font-weight:340; font-size:24px; line-height:1.5; letter-spacing:-.02em; margin:0 0 8px; }
.cat-card-v2 .body .ttl em{ font-style:italic; color:var(--blue); }
.cat-card-v2 .body .ttl a{ color:inherit; }
.cat-card-v2 .body .desc{ font-size:13.5px; line-height:1.55; color:var(--ink-soft); margin:0 0 16px; flex:1; }
.cat-card-v2 .foot{ display:flex; justify-content:flex-end; align-items:center; gap:12px; }
.cat-card-v2 .foot .price{ font-family:var(--display); font-size:22px; color:var(--ink); line-height:1; }
.cat-card-v2 .foot .price small{ display:block; font-family:var(--sans); font-size:10.5px; font-weight:400; color:var(--ink-soft); margin-top:4px; letter-spacing:.02em; }
.cat-card-v2 .foot .add{ background:var(--ink); color:var(--paper); padding:10px 16px; border-radius:999px; font-size:12.5px; font-weight:600; letter-spacing:.01em; transition:background .2s ease; }
.cat-card-v2 .foot .add:hover{ background:var(--gold); color:var(--ink); }

.cat-toolbar{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:16px; margin:20px 0 26px; }
.cat-toolbar .filters{ display:flex; gap:8px; flex-wrap:wrap; }
.cat-toolbar .filter{ padding:8px 14px; border-radius:999px; border:1px solid var(--rule); font-size:13px; font-weight:500; color:var(--ink-soft); background:var(--paper); transition:all .2s ease; }
.cat-toolbar .filter.on, .cat-toolbar .filter:hover{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.cat-toolbar .sort-by{ font-family:var(--mono); font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); }

/* responsive layout fix for pdp-shell on small screens */
@media (max-width:980px){
  .pdp-shell{ grid-template-columns:1fr; gap:36px; }
  .pdp-v2 .pdp-pricecard{ flex-direction:column; align-items:flex-start; }
  .pdp-v2 .pdp-cert{ flex-direction:row; align-items:center; }
}

/* -- Dynamic catalogue: filter links, sort select, count, pagination, no-results -- */
.cat-toolbar a.filter{ text-decoration:none; display:inline-flex; align-items:center; }
.sort-select{ appearance:none; -webkit-appearance:none; font-family:var(--mono); font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink); background:transparent url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none' stroke='%231A2E50' stroke-width='1.5'%3E%3Cpath d='M1 1l4 4 4-4'/%3E%3C/svg%3E") no-repeat right 2px center; padding-right:20px; border:none; outline:none; cursor:pointer; }
.sort-select:focus-visible{ outline:2px solid var(--ink); outline-offset:3px; border-radius:3px; }
.cat-count{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); margin:0 0 22px; }
.cat-no-results{ grid-column:1/-1; padding:72px 0; text-align:center; }
.cat-no-results p{ font-size:15px; color:var(--ink-soft); margin-bottom:24px; }
.cat-pagination{ display:flex; justify-content:center; align-items:center; gap:6px; padding:48px 0 24px; flex-wrap:wrap; }
.cat-pagination .page-btn,
.cat-pagination .page-num{ min-width:36px; height:36px; display:inline-flex; align-items:center; justify-content:center; border-radius:6px; font-family:var(--mono); font-size:12px; letter-spacing:.06em; text-decoration:none; border:1px solid var(--rule); color:var(--ink-soft); transition:all .18s ease; }
.cat-pagination .page-btn:not(.disabled):hover,
.cat-pagination .page-num:not(.current):hover{ border-color:var(--ink); color:var(--ink); }
.cat-pagination .page-num.current{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.cat-pagination .page-btn.disabled{ opacity:.35; pointer-events:none; }
.cat-pagination .page-ellipsis{ min-width:28px; display:inline-flex; align-items:center; justify-content:center; color:var(--ink-soft); font-family:var(--mono); font-size:13px; }

.woocommerce form .form-row::after, .woocommerce form .form-row::before, .woocommerce-page form .form-row::after, .woocommerce-page form .form-row::before {
  content: unset !important;
}
/* ============================================================
   DIRECTIVES — Video gallery
============================================================ */
.sr-only{ position:absolute !important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
.section-head-tight{ margin-top:48px; margin-bottom:18px; display:flex; align-items:end; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.section-head-tight .h3{ font-family:var(--display); font-weight:330; font-size:clamp(24px,2.6vw,34px); line-height:1; letter-spacing:-.02em; margin:8px 0 0; }

/* Player */
.directive-player{ margin-top:24px; border:1px solid var(--rule); border-radius:14px; overflow:hidden; background:#000; box-shadow:0 30px 80px -50px rgba(0,0,0,.35); }
.directive-player-frame{ position:relative; width:100%; aspect-ratio:16/9; background:#000; }
.directive-player-frame iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; display:block; }
.directive-player-meta{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding:12px 16px; background:#0d0d0d; color:#f5f5f5; flex-wrap:wrap; }
.directive-pill{ display:inline-flex; align-items:center; gap:8px; padding:6px 12px; border-radius:999px; font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; background:rgba(255,255,255,.08); color:#f5f5f5; border:1px solid rgba(255,255,255,.14); text-decoration:none; transition:background .18s ease, border-color .18s ease; }
.directive-pill-link:hover{ background:rgba(255,255,255,.16); border-color:rgba(255,255,255,.32); }

/* Search */
.directive-filter input{ height:42px; padding:0 16px; min-width:260px; max-width:340px; border:1px solid var(--rule); border-radius:999px; font-family:var(--sans, inherit); font-size:14px; color:var(--ink); background:transparent; transition:border-color .18s ease, box-shadow .18s ease; }
.directive-filter input:focus{ outline:none; border-color:var(--ink); box-shadow:0 0 0 3px rgba(0,0,0,.05); }
.directive-filter input::placeholder{ color:var(--ink-soft); }

/* Grid */
.directive-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(260px, 1fr)); gap:22px; margin-top:18px; }
.directive-card{ display:flex; flex-direction:column; gap:14px; padding:0; background:transparent; border:0; text-align:left; font:inherit; color:inherit; cursor:pointer; }
.directive-card:focus-visible{ outline:2px solid var(--ink); outline-offset:4px; border-radius:10px; }

.directive-thumb{ position:relative; display:block; aspect-ratio:16/9; overflow:hidden; border-radius:10px; background:#111; border:1px solid var(--rule); transition:border-color .18s ease, transform .25s ease; }
.directive-thumb img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .4s ease, filter .25s ease; filter:saturate(.92); }
.directive-card:hover .directive-thumb{ border-color:var(--ink); }
.directive-card:hover .directive-thumb img{ transform:scale(1.04); filter:saturate(1.05); }

.directive-play{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; color:#fff; background:linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.35) 100%); opacity:.92; transition:opacity .2s ease, transform .2s ease; }
.directive-play svg{ width:54px; height:54px; filter:drop-shadow(0 6px 14px rgba(0,0,0,.5)); transition:transform .25s ease; }
.directive-card:hover .directive-play svg{ transform:scale(1.08); }

.directive-index{ position:absolute; top:10px; left:12px; font-family:var(--mono); font-size:11px; letter-spacing:.1em; color:#fff; background:rgba(0,0,0,.55); backdrop-filter:blur(6px); padding:4px 8px; border-radius:4px; }

.directive-card.is-active .directive-thumb{ border-color:var(--ink); box-shadow:0 0 0 2px var(--ink); }
.directive-card.is-active .directive-play{ background:linear-gradient(180deg, rgba(0,0,0,.2) 0%, rgba(0,0,0,.55) 100%); }

.directive-body{ display:flex; flex-direction:column; gap:4px; }
.directive-title{ font-family:var(--display); font-weight:430; font-size:17px; line-height:1.25; letter-spacing:-.01em; color:var(--ink); }
.directive-sub{ font-size:13px; line-height:1.5; color:var(--ink-soft); }

.directive-empty-results{ text-align:center; padding:48px 0; color:var(--ink-soft); font-size:14px; }

/* Empty (no videos) */
.directives-empty{ padding-top:24px; }
.directives-empty-card{ padding:48px; border:1px dashed var(--rule); border-radius:14px; text-align:center; max-width:680px; margin:0 auto; }
.directives-empty-card .h2{ font-family:var(--display); font-weight:330; font-size:clamp(28px,3.4vw,40px); line-height:1; letter-spacing:-.02em; margin:12px 0 16px; }
.directives-empty-card p{ color:var(--ink-soft); max-width:540px; margin:0 auto 24px; }

@media (max-width: 720px){
  .directive-grid{ grid-template-columns:repeat(auto-fill, minmax(220px, 1fr)); gap:18px; }
  .directive-filter input{ min-width:0; width:100%; }
  .section-head-tight{ flex-direction:column; align-items:flex-start; }
  .directive-play svg{ width:44px; height:44px; }
}

.hero-photo__img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    z-index: 0;
}
 
/* Make sure content inside sits above the image */
.hero-photo > *:not(.hero-photo__img) {
    position: relative;
    z-index: 1;
}
 
/* ============================================================
   ADD-TO-CART — error/feedback state
============================================================ */
[data-add-cart].add-err{ background:#b8332a !important; color:#fff !important; border-color:#b8332a !important; }
[data-add-cart][disabled]{ cursor:wait; opacity:.85; }

/* ============================================================
   GLOBAL SECTIONS (rendered from ACF options on every page
   except product / shop / cart / checkout / my-account)
============================================================ */
.mts-global-sections{ display:block; }
.mts-gs{ padding:clamp(56px, 7vw, 96px) 0; border-top:1px solid var(--rule); position:relative; }
.mts-gs:first-child{ border-top:0; }

.mts-gs-eyebrow{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:14px; }
.mts-gs-title{ font-family:var(--display); font-weight:330; font-size:clamp(28px, 4vw, 52px); line-height:1; letter-spacing:-.025em; margin:0 0 14px; color:var(--ink); }
.mts-gs-title em{ font-style:italic; }
.mts-gs-sub{ font-size:clamp(15px, 1.2vw, 17px); line-height:1.55; color:var(--ink-soft); max-width:62ch; margin:0 0 20px; }
.mts-gs-head{ margin-bottom:36px; max-width:780px; }
.mts-gs-btn{ display:inline-flex; align-items:center; gap:8px; margin-top:8px; }

/* -- CTA Banner ------------------------------------------- */
.mts-gs-cta{ background-color:#111; color:#f5f5f5; background-size:cover; background-position:center; }
.mts-gs-cta--light{ background-color:var(--paper, #f6f4ef); color:var(--ink); }
.mts-gs-cta--dark{ color:#f5f5f5; }
.mts-gs-cta--dark .mts-gs-title{ color:#fff; }
.mts-gs-cta--dark .mts-gs-sub{ color:rgba(255,255,255,.78); }
.mts-gs-cta--dark .mts-gs-eyebrow{ color:rgba(255,255,255,.6); }
.mts-gs-cta-inner{ max-width:880px; text-align:left; }

/* -- Testimonials ----------------------------------------- */
.mts-gs-test-grid{ display:grid; grid-template-columns:repeat(auto-fit, minmax(280px, 1fr)); gap:22px; }
.mts-gs-test-card{ margin:0; padding:28px 28px 24px; background:#fff; border:1px solid var(--rule); border-radius:14px; display:flex; flex-direction:column; gap:18px; box-shadow:0 14px 40px -34px rgba(0,0,0,.25); }
.mts-gs-test-card blockquote{ margin:0; font-family:var(--display); font-weight:330; font-size:clamp(17px, 1.5vw, 21px); line-height:1.4; letter-spacing:-.01em; color:var(--ink); }
.mts-gs-test-card figcaption{ display:flex; flex-direction:column; gap:2px; padding-top:14px; border-top:1px solid var(--rule); font-size:13px; }
.mts-gs-test-card .who{ font-weight:600; color:var(--ink); }
.mts-gs-test-card .role{ color:var(--ink-soft); }

/* -- Newsletter ------------------------------------------- */
.mts-gs-news{ background:linear-gradient(180deg, transparent 0%, rgba(0,0,0,.02) 100%); }
.mts-gs-news-inner{ display:grid; grid-template-columns:1.2fr 1fr; gap:48px; align-items:center; }
.mts-gs-news-form{ display:flex; gap:8px; max-width:480px; }
.mts-gs-news-form input{ flex:1; min-width:0; height:48px; padding:0 16px; border:1px solid var(--rule); border-radius:999px; font-size:14px; font-family:inherit; background:#fff; color:var(--ink); transition:border-color .18s ease; }
.mts-gs-news-form input:focus{ outline:none; border-color:var(--ink); }
.mts-gs-news-form button{ height:48px; padding:0 24px; border:0; border-radius:999px; background:var(--ink); color:var(--paper, #fff); font-family:var(--mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase; cursor:pointer; transition:transform .18s ease, background .18s ease; }
.mts-gs-news-form button:hover{ transform:translateY(-1px); }
@media (max-width: 780px){ .mts-gs-news-inner{ grid-template-columns:1fr; gap:24px; } }

/* -- Logo Bar --------------------------------------------- */
.mts-gs-logos{ padding:clamp(40px, 5vw, 64px) 0; }
.mts-gs-logos-head{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); text-align:center; margin-bottom:28px; }
.mts-gs-logos-row{ display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:36px 56px; }
.mts-gs-logo{ display:inline-flex; align-items:center; opacity:.62; transition:opacity .2s ease, filter .2s ease; filter:grayscale(100%); }
.mts-gs-logo:hover{ opacity:1; filter:grayscale(0%); }
.mts-gs-logo img{ max-height:38px; width:auto; display:block; }
.mts-gs-logo--text{ font-family:var(--display); font-weight:430; font-size:18px; letter-spacing:-.01em; color:var(--ink-soft); }

/* -- Image + Text Band ------------------------------------ */
.mts-gs-band-inner{ display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }
.mts-gs-band--left .mts-gs-band-img{ order:1; }
.mts-gs-band--left .mts-gs-band-text{ order:2; }
.mts-gs-band--right .mts-gs-band-img{ order:2; }
.mts-gs-band--right .mts-gs-band-text{ order:1; }
.mts-gs-band-img img{ width:100%; height:auto; display:block; border-radius:14px; box-shadow:0 30px 80px -50px rgba(0,0,0,.35); }
.mts-gs-band-text{ max-width:560px; }
@media (max-width: 860px){ .mts-gs-band-inner{ grid-template-columns:1fr; gap:32px; } .mts-gs-band--left .mts-gs-band-img, .mts-gs-band--right .mts-gs-band-img{ order:1; } .mts-gs-band--left .mts-gs-band-text, .mts-gs-band--right .mts-gs-band-text{ order:2; } }

/* -- Stats Band ------------------------------------------- */
.mts-gs-stats-grid{ display:grid; gap:24px; grid-template-columns:repeat(auto-fit, minmax(180px, 1fr)); }
.mts-gs-stat{ padding:24px 0; border-top:1px solid var(--rule); }
.mts-gs-stat-v{ font-family:var(--display); font-weight:330; font-size:clamp(38px, 4.6vw, 64px); line-height:1; letter-spacing:-.03em; color:var(--ink); }
.mts-gs-stat-v em{ font-style:normal; font-size:.45em; color:var(--ink-soft); margin-left:6px; letter-spacing:-.01em; }
.mts-gs-stat-l{ margin-top:10px; font-size:13px; color:var(--ink-soft); line-height:1.5; }
.brand .custom-logo {
    height: 50px;   /* slightly less than 79px header */
    width: auto;
    display: block;
}
.brand {
    display: flex;
    align-items: center;
}

.brand .custom-logo-link {
    display: flex;
    align-items: center;
}

.brand .custom-logo {
    height: 50px;
    width: auto;
    display: block;
}
@media (max-width: 625px) {
    .request-quote-header {
        display: none;
    }
}