/* ============================================================
   SOVRANE 序旅 — Brand Site Stylesheet  v2
   Quiet luxury. Sovereign order. Bilingual edition.
   ============================================================ */

:root{
  --black:#0E0E0E;
  --lacquer:#070706;
  --ivory:#F4F0E8;
  --ivory-deep:#EBE5D9;
  --ivory-warm:#EFE9DD;
  --champagne:#B6A58C;
  --champagne-soft:#CBBCA3;
  --champagne-deep:#9C8B72;
  --navy:#101826;
  --cognac:#8A5A37;
  --titanium:#C7C7C0;
  --rose:#C7A29A;
  --line:rgba(14,14,14,.13);
  --line-soft:rgba(14,14,14,.07);
  --line-light:rgba(244,240,232,.16);
  --text:#1b1916;
  --muted:#6c655a;
  --serif:"Cormorant Garamond","Noto Serif TC",Georgia,serif;
  --sans:"Jost","Noto Sans TC","Helvetica Neue",Arial,sans-serif;
  --ease:cubic-bezier(.19,1,.22,1);
  --ease2:cubic-bezier(.6,.01,.05,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--ivory);
  color:var(--text);
  line-height:1.72;
  font-weight:300;
  letter-spacing:.012em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body.locked{overflow:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--champagne);color:#fff}
:focus-visible{outline:1px solid var(--champagne);outline-offset:3px}

/* ---------- Scroll progress ---------- */
.scroll-progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--champagne);z-index:200;transition:width .1s linear}

/* ---------- Preloader ---------- */
.preloader{
  position:fixed;inset:0;z-index:300;background:var(--black);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.4rem;
  transition:opacity .9s var(--ease),visibility .9s var(--ease);
}
.preloader.done{opacity:0;visibility:hidden}
.preloader .pl-mark{
  font-family:var(--serif);color:var(--ivory);font-size:clamp(2rem,5vw,3.2rem);
  letter-spacing:.62em;text-indent:.62em;font-weight:400;opacity:0;
  animation:plIn 1.3s var(--ease) .15s forwards;
}
.preloader .pl-line{height:1px;width:0;background:var(--champagne);animation:plLine 1.6s var(--ease) .5s forwards}
.preloader .pl-cn{font-family:var(--serif);color:var(--champagne);letter-spacing:.5em;text-indent:.5em;font-size:.9rem;opacity:0;animation:plIn 1.3s var(--ease) .5s forwards}
@keyframes plIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes plLine{from{width:0}to{width:min(260px,46vw)}}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;line-height:1.06;letter-spacing:.004em}
.eyebrow{
  font-family:var(--sans);font-size:.68rem;font-weight:400;
  letter-spacing:.44em;text-transform:uppercase;color:var(--champagne-deep);
  display:inline-block;
}
.serif-lg{font-size:clamp(2.6rem,6vw,5.4rem)}
.serif-md{font-size:clamp(2rem,4.2vw,3.5rem)}
.lede{font-size:clamp(1.05rem,1.5vw,1.32rem);color:var(--muted);font-weight:300;max-width:48ch}
.cn{font-family:var(--serif);letter-spacing:.06em}
em{font-style:italic;color:var(--champagne-deep)}

/* ---------- Layout ---------- */
.wrap{width:100%;max-width:1360px;margin:0 auto;padding:0 clamp(22px,5vw,76px)}
section{position:relative}
.pad{padding:clamp(82px,12vw,184px) 0}
.pad-sm{padding:clamp(58px,7.5vw,108px) 0}
.center{text-align:center}
.divider{height:1px;background:var(--line);border:0;width:100%}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.85em;
  font-family:var(--sans);font-size:.7rem;font-weight:400;
  letter-spacing:.3em;text-transform:uppercase;
  padding:1.2em 2.5em;border:1px solid var(--black);
  color:var(--black);background:transparent;cursor:pointer;
  transition:color .6s var(--ease),background .6s var(--ease),border-color .6s var(--ease);
  position:relative;overflow:hidden;
}
.btn span{position:relative;z-index:1}
.btn::before{content:"";position:absolute;inset:0;background:var(--black);transform:translateY(101%);transition:transform .55s var(--ease);z-index:0}
.btn:hover{color:var(--ivory)}
.btn:hover::before{transform:translateY(0)}
.btn--light{border-color:rgba(244,240,232,.55);color:var(--ivory)}
.btn--light::before{background:var(--ivory)}
.btn--light:hover{color:var(--black)}
.btn--solid{border-color:var(--black);color:var(--ivory)}
.btn--solid::before{transform:translateY(0);background:var(--black)}
.btn--solid:hover{color:var(--ivory)}
.btn--solid::after{content:"";position:absolute;inset:0;background:var(--champagne-deep);transform:translateY(101%);transition:transform .55s var(--ease);z-index:0}
.btn--solid:hover::after{transform:translateY(0)}
.btn--solid span{z-index:2}
.link-underline{
  font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;
  padding-bottom:.55em;position:relative;display:inline-block;color:var(--text);
}
.link-underline::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--champagne);transform-origin:right;transform:scaleX(1);transition:transform .5s var(--ease)}
.link-underline:hover::after{transform-origin:left;transform:scaleX(0)}
.link-underline::before{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--black);transform-origin:left;transform:scaleX(0);transition:transform .5s var(--ease) .04s}
.link-underline:hover::before{transform:scaleX(1)}

/* ---------- Header ---------- */
.site-header{
  position:fixed;top:0;left:0;width:100%;z-index:100;
  padding:1.6rem 0;transition:padding .5s var(--ease),background .5s var(--ease),border-color .5s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header.solid{
  background:rgba(244,240,232,.86);backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
  border-bottom-color:var(--line-soft);padding:1rem 0;
}
.site-header.hide{transform:translateY(-100%)}
.nav{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem}
.nav-links{display:flex;gap:clamp(1.3rem,2.3vw,2.6rem);list-style:none}
.nav-links a{
  font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;font-weight:400;
  position:relative;padding:.4em 0;color:var(--text);transition:color .4s;
}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--champagne);transition:width .45s var(--ease)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.brand-mark{
  font-family:var(--serif);font-size:1.6rem;letter-spacing:.46em;text-indent:.46em;
  text-transform:uppercase;color:var(--black);font-weight:500;line-height:1;white-space:nowrap;text-align:center;
}
.brand-mark .cn{font-size:.58rem;letter-spacing:.4em;text-indent:.4em;display:block;color:var(--champagne-deep);margin-top:.34em}
.nav-side{display:flex;align-items:center}
.nav-side.right{justify-content:flex-end;gap:1.4rem}
.nav-side.left{justify-content:flex-start}
.header-light:not(.solid) .nav-links a,.header-light:not(.solid) .brand-mark,
.header-light:not(.solid) .lang-switch,.header-light:not(.solid) .menu-toggle{color:var(--ivory)}
.header-light:not(.solid) .brand-mark .cn{color:var(--champagne-soft)}
.header-light:not(.solid) .lang-switch a{color:rgba(244,240,232,.62)}
.header-light:not(.solid) .lang-switch a.on{color:var(--ivory)}

/* Language switch */
.lang-switch{display:flex;align-items:center;gap:.5em;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase}
.lang-switch a{color:var(--muted);transition:color .35s}
.lang-switch a.on{color:var(--black)}
.lang-switch a:hover{color:var(--champagne-deep)}
.lang-switch .sep{opacity:.4}

.menu-toggle{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px;padding:6px;color:var(--black)}
.menu-toggle span{width:24px;height:1.3px;background:currentColor;transition:.4s var(--ease)}

/* ---------- Hero ---------- */
.hero{min-height:100vh;display:flex;align-items:flex-end;position:relative;color:var(--ivory);overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0;will-change:transform}
.hero-bg img{width:100%;height:118%;object-fit:cover;animation:slowzoom 16s var(--ease) forwards}
@keyframes slowzoom{from{transform:scale(1.1)}to{transform:scale(1)}}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,14,10,.32) 0%,rgba(18,14,10,.04) 38%,rgba(14,11,8,.62) 100%)}
.hero-content{position:relative;z-index:2;padding-bottom:clamp(74px,9vw,140px);max-width:880px}
.hero h1{font-size:clamp(3rem,7.6vw,7.2rem);color:#fff;margin:.34em 0 .42em;font-weight:300;letter-spacing:.01em}
.hero .lede{color:rgba(255,255,255,.85);max-width:44ch;margin-bottom:2.5em}
.hero .eyebrow{color:var(--champagne-soft)}
.hero-cn{font-family:var(--serif);font-size:clamp(1.1rem,1.7vw,1.5rem);color:rgba(255,255,255,.82);letter-spacing:.13em;margin-bottom:.45em}
.scroll-cue{position:absolute;bottom:2.2rem;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:.7rem}
.scroll-cue .ln{width:1px;height:48px;background:linear-gradient(var(--champagne-soft),transparent);position:relative;overflow:hidden}
.scroll-cue .ln::after{content:"";position:absolute;top:-50%;left:0;width:1px;height:50%;background:var(--ivory);animation:cue 2.2s var(--ease) infinite}
@keyframes cue{0%{top:-50%}100%{top:100%}}
.scroll-cue span{font-size:.58rem;letter-spacing:.34em;text-transform:uppercase;color:rgba(244,240,232,.7)}

/* ---------- Marquee ---------- */
.marquee{background:var(--black);color:var(--ivory);padding:1.3rem 0;overflow:hidden;white-space:nowrap;border-top:1px solid var(--line-light);border-bottom:1px solid var(--line-light)}
.marquee-track{display:inline-flex;gap:3.5rem;animation:marq 34s linear infinite;will-change:transform}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee span{font-family:var(--serif);font-size:1.5rem;letter-spacing:.18em;color:rgba(244,240,232,.55);display:inline-flex;align-items:center;gap:3.5rem}
.marquee span::after{content:"·";color:var(--champagne)}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- Statement ---------- */
.statement{max-width:920px;margin:0 auto;text-align:center}
.statement h2{font-size:clamp(1.8rem,3.5vw,3.1rem);font-weight:300;line-height:1.26;color:var(--black)}

/* ---------- Two-column feature ---------- */
.feature{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:clamp(2rem,6vw,6.5rem)}
.feature.rev .feature-img{order:2}
.feature-img{position:relative;overflow:hidden}
.feature-img img{width:100%;transition:transform 1.5s var(--ease)}
.feature-img:hover img{transform:scale(1.045)}
.feature-tag{position:absolute;top:1.4rem;left:1.4rem;z-index:2;font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ivory);background:rgba(14,14,14,.5);backdrop-filter:blur(6px);padding:.5em 1.1em}
.feature-body .eyebrow{margin-bottom:1.7rem}
.feature-body h2{margin-bottom:1.35rem;color:var(--black)}
.feature-body p{color:var(--muted);margin-bottom:1.2rem;max-width:50ch}
.feature-body .cn-note{font-family:var(--serif);font-size:1.18rem;color:var(--text);letter-spacing:.04em;margin-bottom:1.9rem}

/* ---------- Collections grid ---------- */
.col-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2vw,1.9rem)}
.col-card{position:relative;overflow:hidden;background:var(--ivory-deep);display:block}
.col-card .img-hold{aspect-ratio:4/5;overflow:hidden;background:var(--ivory-deep);position:relative}
.col-card img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease)}
.col-card:hover img{transform:scale(1.06)}
.col-card .img-hold::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(10,8,6,.5));opacity:0;transition:opacity .6s var(--ease)}
.col-card:hover .img-hold::after{opacity:1}
.col-card .meta{padding:1.6rem 1.55rem 1.95rem;position:relative}
.col-card .meta .idx{position:absolute;top:-2.4rem;right:1.4rem;font-family:var(--serif);font-size:.78rem;letter-spacing:.2em;color:var(--ivory);opacity:0;transform:translateY(8px);transition:.5s var(--ease)}
.col-card:hover .meta .idx{opacity:1;transform:none}
.col-card .meta h3{font-size:1.55rem;color:var(--black);margin-bottom:.15rem}
.col-card .meta .sub{font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;color:var(--champagne-deep)}
.col-card .meta p{font-size:.86rem;color:var(--muted);margin-top:.7rem;line-height:1.6}

/* ---------- Dark section ---------- */
.dark{background:var(--black);color:var(--ivory)}
.dark .eyebrow{color:var(--champagne)}
.dark h2,.dark h3{color:var(--ivory)}
.dark p{color:rgba(244,240,232,.6)}
.dark .divider{background:var(--line-light)}
.dark .cn-note{color:rgba(244,240,232,.82)}

/* ---------- Colorways ---------- */
.colorways{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(.8rem,1.6vw,1.7rem)}
.cw{text-align:center}
.cw .img-hold{aspect-ratio:1/1;background:var(--ivory-deep);overflow:hidden;margin-bottom:1.1rem}
.cw img{width:100%;height:100%;object-fit:cover;transition:transform 1.3s var(--ease)}
.cw:hover img{transform:scale(1.06)}
.cw .dot{display:inline-block;width:11px;height:11px;border-radius:50%;margin-right:.5em;vertical-align:middle;border:1px solid rgba(0,0,0,.12)}
.cw h4{font-size:1.28rem;color:var(--black);display:inline-block;vertical-align:middle}
.cw .en{font-size:.64rem;letter-spacing:.24em;text-transform:uppercase;color:var(--champagne-deep);margin-top:.3rem}

/* ---------- Specs ---------- */
.specs{display:grid;grid-template-columns:repeat(3,1fr);gap:2.6rem 3rem}
.spec-item{border-top:1px solid var(--line);padding-top:1.35rem}
.dark .spec-item{border-top-color:var(--line-light)}
.spec-item .k{font-size:.64rem;letter-spacing:.26em;text-transform:uppercase;color:var(--champagne-deep);margin-bottom:.55rem}
.spec-item .v{font-family:var(--serif);font-size:1.42rem;color:var(--black);line-height:1.3}
.dark .spec-item .v{color:var(--ivory)}
.spec-item .vsub{font-size:.84rem;color:var(--muted);margin-top:.32rem}

/* ---------- Values ---------- */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(2rem,4vw,3.6rem)}
.value .num{font-family:var(--serif);font-size:1.1rem;color:var(--champagne-deep);letter-spacing:.1em}
.value h3{font-size:1.72rem;color:var(--black);margin:.8rem 0 .4rem}
.value .cnh{font-family:var(--serif);font-size:1.05rem;color:var(--muted);margin-bottom:1rem}
.value p{font-size:.92rem;color:var(--muted)}
.value .line{width:34px;height:1px;background:var(--champagne);margin:1.3rem 0}

/* ---------- Manifesto ---------- */
.manifesto{text-align:center;max-width:800px;margin:0 auto}
.manifesto p{font-family:var(--serif);font-size:clamp(1.3rem,2.4vw,2rem);line-height:1.58;color:var(--ivory);font-weight:300;letter-spacing:.02em}
.manifesto .sig{margin-top:2.6rem;font-size:.68rem;letter-spacing:.42em;text-transform:uppercase;color:var(--champagne)}

/* ---------- Banner ---------- */
.banner{position:relative;min-height:66vh;display:flex;align-items:center;color:var(--ivory);overflow:hidden}
.banner-bg{position:absolute;inset:0;z-index:0}
.banner-bg img{width:100%;height:100%;object-fit:cover}
.banner-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(10,8,6,.68),rgba(10,8,6,.16))}
.banner .wrap{position:relative;z-index:2}
.banner h2{color:#fff;font-size:clamp(2rem,4vw,3.5rem);font-weight:300;max-width:18ch;margin-bottom:1.4rem}
.banner p{color:rgba(255,255,255,.8);max-width:46ch;margin-bottom:2rem}

/* ---------- Journal ---------- */
.journal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,2.5vw,2.6rem)}
.jr .cat{font-size:.64rem;letter-spacing:.26em;text-transform:uppercase;color:var(--champagne-deep)}
.jr h3{font-size:1.5rem;color:var(--black);margin:.7rem 0;line-height:1.25}
.jr p{font-size:.9rem;color:var(--muted)}

/* ---------- Forms ---------- */
.form{display:grid;grid-template-columns:1fr 1fr;gap:1.7rem 2rem;max-width:760px}
.field{display:flex;flex-direction:column}
.field.full{grid-column:1/-1}
.field label{font-size:.64rem;letter-spacing:.24em;text-transform:uppercase;color:var(--champagne-deep);margin-bottom:.7rem}
.field input,.field textarea,.field select{
  font-family:var(--sans);font-size:.95rem;font-weight:300;color:var(--text);
  border:0;border-bottom:1px solid var(--line);background:transparent;padding:.72em 0;transition:border-color .4s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:0;border-bottom-color:var(--champagne)}
.field textarea{resize:vertical;min-height:110px}

/* ---------- Footer ---------- */
.site-footer{background:var(--lacquer);color:var(--ivory);padding:clamp(64px,8vw,116px) 0 2.6rem}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2.6rem}
.footer-brand .brand-mark{color:var(--ivory);text-align:left}
.footer-brand p{color:rgba(244,240,232,.48);font-size:.86rem;margin-top:1.6rem;max-width:32ch}
.footer-col h4{font-family:var(--sans);font-size:.64rem;letter-spacing:.26em;text-transform:uppercase;color:var(--champagne);margin-bottom:1.45rem;font-weight:400}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:.85rem}
.footer-col a{font-size:.88rem;color:rgba(244,240,232,.64);transition:color .35s}
.footer-col a:hover{color:var(--ivory)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-top:clamp(42px,6vw,84px);padding-top:2rem;border-top:1px solid var(--line-light)}
.footer-bottom p{font-size:.73rem;color:rgba(244,240,232,.4);letter-spacing:.04em}
.footer-bottom .motto{letter-spacing:.22em;text-transform:uppercase;color:var(--champagne);font-size:.66rem}

/* ---------- Page hero ---------- */
.page-hero{padding:clamp(150px,19vw,232px) 0 clamp(52px,7vw,94px);text-align:center;border-bottom:1px solid var(--line)}
.page-hero h1{font-size:clamp(2.6rem,5.6vw,4.8rem);color:var(--black);font-weight:300;margin:.4em 0 .36em}
.page-hero .lede{margin:0 auto}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(36px);transition:opacity 1.15s var(--ease),transform 1.15s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.12s}.reveal.d2{transition-delay:.24s}
.reveal.d3{transition-delay:.36s}.reveal.d4{transition-delay:.48s}
.img-fade{opacity:0;transition:opacity 1.2s var(--ease)}
.img-fade.loaded{opacity:1}

/* ---------- Product detail (collections) ---------- */
.series{scroll-margin-top:90px}
.cw-stage{aspect-ratio:1/1;background:var(--ivory-deep);overflow:hidden}
.cw-stage img{width:100%;height:100%;object-fit:cover;transition:opacity .3s var(--ease)}
.swatch-row{display:flex;gap:1rem;margin:1.9rem 0 1.2rem;flex-wrap:wrap}
.swatch{width:46px;height:46px;border-radius:50%;cursor:pointer;border:1px solid var(--line);position:relative;transition:transform .35s var(--ease)}
.swatch:hover{transform:scale(1.09)}
.swatch.active{box-shadow:0 0 0 1px var(--ivory),0 0 0 2px var(--champagne)}
.price{font-family:var(--serif);font-size:1.62rem;color:var(--black)}
.price small{font-size:.8rem;color:var(--muted);font-family:var(--sans);letter-spacing:.1em}
.gallery3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2.6rem}
.gallery3 img{aspect-ratio:4/5;object-fit:cover;width:100%;background:var(--ivory-deep)}
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2.5rem,6vw,6rem);align-items:start}
@media(max-width:860px){.gallery3{grid-template-columns:1fr 1fr}.contact-grid{grid-template-columns:1fr}}

/* ---------- Helpers ---------- */
.note-tag{font-size:.72rem;color:var(--muted);letter-spacing:.03em}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .col-grid,.journal-grid,.values,.specs{grid-template-columns:1fr 1fr}
  .colorways{grid-template-columns:1fr 1fr}
  .footer-top{grid-template-columns:1fr 1fr}
  .feature{grid-template-columns:1fr;gap:2.2rem}
  .feature.rev .feature-img{order:0}
}
@media(max-width:760px){
  .nav{grid-template-columns:auto 1fr auto}
  .nav-side.left{order:3}
  .nav-links{
    position:fixed;inset:0;background:var(--ivory);flex-direction:column;
    justify-content:center;align-items:center;gap:2rem;
    transform:translateX(100%);transition:transform .6s var(--ease);z-index:99;
  }
  .nav-links.open{transform:none}
  .nav-links a{font-size:1.05rem;letter-spacing:.2em;color:var(--text)!important}
  .menu-toggle{display:flex;z-index:100}
  .brand-mark{justify-self:start;text-align:left;font-size:1.3rem;letter-spacing:.34em;text-indent:.34em}
  .nav-side.right{order:2}
  .menu-toggle.x span:nth-child(1){transform:translateY(6.3px) rotate(45deg)}
  .menu-toggle.x span:nth-child(2){opacity:0}
  .menu-toggle.x span:nth-child(3){transform:translateY(-6.3px) rotate(-45deg)}
  .col-grid,.journal-grid,.values,.specs,.form{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr}
  .statement h2{font-size:1.55rem}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .hero-bg img{height:100%}
}
html{scroll-behavior:smooth}
