/* ══════════════════════════════════════════════════════════════
   Brassline — A Model Railway Co.
   Heritage / brass / forest-green visual system
   ══════════════════════════════════════════════════════════════ */

:root{
  /* palette */
  --green-900:#0e1b14;
  --green-800:#16271f;
  --green-700:#1d3328;
  --green-600:#234d35;
  --green-500:#1f3a2c;
  --brass:#c9a24a;
  --brass-light:#e7cf8f;
  --brass-deep:#a8843a;
  --paper:#f4efe4;
  --paper-2:#ece4d4;
  --ink:#10130f;
  --cream:#f7f3ea;
  --rust:#7a3326;

  /* surface tokens (default = dark green) */
  --bg:var(--green-800);
  --fg:#e9e4d6;
  --muted:rgba(233,228,214,.62);
  --line:rgba(201,162,74,.22);
  --card:rgba(255,255,255,.04);

  --wrap:1180px;
  --gut:clamp(20px,5vw,56px);
  --r:16px;
  --r-sm:10px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --shadow:0 24px 60px -28px rgba(0,0,0,.6);

  --font-display:"Fraunces",Georgia,serif;
  --font-sans:"Spline Sans",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  font-family:var(--font-sans);
  background:var(--bg);
  color:var(--fg);
  line-height:1.6;
  font-size:clamp(15px,.5vw + 14px,17px);
  -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-family:inherit;cursor:pointer}
ul{margin:0;padding:0;list-style:none}
h1,h2,h3,h4{margin:0;font-family:var(--font-display);font-weight:600;line-height:1.08;letter-spacing:-.01em}

.wrap{width:min(100% - 2*var(--gut),var(--wrap));margin-inline:auto}
.section{padding:clamp(72px,9vw,128px) 0}

.sr-only,.skip-link{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.skip-link:focus{position:fixed;top:14px;left:14px;width:auto;height:auto;clip:auto;z-index:200;background:var(--brass);color:var(--green-900);padding:10px 16px;border-radius:8px;font-weight:600}
:focus-visible{outline:2px solid var(--brass);outline-offset:3px;border-radius:4px}

/* ── eyebrow / headings ─────────────────────────── */
.eyebrow{
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--brass);font-weight:600;margin:0 0 18px;
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--brass);opacity:.7}
.eyebrow--light{color:var(--brass-light)}

.section__head{max-width:680px;margin-bottom:clamp(40px,5vw,64px)}
.section__head--row{display:flex;flex-wrap:wrap;gap:28px 48px;align-items:flex-end;justify-content:space-between;max-width:none}
.section__title{font-size:clamp(2rem,4.4vw,3.4rem)}
.section__lead{color:var(--muted);font-size:1.06rem;margin:18px 0 0;max-width:56ch}
.section__lead--right{text-align:left;max-width:42ch}

/* ── buttons ────────────────────────────────────── */
.btn{
  --bbg:transparent;--bfg:var(--fg);--bbd:transparent;
  display:inline-flex;align-items:center;gap:.55em;
  background:var(--bbg);color:var(--bfg);border:1px solid var(--bbd);
  padding:.85em 1.5em;border-radius:999px;font-weight:600;font-size:.94rem;
  letter-spacing:.01em;transition:transform .35s var(--ease),background .3s,color .3s,border-color .3s,box-shadow .3s;
  will-change:transform;
}
.btn svg{transition:transform .35s var(--ease)}
.btn:hover{transform:translateY(-2px)}
.btn:hover svg{transform:translateX(4px)}
.btn--brass{--bbg:var(--brass);--bfg:var(--green-900);box-shadow:0 10px 26px -12px rgba(201,162,74,.65)}
.btn--brass:hover{--bbg:var(--brass-light);box-shadow:0 16px 34px -12px rgba(201,162,74,.75)}
.btn--line{--bbd:var(--line);--bfg:var(--fg)}
.btn--line:hover{--bbd:var(--brass);background:rgba(201,162,74,.08)}
.btn--ghost{--bfg:var(--fg);padding:.55em 1.1em;font-size:.88rem}
.btn--ghost:hover{color:var(--brass)}
.btn--mini{--bbd:var(--line);--bfg:var(--fg);padding:.5em 1.05em;font-size:.82rem;border-radius:999px}
.btn--mini:hover{--bbd:var(--brass);background:var(--brass);color:var(--green-900)}

/* ── NAV ────────────────────────────────────────── */
.nav{
  position:sticky;top:0;z-index:100;
  background:rgba(14,27,20,.62);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid transparent;
  transition:background .4s var(--ease),border-color .4s,box-shadow .4s;
}
.nav.is-stuck{background:rgba(14,27,20,.92);border-bottom-color:var(--line);box-shadow:0 10px 30px -22px rgba(0,0,0,.8)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;height:74px;gap:24px}
.brand{display:inline-flex;align-items:center;gap:11px;color:var(--fg)}
.brand__mark{color:var(--brass);display:grid;place-items:center;transition:transform .6s var(--ease)}
.brand:hover .brand__mark{transform:rotate(180deg)}
.brand__type{font-family:var(--font-display);font-weight:600;font-size:1.3rem;letter-spacing:.01em}
.nav__links{display:flex;gap:30px}
.nav__links a{font-size:.92rem;color:var(--muted);position:relative;padding:4px 0;transition:color .3s}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--brass);transition:width .35s var(--ease)}
.nav__links a:hover{color:var(--fg)}
.nav__links a:hover::after{width:100%}
.nav__actions{display:flex;align-items:center;gap:8px}
.nav__cart{background:transparent;border:1px solid var(--line);color:var(--fg);width:40px;height:40px;border-radius:50%;display:grid;place-items:center;transition:border-color .3s,color .3s,transform .3s}
.nav__cart:hover{border-color:var(--brass);color:var(--brass);transform:translateY(-2px)}

@media (max-width:900px){.nav__links{display:none}}

/* ── HERO ───────────────────────────────────────── */
.hero{position:relative;min-height:clamp(640px,94vh,940px);display:flex;flex-direction:column;justify-content:center;overflow:hidden;padding:120px 0 60px}
.hero__scene{position:absolute;inset:0;z-index:0;pointer-events:none}
.layer{position:absolute;inset:0;will-change:transform}
.layer--sky{background:radial-gradient(120% 90% at 70% 8%,#26433200 0%,#0e1b14 78%),linear-gradient(180deg,#1c3527 0%,#16271f 46%,#0e1b14 100%)}
.layer--sky::after{content:"";position:absolute;top:8%;right:14%;width:130px;height:130px;border-radius:50%;background:radial-gradient(circle,rgba(231,207,143,.5),rgba(231,207,143,0) 70%);filter:blur(2px)}
.layer--hills-far,.layer--hills-mid,.layer--fore{display:flex;align-items:flex-end}
.layer--hills-far svg,.layer--hills-mid svg,.layer--fore svg{width:100%;height:62%}
.layer--train{display:flex;align-items:flex-end;justify-content:center;bottom:0}
.loco{width:min(560px,70%);margin-bottom:9%;filter:drop-shadow(0 18px 22px rgba(0,0,0,.45))}
.layer--fore{align-items:flex-end}
.layer--fore svg{height:32%}
.tree{position:absolute;bottom:2%;width:0;height:0;border-left:14px solid transparent;border-right:14px solid transparent;border-bottom:54px solid #0c170f;filter:drop-shadow(0 6px 6px rgba(0,0,0,.4))}
.tree.t1{left:6%;transform:scale(1.1)}
.tree.t2{left:18%;bottom:4%;transform:scale(.8)}
.tree.t3{right:9%;transform:scale(1.25)}
.hero__grain{position:absolute;inset:0;opacity:.05;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.hero__vignette{position:absolute;inset:0;background:radial-gradient(110% 80% at 50% 30%,transparent 50%,rgba(14,27,20,.7) 100%)}

.hero__content{position:relative;z-index:2;max-width:760px}
.hero__title{font-size:clamp(2.7rem,7vw,5.4rem);line-height:1.02;letter-spacing:-.02em;font-weight:600}
.hero__title em{font-style:italic;color:var(--brass);font-weight:500}
.hero__lead{color:var(--muted);font-size:clamp(1.05rem,1.6vw,1.28rem);margin:26px 0 0;max-width:54ch}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:38px}

.hero__stats{position:relative;z-index:2;display:flex;flex-wrap:wrap;gap:18px clamp(36px,6vw,80px);margin-top:clamp(56px,8vw,96px);padding-top:30px;border-top:1px solid var(--line)}
.stat{display:flex;flex-direction:column;gap:4px}
.stat__num{font-family:var(--font-display);font-size:clamp(2rem,4vw,2.9rem);font-weight:600;color:var(--brass-light);line-height:1;font-variant-numeric:tabular-nums}
.stat__label{font-size:.82rem;color:var(--muted);letter-spacing:.02em;max-width:18ch}

/* ── MARQUEE ────────────────────────────────────── */
.marquee{background:var(--green-900);border-block:1px solid var(--line);overflow:hidden;padding:16px 0}
.marquee__track{display:flex;gap:0;white-space:nowrap;width:max-content;animation:marquee 32s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__track span{font-family:var(--font-display);font-size:1.05rem;letter-spacing:.04em;color:var(--brass);padding:0 26px;opacity:.85}
.marquee__track .dot{color:var(--brass-deep);opacity:.5;font-size:.6rem;padding:0 4px}
@keyframes marquee{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee__track{animation:none}}

/* ── paper sections ─────────────────────────────── */
.section--paper{
  --fg:var(--ink);--muted:rgba(16,19,15,.62);--line:rgba(16,39,31,.14);--card:#fff;
  background:linear-gradient(180deg,var(--paper) 0%,var(--paper-2) 100%);
  color:var(--ink);position:relative;
}
.section--paper .eyebrow{color:var(--brass-deep)}
.section--paper .eyebrow::before{background:var(--brass-deep)}
.section--paper .btn--line{--bfg:var(--ink)}
.section--paper .btn--mini{--bfg:var(--ink)}
.section--paper .btn--mini:hover{color:var(--green-900)}

/* ── SCALES ─────────────────────────────────────── */
.scales__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:22px}
.scale-card{
  position:relative;background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:30px 26px 28px;display:flex;flex-direction:column;
  transition:transform .5s var(--ease),border-color .4s,box-shadow .5s,background .4s;
}
.scale-card:hover{transform:translateY(-7px);border-color:var(--brass);box-shadow:var(--shadow)}
.scale-card--featured{background:var(--green-800);color:#e9e4d6;border-color:var(--brass)}
.scale-card--featured h3{color:#fff}
.scale-card--featured p{color:rgba(233,228,214,.72)}
.scale-card--featured .scale-card__tag{color:var(--brass-light)}
.scale-card--featured .scale-card__meta b{color:var(--brass-light)}
.scale-card--featured .scale-card__meta li{border-color:rgba(201,162,74,.22)}
.scale-card__badge{position:absolute;top:-12px;left:26px;background:var(--brass);color:var(--green-900);font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:5px 12px;border-radius:999px}
.scale-card__top{display:flex;align-items:baseline;justify-content:space-between;gap:12px}
.scale-card__ratio{font-family:var(--font-display);font-size:1.9rem;font-weight:600;color:var(--brass-deep)}
.scale-card--featured .scale-card__ratio{color:var(--brass)}
.scale-card__tag{font-size:.74rem;text-transform:uppercase;letter-spacing:.14em;color:var(--brass-deep);font-weight:600}
.scale-card__rule{height:6px;border-radius:999px;background:rgba(201,162,74,.16);margin:18px 0 22px;overflow:hidden}
.scale-card__rule span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--brass-deep),var(--brass));border-radius:999px;transition:width 1.1s var(--ease) .2s}
.scale-card.in .scale-card__rule span{width:var(--rule-w,40%)}
.scale-card h3{font-size:1.32rem;margin-bottom:10px}
.scale-card p{color:var(--muted);font-size:.96rem;flex:1}
.scale-card__meta{margin-top:22px;display:grid;gap:0}
.scale-card__meta li{display:flex;justify-content:space-between;gap:14px;font-size:.85rem;padding:9px 0;border-top:1px solid var(--line)}
.scale-card__meta b{font-weight:600;color:var(--brass-deep);font-size:.74rem;text-transform:uppercase;letter-spacing:.08em}
.scales__foot{margin-top:36px;color:var(--muted);font-size:1rem}
.scales__foot a{color:var(--brass-deep);font-weight:600;border-bottom:1px solid currentColor;padding-bottom:1px}
.scales__foot a:hover{color:var(--brass)}

/* ── COLLECTION ─────────────────────────────────── */
.collection__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:26px}
.product{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .5s var(--ease),box-shadow .5s,border-color .4s;
}
.product:hover{transform:translateY(-8px);box-shadow:0 30px 60px -30px rgba(16,39,31,.4);border-color:var(--brass-deep)}
.product__media{position:relative;aspect-ratio:16/9;display:grid;place-items:center;overflow:hidden}
.product__media--green{background:linear-gradient(135deg,#1d3328,#0e1b14)}
.product__media--brass{background:linear-gradient(135deg,#3a2f1c,#221a0e)}
.product__media--cream{background:linear-gradient(135deg,#2a3a30,#16271f)}
.product__media--slate{background:linear-gradient(135deg,#2a2f33,#14181b)}
.product__art{width:78%;transition:transform .6s var(--ease)}
.product:hover .product__art{transform:scale(1.06) translateX(6px)}
.product__scale{position:absolute;top:12px;left:12px;background:rgba(201,162,74,.92);color:var(--green-900);font-size:.66rem;font-weight:700;letter-spacing:.1em;padding:4px 9px;border-radius:6px}
.product__body{padding:22px 22px 20px;display:flex;flex-direction:column;flex:1;background:var(--card)}
.product__cat{font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;color:var(--brass-deep);font-weight:600;margin-bottom:8px}
.product__name{font-size:1.18rem;margin-bottom:8px;line-height:1.18}
.product__spec{font-size:.86rem;color:var(--muted);flex:1;margin-bottom:18px}
.product__foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-top:16px;border-top:1px solid var(--line)}
.product__price{font-family:var(--font-display);font-size:1.45rem;font-weight:600;color:var(--brass-deep)}
.collection__cta{display:flex;justify-content:center;margin-top:48px}

/* ── BUILD YOUR WORLD ───────────────────────────── */
.build__inner{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:clamp(36px,6vw,80px);align-items:center}
.build__copy .btn{margin-top:30px}
.build__cards{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.build-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:26px 22px;transition:transform .5s var(--ease),border-color .4s,background .4s}
.build-card:hover{transform:translateY(-6px);border-color:var(--brass);background:rgba(201,162,74,.05)}
.build-card__ico{display:grid;place-items:center;width:46px;height:46px;border-radius:12px;background:rgba(201,162,74,.1);color:var(--brass);margin-bottom:16px}
.build-card__ico svg{width:24px;height:24px}
.build-card h3{font-size:1.12rem;margin-bottom:8px}
.build-card p{color:var(--muted);font-size:.9rem}
@media (max-width:860px){.build__inner{grid-template-columns:1fr}.build__cards{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.build__cards{grid-template-columns:1fr}}

/* ── STORY / HERITAGE ───────────────────────────── */
.story{position:relative;background:var(--green-900);overflow:hidden}
.story__grain{position:absolute;inset:0;opacity:.05;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");pointer-events:none}
.story::before{content:"";position:absolute;top:-30%;left:50%;transform:translateX(-50%);width:120%;height:80%;background:radial-gradient(closest-side,rgba(201,162,74,.1),transparent 70%);pointer-events:none}
.story__inner{position:relative;z-index:1;max-width:860px;text-align:center;margin-inline:auto}
.story__quote{font-family:var(--font-display);font-size:clamp(1.5rem,3.4vw,2.6rem);line-height:1.28;font-weight:500;margin:0 auto;color:#f1ecdd;letter-spacing:-.01em}
.story__quote em{color:var(--brass);font-style:italic}
.story__body{color:rgba(233,228,214,.7);font-size:1.08rem;margin:30px auto 0;max-width:62ch}
.story__sign{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:38px}
.story__line{width:48px;height:1px;background:var(--brass);opacity:.6}
.story__name{font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brass)}

/* ── COMMUNITY ──────────────────────────────────── */
.community__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,64px);align-items:stretch}
.lotm{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:14px 14px 26px;display:flex;flex-direction:column;box-shadow:0 30px 70px -40px rgba(16,39,31,.4)}
.lotm__tag{align-self:flex-start;margin:8px 0 14px 8px;background:var(--green-800);color:var(--brass-light);font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:6px 12px;border-radius:999px}
.lotm__art{border-radius:12px;overflow:hidden;aspect-ratio:16/9;margin-bottom:20px}
.lotm__art svg{width:100%;height:100%}
.lotm h3{font-size:1.3rem;margin:0 8px 10px}
.lotm p{color:var(--muted);font-size:.96rem;margin:0 8px 18px}
.link-arrow{margin:0 8px;color:var(--brass-deep);font-weight:600;font-size:.95rem;display:inline-flex;align-items:center;gap:.4em;transition:gap .3s var(--ease),color .3s}
.link-arrow:hover{gap:.85em;color:var(--brass)}

.signup{align-self:center}
.signup__title{font-size:clamp(1.9rem,3.6vw,2.8rem);margin-bottom:14px}
.signup__lead{color:var(--muted);font-size:1.04rem;max-width:46ch;margin-bottom:26px}
.signup__form{display:flex;gap:10px;flex-wrap:wrap;max-width:480px}
.signup__form input{
  flex:1;min-width:200px;padding:.9em 1.1em;border-radius:999px;border:1px solid var(--line);
  background:#fff;color:var(--ink);font-family:inherit;font-size:.96rem;transition:border-color .3s,box-shadow .3s;
}
.signup__form input:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px rgba(201,162,74,.18)}
.signup__form input.invalid{border-color:var(--rust);box-shadow:0 0 0 3px rgba(122,51,38,.16)}
.signup__note{font-size:.84rem;color:var(--muted);margin:14px 0 0}
.signup__note.ok{color:var(--green-600);font-weight:600}
.signup__note.err{color:var(--rust);font-weight:600}
.signup__perks{margin-top:26px;display:grid;gap:10px}
.signup__perks li{font-size:.92rem;color:var(--muted)}
.signup__perks li::first-letter{color:var(--brass-deep)}
@media (max-width:820px){.community__grid{grid-template-columns:1fr}}

/* ── FOOTER ─────────────────────────────────────── */
.footer{background:var(--green-900);border-top:1px solid var(--line);padding:clamp(56px,7vw,88px) 0 30px}
.footer__grid{display:grid;grid-template-columns:1.6fr repeat(3,1fr) 1.1fr;gap:36px 28px}
.footer__brand{max-width:280px}
.brand--footer{margin-bottom:14px}
.footer__tag{color:var(--muted);font-size:.9rem;line-height:1.55}
.footer__col h4{font-size:.74rem;text-transform:uppercase;letter-spacing:.14em;color:var(--brass);margin-bottom:16px;font-family:var(--font-sans);font-weight:600}
.footer__col a{display:block;color:var(--muted);font-size:.92rem;padding:6px 0;transition:color .3s,transform .3s}
.footer__col a:hover{color:var(--fg);transform:translateX(3px)}
.footer__icons{display:flex;gap:10px}
.footer__icons a{width:40px;height:40px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;color:var(--muted);transition:border-color .3s,color .3s,transform .3s;padding:0}
.footer__icons a:hover{border-color:var(--brass);color:var(--brass);transform:translateY(-3px)}
.footer__base{display:flex;flex-wrap:wrap;gap:10px 24px;justify-content:space-between;align-items:center;margin-top:48px;padding-top:24px;border-top:1px solid var(--line)}
.footer__base p{color:var(--muted);font-size:.82rem;margin:0}
.footer__legal a:hover{color:var(--brass)}
@media (max-width:980px){.footer__grid{grid-template-columns:1fr 1fr 1fr}.footer__brand{grid-column:1 / -1}}
@media (max-width:560px){.footer__grid{grid-template-columns:1fr 1fr}}

/* ── reveal animations ──────────────────────────── */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ── hero loco animations ───────────────────────── */
.wheel{transform-box:fill-box;transform-origin:center;animation:spin 2.4s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loco__body{animation:chug 1.6s ease-in-out infinite}
@keyframes chug{0%,100%{transform:translateY(0)}50%{transform:translateY(-1.5px)}}
.puff{fill:rgba(231,207,143,.5)}
.puff.p1{animation:puff 2.6s ease-out infinite}
.puff.p2{animation:puff 2.6s ease-out infinite .35s}
.puff.p3{animation:puff 2.6s ease-out infinite .7s}
@keyframes puff{0%{opacity:.6;transform:translate(0,0) scale(.6)}100%{opacity:0;transform:translate(-30px,-40px) scale(1.4)}}
@media (prefers-reduced-motion:reduce){.wheel,.loco__body,.puff{animation:none}}
