/* =========================================================
   SM Magnetics — Modern, Apple-inspired stylesheet
   ========================================================= */

:root{
  --bg: #fbfbfd;
  --bg-gray: #f4f5f7;
  --bg-dark: #02344b;        /* SM Magnetics navy */
  --bg-black: #011a26;       /* deeper navy */
  --ink: #02344b;            /* navy as primary text on light */
  --ink-soft: #5a6b78;
  --line: #d6dde2;
  --line-dark: rgba(255,255,255,.14);
  --accent: #8a1a27;         /* SM Magnetics maroon */
  --accent-2: #b31427;       /* brighter red highlight */
  --accent-3: #d63a4a;       /* warm red for gradients */
  --navy: #02344b;
  --navy-deep: #011a26;
  --radius: 18px;
  --radius-lg: 28px;
  --shadow: 0 30px 80px -30px rgba(2,52,75,.35);
  --max: 1240px;
  --pad: clamp(20px, 4vw, 48px);
  --ease: cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility}
body{
  margin:0;
  font-family:'Inter','SF Pro Text','-apple-system',BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  font-size:17px;
  line-height:1.5;
  color:var(--ink);
  background:var(--bg);
  overflow-x:hidden;
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
button{font:inherit; cursor:pointer; border:0; background:none; color:inherit}

.container{max-width:var(--max); margin:0 auto; padding:0 var(--pad)}

/* ---------- Typography ---------- */
.display{
  font-weight:800;
  font-size:clamp(48px, 9vw, 128px);
  line-height:.95;
  letter-spacing:-0.04em;
  margin:0 0 24px;
}
.display--sm{font-size:clamp(40px, 6.5vw, 88px)}
.headline{
  font-weight:700;
  font-size:clamp(36px, 5.6vw, 76px);
  line-height:1.02;
  letter-spacing:-0.03em;
  margin:0 0 18px;
}
.headline--md{font-size:clamp(30px, 4vw, 56px)}
.eyebrow{
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:12px;
  font-weight:600;
  color:var(--accent);
  margin:0 0 18px;
}
.eyebrow--light{color:#ff8c98}
.lede{font-size:clamp(18px, 1.6vw, 22px); color:var(--ink-soft); max-width:620px; margin:0 0 36px}
.sub{font-size:clamp(17px, 1.3vw, 20px); color:var(--ink-soft); max-width:680px; margin:0 0 32px}
.sub--light{color:rgba(255,255,255,.72)}
.grad{
  background:linear-gradient(90deg,var(--accent) 0%, var(--accent-2) 55%, var(--accent-3) 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

/* ---------- Banner ---------- */
.banner{
  background:var(--navy-deep); color:#dfe6ec;
  text-align:center; padding:10px 16px;
  font-size:13px; font-weight:500;
}
.banner a{color:#ff8c98; margin-left:6px}
.banner a:hover{text-decoration:underline}

/* ---------- Navigation ---------- */
.nav{
  position:sticky; top:0; z-index:50;
  background:rgba(251,251,253,.72);
  backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
  border-bottom:1px solid transparent;
  transition:border-color .3s var(--ease), background .3s var(--ease);
}
.nav.is-stuck{border-bottom-color:rgba(0,0,0,.08)}
.nav__inner{
  max-width:var(--max); margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px var(--pad); gap:24px;
}
.nav__brand{display:flex; align-items:center; gap:10px; font-weight:700; letter-spacing:-.01em; font-size:17px}
.nav__logo{height:32px; width:auto; display:block}
.nav__logo--footer{height:38px; background:#fff; padding:8px 12px; border-radius:8px}
.nav__links{display:flex; gap:32px}
.nav__links a{font-size:14px; color:var(--ink); opacity:.84; transition:opacity .2s}
.nav__links a:hover{opacity:1; color:var(--accent)}
.nav__cta{
  background:var(--accent); color:#fff;
  padding:10px 18px; border-radius:999px;
  font-size:13px; font-weight:600;
  transition:transform .2s var(--ease), background .2s;
}
.nav__cta:hover{background:var(--accent-2); transform:translateY(-1px)}
.nav__menu{display:none; flex-direction:column; gap:5px; padding:8px}
.nav__menu span{width:22px; height:2px; background:var(--ink); border-radius:2px; transition:transform .25s, opacity .2s}
.nav__menu.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__menu.is-open span:nth-child(2){opacity:0}
.nav__menu.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav__mobile{
  display:none; flex-direction:column; gap:4px;
  padding:8px var(--pad) 24px;
  border-top:1px solid var(--line);
}
.nav__mobile.is-open{display:flex}
.nav__mobile a{padding:14px 4px; font-size:18px; font-weight:600; border-bottom:1px solid var(--line)}

@media (max-width: 880px){
  .nav__links, .nav__cta{display:none}
  .nav__menu{display:flex}
}

/* ---------- Buttons & links ---------- */
.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:14px 26px; border-radius:999px;
  font-weight:600; font-size:15px;
  transition:transform .2s var(--ease), background .2s, color .2s, box-shadow .25s;
}
.btn span{transition:transform .25s var(--ease)}
.btn:hover span{transform:translateX(4px)}
.btn--primary{background:var(--accent); color:#fff; box-shadow:0 10px 26px -10px rgba(138,26,39,.6)}
.btn--primary:hover{background:var(--accent-2); transform:translateY(-1px)}
.btn--dark{background:var(--navy); color:#fff}
.btn--dark:hover{background:var(--navy-deep)}
.btn--ghost{background:rgba(255,255,255,.1); color:#fff; border:1px solid rgba(255,255,255,.25)}
.btn--ghost:hover{background:rgba(255,255,255,.18)}
.btn--ghost-dark{background:transparent; color:var(--ink); border:1px solid var(--line)}
.btn--ghost-dark:hover{border-color:var(--ink)}
.cta-row{display:flex; flex-wrap:wrap; gap:14px}
.link{color:var(--accent); font-weight:600}
.link span, .cap__more{transition:transform .25s var(--ease); display:inline-block}
.link:hover span{transform:translateX(4px)}
.link--light{color:#ff8c98}

/* ---------- HERO ---------- */
.hero{
  position:relative;
  min-height:92vh;
  display:flex; align-items:center;
  color:#fff;
  isolation:isolate;
  overflow:hidden;
}
.hero__bg{position:absolute; inset:0; z-index:-2}
.hero__bg img{
  width:100%; height:100%; object-fit:cover;
  transform:scale(1.05);
  filter:contrast(1.05) saturate(1.1);
}
.hero::before{
  content:""; position:absolute; inset:0; z-index:-1;
  background:
    radial-gradient(ellipse at 20% 30%, rgba(138,26,39,.55), transparent 55%),
    radial-gradient(ellipse at 80% 70%, rgba(2,52,75,.7), transparent 60%),
    linear-gradient(180deg, rgba(1,26,38,.55) 0%, rgba(1,26,38,.85) 100%);
}
.hero__content{
  max-width:var(--max); margin:0 auto;
  padding:120px var(--pad) 140px;
  width:100%;
}
.hero__content .eyebrow{color:#ff8c98; margin-bottom:24px}
.hero__content .lede{color:rgba(255,255,255,.84)}
.hero__scroll{
  position:absolute; left:50%; bottom:32px; transform:translateX(-50%);
  width:24px; height:38px; border:1.5px solid rgba(255,255,255,.5);
  border-radius:14px;
}
.hero__scroll span{
  position:absolute; left:50%; top:8px; transform:translateX(-50%);
  width:3px; height:8px; background:#fff; border-radius:2px;
  animation:scroll 2s var(--ease) infinite;
}
@keyframes scroll{
  0%{opacity:0; transform:translate(-50%, 0)}
  20%{opacity:1}
  100%{opacity:0; transform:translate(-50%, 14px)}
}

/* ---------- Stats strip ---------- */
.stats{padding:80px 0; background:var(--bg)}
.stats__grid{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:40px;
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  padding:48px 0;
}
.stat__num{
  font-size:clamp(40px, 5vw, 64px);
  font-weight:800; letter-spacing:-.03em;
  background:linear-gradient(135deg, var(--navy), var(--accent));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.stat__label{font-size:15px; color:var(--ink-soft); margin-top:6px}
@media (max-width:880px){
  .stats__grid{grid-template-columns:repeat(2, 1fr); gap:30px}
}

/* ---------- Tile pair (Apple product-tile style) ---------- */
.tiles{padding:8px var(--pad)}
.tiles__grid{
  display:grid; grid-template-columns:1fr 1fr; gap:12px;
  max-width:var(--max); margin:0 auto;
}
.tile{
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  min-height:560px;
  background-size:cover;
  background-position:center;
  isolation:isolate;
  transition:transform .5s var(--ease);
}
.tile::before{
  content:""; position:absolute; inset:0; z-index:0;
  transition:background .4s;
}
.tile--dark::before{background:linear-gradient(180deg, rgba(0,0,0,.1) 0%, rgba(0,0,0,.65) 100%)}
.tile--light::before{background:linear-gradient(180deg, rgba(255,255,255,.05) 0%, rgba(255,255,255,.7) 100%)}
.tile:hover{transform:translateY(-4px)}
.tile__inner{
  position:relative; z-index:1;
  padding:56px 48px;
  height:100%;
  display:flex; flex-direction:column; justify-content:flex-end;
}
.tile--dark .tile__inner{color:#fff}
.tile__title{
  font-size:clamp(34px, 3.5vw, 52px);
  font-weight:700; line-height:1.04;
  letter-spacing:-.025em;
  margin:0 0 14px;
}
.tile__sub{font-size:18px; max-width:480px; margin:0 0 22px; opacity:.84}
.tile--light .tile__sub{color:var(--ink-soft); opacity:1}
@media (max-width:880px){
  .tiles__grid{grid-template-columns:1fr}
  .tile{min-height:480px}
  .tile__inner{padding:36px 28px}
}

/* ---------- Generic section helpers ---------- */
.section{padding:140px 0; position:relative}
.section--gray{background:var(--bg-gray)}
.section--dark{background:var(--bg-dark); color:#fff}
.section--dark .sub{color:rgba(255,255,255,.7)}
.section--black{background:var(--bg-black); color:#fff}
.section--black .sub{color:rgba(255,255,255,.7)}
.section__head{max-width:760px; margin:0 0 64px}
.section__head--center{margin:0 auto 56px; text-align:center}
@media (max-width:880px){.section{padding:90px 0}}

/* ---------- Capabilities grid ---------- */
.cap-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:14px;
}
.cap{
  background:#022a3d;
  border-radius:var(--radius);
  overflow:hidden;
  display:flex; flex-direction:column;
  transition:transform .4s var(--ease), box-shadow .4s;
  color:#fff;
}
.cap:hover{transform:translateY(-6px); box-shadow:var(--shadow)}
.cap__img{
  height:240px;
  background-size:cover; background-position:center;
  position:relative;
}
.cap__img::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(0,0,0,.5));
}
.cap__body{padding:28px 28px 32px}
.cap__body h3{font-size:22px; font-weight:600; margin:0 0 8px; letter-spacing:-.01em}
.cap__body p{margin:0 0 16px; color:rgba(255,255,255,.7); font-size:15px}
.cap__more{font-size:13px; font-weight:600; color:#ff8c98}
.cap:hover .cap__more{transform:translateX(4px)}
@media (max-width:980px){.cap-grid{grid-template-columns:repeat(2, 1fr)}}
@media (max-width:640px){.cap-grid{grid-template-columns:1fr}}

/* ---------- Split section ---------- */
.split{
  display:grid; grid-template-columns:1fr 1fr; gap:80px;
  align-items:center;
}
.split--reverse .split__media{order:2}
.split__media img{
  width:100%; border-radius:var(--radius-lg); box-shadow:var(--shadow);
}
.checks{list-style:none; padding:0; margin:0 0 32px; display:grid; gap:10px}
.checks li{position:relative; padding-left:30px; font-size:16px; color:var(--ink)}
.checks li::before{
  content:""; position:absolute; left:0; top:8px;
  width:18px; height:18px; border-radius:50%;
  background:var(--accent); box-shadow:0 0 0 4px rgba(138,26,39,.18);
}
.checks li::after{
  content:""; position:absolute; left:5px; top:12px;
  width:8px; height:5px; border-left:2px solid #fff; border-bottom:2px solid #fff;
  transform:rotate(-45deg);
}
.checks--light li{color:rgba(255,255,255,.85)}
@media (max-width:980px){
  .split{grid-template-columns:1fr; gap:48px}
  .split--reverse .split__media{order:0}
}

/* ---------- Industries horizontal scroller ---------- */
.ind-scroll{
  margin-top:32px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding:8px var(--pad) 24px;
}
.ind-scroll::-webkit-scrollbar{height:6px}
.ind-scroll::-webkit-scrollbar-thumb{background:var(--line); border-radius:3px}
.ind-track{display:flex; gap:18px; min-width:min-content}
.ind{
  flex:0 0 320px;
  background:#fff;
  border-radius:var(--radius);
  padding:32px 28px;
  box-shadow:0 1px 3px rgba(0,0,0,.04), 0 12px 30px -18px rgba(0,0,0,.15);
  scroll-snap-align:start;
  border:1px solid rgba(0,0,0,.04);
  transition:transform .35s var(--ease), box-shadow .35s;
}
.ind:hover{transform:translateY(-4px); box-shadow:0 1px 3px rgba(0,0,0,.04), 0 24px 50px -22px rgba(0,0,0,.25)}
.ind__num{
  font-size:13px; font-weight:600; color:var(--accent);
  letter-spacing:.18em; margin-bottom:14px;
}
.ind h3{font-size:24px; font-weight:600; margin:0 0 10px; letter-spacing:-.01em}
.ind p{margin:0; font-size:15px; color:var(--ink-soft)}

/* ---------- Spotlight ---------- */
.spotlight{
  position:relative;
  min-height:80vh;
  display:flex; align-items:center;
  color:#fff;
  isolation:isolate;
}
.spotlight__bg{
  position:absolute; inset:0; z-index:-2;
  background-size:cover; background-position:center;
}
.spotlight__overlay{
  position:absolute; inset:0; z-index:-1;
  background:linear-gradient(90deg, rgba(0,0,0,.85) 0%, rgba(0,0,0,.4) 70%, transparent 100%);
}
.spotlight__content{
  max-width:var(--max); width:100%;
  margin:0 auto; padding:120px var(--pad);
}
.spotlight__content .headline{max-width:760px}

/* ---------- Custom magnet CTA ---------- */
.custom{
  display:grid; grid-template-columns:1fr 1.2fr; gap:80px; align-items:center;
}
.custom__media img{
  width:100%; border-radius:var(--radius-lg);
  box-shadow:var(--shadow);
}
@media (max-width:980px){.custom{grid-template-columns:1fr; gap:48px}}

/* ---------- Partners ---------- */
.partners{
  display:grid; grid-template-columns:repeat(5, 1fr); gap:30px;
  align-items:center;
}
.partners img{
  max-height:60px; width:auto; margin:0 auto;
  filter:grayscale(1) opacity(.7);
  transition:filter .3s, transform .3s;
}
.partners img:hover{filter:grayscale(0) opacity(1); transform:scale(1.05)}
@media (max-width:880px){.partners{grid-template-columns:repeat(2, 1fr); gap:40px}}

/* ---------- Contact ---------- */
.contact{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  grid-template-areas:
    "lead  form"
    "info  form";
  gap:40px 80px;
}
.contact__lead{grid-area:lead}
.contact__form{grid-area:form; align-self:start; background:rgba(255,255,255,.04); padding:40px; border-radius:var(--radius); border:1px solid var(--line-dark)}
.contact__info{grid-area:info; display:grid; grid-template-columns:1fr 1fr; gap:28px}
.contact__form label{display:block; font-size:13px; font-weight:600; letter-spacing:.04em; color:rgba(255,255,255,.7); margin-bottom:18px}
.contact__form input, .contact__form textarea{
  display:block; width:100%; margin-top:8px;
  background:rgba(255,255,255,.05);
  border:1px solid var(--line-dark);
  color:#fff;
  font:inherit; font-size:16px;
  padding:14px 16px; border-radius:12px;
  transition:border-color .2s, background .2s;
}
.contact__form input:focus, .contact__form textarea:focus{
  outline:none; border-color:var(--accent); background:rgba(138,26,39,.12);
}
.contact__form textarea{resize:vertical; min-height:120px}
.contact__form .btn{margin-top:8px}
.contact__sent{margin-top:14px; color:var(--accent-2); font-weight:600}
.contact__label{font-size:12px; text-transform:uppercase; letter-spacing:.18em; color:#ff8c98; margin:0 0 6px; font-weight:600}
.contact__info p{margin:0; color:rgba(255,255,255,.78); line-height:1.6}
.contact__info a{color:#fff}
.contact__info a:hover{color:#ff8c98}

@media (max-width:980px){
  .contact{grid-template-columns:1fr; grid-template-areas:"lead" "form" "info"}
  .contact__info{grid-template-columns:1fr 1fr}
}

/* ---------- Footer ---------- */
.footer{background:var(--navy-deep); color:#9eb1bf; padding:80px 0 40px}
.footer__inner{display:grid; grid-template-columns:1fr 2fr; gap:60px; align-items:start}
.footer__brand p{margin-top:14px; max-width:300px; font-size:14px}
.footer__brand .nav__brand{color:#fff}
.footer__cols{display:grid; grid-template-columns:repeat(3, 1fr); gap:40px}
.footer__cols h4{color:#fff; font-size:14px; margin:0 0 16px; font-weight:600; letter-spacing:.04em}
.footer__cols a{display:block; padding:6px 0; font-size:13px; color:#9eb1bf; transition:color .2s}
.footer__cols a:hover{color:#fff}
.footer__base{
  display:flex; justify-content:space-between; align-items:center;
  margin-top:60px; padding-top:24px;
  border-top:1px solid var(--line-dark);
  font-size:12px;
}
@media (max-width:880px){
  .footer__inner{grid-template-columns:1fr}
  .footer__cols{grid-template-columns:repeat(3, 1fr); gap:24px}
  .footer__base{flex-direction:column; gap:8px; text-align:center}
}

/* ---------- Reveal animation ---------- */
.reveal{
  opacity:0; transform:translateY(30px);
  transition:opacity .9s var(--ease), transform .9s var(--ease);
}
.reveal.is-visible{opacity:1; transform:none}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1; transform:none; transition:none}
  .hero__scroll span{animation:none}
  html{scroll-behavior:auto}
}
