/* ─────────────────────────────────────────────
   MISSION BARBERSHOP · Heritage Atelier
   Dark luxe · brass · editorial
   ───────────────────────────────────────────── */

:root{
  --ink:        #0a0908;
  --ink-2:      #0e0c0a;
  --ink-3:      #16130f;
  --ink-4:      #1c1814;
  --line:       #2a241d;
  --line-2:     #3a3127;
  --brass:      #c9a45c;
  --brass-hi:   #e3c285;
  --brass-lo:   #8a6d36;
  --cream:      #efe4cb;
  --parchment:  #f3ead4;
  --muted:      #8c8170;
  --muted-2:    #5e574b;

  --font-display: "Bodoni Moda", "Didot", "GFS Didot", serif;
  --font-serif:   "Cormorant Garamond", "EB Garamond", Georgia, serif;
  --font-sans:    "Archivo", "Helvetica Neue", system-ui, sans-serif;

  --pad: clamp(20px, 4vw, 56px);
  --maxw: 1320px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background: radial-gradient(1200px 700px at 70% -10%, #1a1612 0%, var(--ink) 55%) no-repeat var(--ink);
  color: var(--cream);
  font-family: var(--font-serif);
  font-weight:300;
  font-size:18px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

::selection{ background:var(--brass); color:var(--ink); }

a{ color:inherit; text-decoration:none; }
a:hover{ color:var(--brass-hi); }

/* ── grain overlay ── */
.grain{
  position:fixed; inset:0; pointer-events:none; z-index:60;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.78  0 0 0 0 0.65  0 0 0 0 0.36  0 0 0 0.5 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.18'/></svg>");
  mix-blend-mode: overlay;
  opacity:.35;
}

/* ── custom cursor (subtle brass dot) ── */
.cursor{
  position:fixed; top:0; left:0; width:8px; height:8px; border-radius:50%;
  background:var(--brass);
  pointer-events:none; z-index:80;
  transform: translate(-100px,-100px);
  transition: width .25s, height .25s, opacity .3s, background .3s;
  mix-blend-mode: screen;
  opacity:.85;
}
.cursor.hover{ width:34px; height:34px; background:transparent; border:1px solid var(--brass); }
@media (hover:none){ .cursor{ display:none; } }

/* ─── TOP RIBBON ─── */
.ribbon{
  display:flex; align-items:center; justify-content:center; gap:14px; flex-wrap:wrap;
  padding:9px var(--pad);
  background:#070605;
  border-bottom:1px solid var(--line);
  font-family:var(--font-sans);
  font-size:10.5px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--muted);
}
.ribbon a{ color:var(--brass-hi); }
.ribbon .rb-dot{ width:3px; height:3px; background:var(--brass-lo); border-radius:50%; display:inline-block; }
.ribbon .rb-mark{ color:var(--brass); }

/* ─── NAV ─── */
.nav{
  position:sticky; top:0; z-index:50;
  display:grid;
  grid-template-columns: auto 1fr auto;
  align-items:center;
  gap:24px;
  padding: 18px var(--pad);
  background:linear-gradient(to bottom, rgba(10,9,8,.92), rgba(10,9,8,.65) 70%, transparent);
  backdrop-filter: blur(8px) saturate(120%);
  -webkit-backdrop-filter: blur(8px) saturate(120%);
}
.mark{
  display:flex; align-items:center; gap:12px;
  color:var(--brass-hi);
}
.mark svg{ flex-shrink:0; }
.mark-txt{
  font-family:var(--font-display);
  font-size:20px; letter-spacing:.02em; color:var(--cream);
  line-height:1;
}
.mark-txt em{
  font-style: italic; color:var(--muted); font-weight:400; margin-left:4px;
  font-family:var(--font-serif); font-size:15px; letter-spacing:.04em;
}

.links{
  display:flex; gap: clamp(14px, 2.5vw, 36px); justify-content:center;
  font-family:var(--font-sans); font-size:11.5px;
  letter-spacing:.28em; text-transform:uppercase; color:var(--cream);
}
.links a{ position:relative; padding:6px 2px; color:var(--cream); }
.links a::after{
  content:""; position:absolute; left:0; right:0; bottom:-2px;
  height:1px; background:var(--brass); transform:scaleX(0); transform-origin:left;
  transition: transform .5s cubic-bezier(.2,.7,.2,1);
}
.links a:hover{ color:var(--brass-hi); }
.links a:hover::after{ transform:scaleX(1); }

.cta{
  display:inline-flex; align-items:center; gap:10px;
  padding:11px 18px;
  border:1px solid var(--brass);
  color:var(--brass-hi);
  font-family:var(--font-sans); font-size:11px; letter-spacing:.28em; text-transform:uppercase;
  position:relative; overflow:hidden;
  transition: color .4s ease;
}
.cta i{
  width:6px; height:6px; background:var(--brass); border-radius:50%; display:inline-block;
}
.cta::before{
  content:""; position:absolute; inset:0; background:var(--brass); transform:translateY(101%);
  transition: transform .5s cubic-bezier(.2,.7,.2,1); z-index:-1;
}
.cta:hover{ color:var(--ink); }
.cta:hover::before{ transform:translateY(0); }
.cta:hover i{ background:var(--ink); }

@media (max-width: 880px){
  .nav{ grid-template-columns: auto auto; }
  .links{ display:none; }
}

/* ─── HERO ─── */
.hero{
  position:relative;
  min-height: clamp(640px, 92vh, 980px);
  padding: clamp(40px, 8vh, 110px) var(--pad) clamp(40px, 8vh, 90px);
  display:grid;
  place-items:center;
  border-bottom:1px solid var(--line);
  isolation:isolate;
  overflow:hidden;
}
.hero::before{
  /* soft brass spotlight */
  content:""; position:absolute; inset:auto;
  width:1100px; height:1100px;
  left:50%; top:62%;
  transform:translate(-50%,-50%);
  background: radial-gradient(closest-side, rgba(201,164,92,.08), transparent 70%);
  z-index:0; pointer-events:none;
}
.hero::after{
  /* hairline cross */
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(transparent 49.7%, rgba(201,164,92,.10) 49.85%, rgba(201,164,92,.10) 50.15%, transparent 50.3%),
    linear-gradient(90deg, transparent 49.7%, rgba(201,164,92,.06) 49.85%, rgba(201,164,92,.06) 50.15%, transparent 50.3%);
  pointer-events:none; z-index:0;
  mask-image: radial-gradient(circle at 50% 55%, transparent 180px, #000 320px);
  -webkit-mask-image: radial-gradient(circle at 50% 55%, transparent 180px, #000 320px);
}

.hero-meta{
  position:absolute; top: 28px;
  font-family: var(--font-sans); font-size:10.5px;
  letter-spacing:.3em; text-transform:uppercase;
  color:var(--muted);
  display:flex; gap:18px;
  z-index:2;
}
.hero-meta em{ color:var(--brass-hi); font-style:normal; }
.hero-meta.left{ left:var(--pad); }
.hero-meta.right{ right:var(--pad); }

.hero-stack{
  position:relative; z-index:3; text-align:center;
  max-width: 1100px;
}

.eyebrow{
  font-family:var(--font-sans);
  font-size:11px; letter-spacing:.4em; text-transform:uppercase;
  color:var(--brass);
  margin: 0 0 28px;
  display:flex; align-items:center; justify-content:center; gap:14px;
}
.eyebrow span{ color:var(--brass-lo); }

.display{
  font-family: var(--font-display);
  font-weight:400;
  font-size: clamp(64px, 14vw, 220px);
  line-height: 0.86;
  letter-spacing: -0.02em;
  margin: 0;
  color:var(--parchment);
  text-shadow: 0 1px 0 rgba(0,0,0,.4);
}
.display .word{ display:block; }
.display .word.ital{
  font-style: italic;
  color: var(--brass);
  font-weight:400;
  font-size: .82em;
  letter-spacing:-.01em;
  margin-top: -.04em;
  font-family: var(--font-display);
}
.display .word.ital em{ font-style:italic; }

.kicker{
  margin: 32px auto 0;
  max-width: 560px;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(17px, 1.6vw, 21px);
  color: var(--cream);
  opacity:.85;
  letter-spacing:.01em;
}

.hero-actions{
  display:flex; gap:16px; justify-content:center; flex-wrap:wrap;
  margin-top: 36px;
}

.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-sans); font-size:11px; letter-spacing:.3em; text-transform:uppercase;
  padding: 16px 28px;
  border:1px solid transparent;
  transition: all .4s ease;
}
.btn.primary{
  background:var(--brass); color:var(--ink); border-color:var(--brass);
}
.btn.primary:hover{ background:var(--brass-hi); border-color:var(--brass-hi); color:var(--ink); }
.btn.ghost{
  border-color:var(--line-2); color:var(--cream);
}
.btn.ghost:hover{ border-color:var(--brass); color:var(--brass-hi); }

.hero-orn{
  position:absolute; left:50%; top:54%;
  width: clamp(280px, 38vw, 520px);
  transform: translate(-50%,-50%);
  color: rgba(201,164,92, .14);
  z-index:1;
  animation: turn 80s linear infinite;
}
@keyframes turn { to { transform: translate(-50%,-50%) rotate(360deg); } }

.scroll{
  position:absolute; bottom:18px; left:50%; transform:translateX(-50%);
  font-family:var(--font-sans); font-size:10px; letter-spacing:.4em; text-transform:uppercase;
  color:var(--muted);
  margin:0;
}
.scroll span{
  display:inline-block; width:1px; height:32px; background:var(--brass-lo); margin-left:10px; vertical-align:middle;
  animation: drop 2.4s ease-in-out infinite;
  transform-origin: top;
}
@keyframes drop{
  0%   { transform: scaleY(0); opacity:0; }
  40%  { transform: scaleY(1); opacity:1; }
  100% { transform: scaleY(0); opacity:0; transform-origin:bottom; }
}

/* ─── MARQUEE ─── */
.marquee{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background: #060504;
  overflow:hidden;
  padding: 22px 0;
}
.marquee-track{
  display:flex; gap:42px; align-items:center;
  white-space:nowrap;
  animation: slide 60s linear infinite;
  width: max-content;
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(28px, 4.4vw, 56px);
  color: var(--parchment);
}
.marquee-track .dia{ color: var(--brass); font-style:normal; font-size:.5em; }
@keyframes slide { to { transform: translateX(-50%); } }

/* ─── SECTION SCAFFOLD ─── */
.section{
  padding: clamp(80px, 12vh, 140px) var(--pad);
  max-width: var(--maxw);
  margin: 0 auto;
  position:relative;
}
.section + .section{ border-top:1px solid var(--line); }

.section-head{
  display:grid;
  grid-template-columns: auto 1fr;
  column-gap: clamp(18px, 4vw, 60px);
  align-items: end;
  margin-bottom: clamp(40px, 6vh, 70px);
  padding-bottom: 20px;
  border-bottom:1px solid var(--line);
}
.numeral{
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(48px, 7vw, 96px);
  color: var(--brass);
  line-height: .9;
  align-self:end;
  grid-row: span 2;
}
.section-head h2{
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(34px, 5vw, 72px);
  letter-spacing:-.01em;
  margin: 0;
  color:var(--parchment);
}
.section-head .lede{
  grid-column: 2;
  margin: 14px 0 0;
  max-width: 56ch;
  font-style: italic;
  color: var(--muted);
  font-size: 17px;
}

/* ─── SERVICES ─── */
.svc-list{
  list-style:none; margin:0; padding:0;
  display:grid; grid-template-columns: repeat(2, 1fr);
  gap: 0;
  border-top:1px solid var(--line);
}
.svc{
  position:relative;
  padding: 36px clamp(20px, 3vw, 40px) 36px clamp(56px, 5vw, 72px);
  border-bottom:1px solid var(--line);
  transition: background .4s ease;
}
.svc:nth-child(odd){ border-right:1px solid var(--line); }
.svc:hover{ background: rgba(201,164,92,.04); }
.svc-no{
  position:absolute; left: clamp(14px, 1.8vw, 22px); top: 38px;
  font-family: var(--font-sans);
  font-size: 11px; letter-spacing:.3em; color: var(--brass-lo);
}
.svc h3{
  font-family: var(--font-display);
  font-weight:400; font-size: clamp(24px, 2.4vw, 32px);
  margin: 0 0 12px;
  color: var(--parchment);
  letter-spacing:-.01em;
}
.svc p{
  margin: 0 0 14px;
  color: var(--cream); opacity:.82;
  font-size: 16.5px; line-height:1.6;
  max-width: 46ch;
}
.svc-meta{
  font-family: var(--font-sans);
  font-size: 10.5px; letter-spacing:.28em; text-transform:uppercase;
  color: var(--muted);
}

@media (max-width: 780px){
  .svc-list{ grid-template-columns: 1fr; }
  .svc:nth-child(odd){ border-right:none; }
}

.rates-note{
  margin-top: 36px;
  text-align:center;
  font-style:italic;
  color: var(--muted);
}
.rates-note a{
  color: var(--brass-hi);
  border-bottom: 1px solid var(--brass-lo);
  padding-bottom:1px;
}

/* ─── CRAFT ─── */
.craft-grid{
  display:grid;
  grid-template-columns: 5fr 7fr;
  gap: clamp(28px, 5vw, 80px);
  align-items: start;
}
@media (max-width: 880px){ .craft-grid{ grid-template-columns:1fr; } }

.craft-portrait{
  margin:0;
  position: sticky; top: 100px;
}
.craft-portrait .frame{
  position:relative;
  padding: 14px;
  border:1px solid var(--brass-lo);
  background: #0c0a08;
  box-shadow: inset 0 0 0 1px #1d1812, 0 30px 60px -30px rgba(0,0,0,.8);
}
.craft-portrait .frame::before, .craft-portrait .frame::after{
  content:""; position:absolute; width:18px; height:18px; border:1px solid var(--brass);
}
.craft-portrait .frame::before{ top:-4px; left:-4px; border-right:none; border-bottom:none; }
.craft-portrait .frame::after{ bottom:-4px; right:-4px; border-left:none; border-top:none; }
.craft-portrait svg{ display:block; width:100%; height:auto; }
.craft-portrait figcaption{
  margin-top: 14px; text-align:center;
  font-family:var(--font-sans); font-size:10.5px; letter-spacing:.3em; text-transform:uppercase;
  color: var(--muted);
}

.craft-text .pull{
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(28px, 3.4vw, 44px);
  line-height: 1.18;
  color: var(--parchment);
  margin: 0 0 32px;
  border-left: 1px solid var(--brass);
  padding-left: 22px;
}
.craft-text p{
  font-size: 18px; line-height: 1.7;
  color: var(--cream); opacity:.88;
  margin: 0 0 18px;
  max-width: 60ch;
}
.craft-text p:first-of-type{ font-size: 19px; }
.creed{
  list-style:none; padding:0; margin: 28px 0 0;
  border-top:1px solid var(--line); padding-top:22px;
}
.creed li{
  font-family: var(--font-sans);
  font-size: 12px; letter-spacing:.22em; text-transform:uppercase;
  color: var(--cream); opacity:.85;
  padding: 8px 0;
  display:flex; gap:14px;
}
.creed li span{ color: var(--brass); }

/* ─── CHAIRS ─── */
.chair-grid{
  display:grid; grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border:1px solid var(--line);
}
.chair{
  padding: 40px clamp(18px, 2vw, 28px);
  border-right:1px solid var(--line);
  transition: background .4s ease;
}
.chair:last-child{ border-right:none; }
.chair:hover{ background: rgba(201,164,92,.04); }
.chair-plate{
  width:84px; height:84px; border-radius:50%;
  border:1px solid var(--brass-lo);
  display:grid; place-items:center;
  margin-bottom:24px;
  position:relative;
}
.chair-plate::before{
  content:""; position:absolute; inset:6px; border-radius:50%;
  border:1px solid var(--line-2);
}
.chair-roman{
  font-family:var(--font-display); font-style:italic; font-size: 30px; color: var(--brass-hi);
}
.chair h3{
  font-family: var(--font-display);
  font-weight:400; font-size: 22px;
  margin:0 0 10px; color: var(--parchment);
}
.chair p{
  margin:0; font-size: 15px; color: var(--cream); opacity:.78;
  line-height:1.55;
}
@media (max-width: 880px){
  .chair-grid{ grid-template-columns: repeat(2, 1fr); }
  .chair:nth-child(2){ border-right:none; }
  .chair:nth-child(1), .chair:nth-child(2){ border-bottom:1px solid var(--line); }
}
@media (max-width: 520px){
  .chair-grid{ grid-template-columns: 1fr; }
  .chair{ border-right:none; border-bottom:1px solid var(--line); }
  .chair:last-child{ border-bottom:none; }
}

/* ─── ATELIER / GALLERY ─── */
.gal{
  display:grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: 180px;
  gap: 14px;
}
.g{ margin:0; position:relative; overflow:hidden; }
.g .ph{
  width:100%; height:100%;
  background:
    radial-gradient(closest-side at 30% 30%, #221c15, #0c0a08 70%),
    linear-gradient(135deg, #14110d, #0a0908);
  border:1px solid var(--line);
  display:grid; place-items:center;
  position:relative;
  transition: transform .8s cubic-bezier(.2,.7,.2,1), border-color .4s;
}
.g .ph::before{
  content:""; position:absolute; inset:10px; border:1px solid var(--brass-lo); opacity:.35;
  pointer-events:none;
}
.g .ph span{
  font-family:var(--font-display); font-style:italic; font-size:54px;
  color: var(--brass); opacity:.55;
}
.g:hover .ph{ transform: scale(1.03); border-color: var(--brass-lo); }
.g figcaption{
  position:absolute; left:14px; bottom:12px;
  font-family:var(--font-sans); font-size:10px; letter-spacing:.3em; text-transform:uppercase;
  color:var(--brass-hi);
  background: rgba(7,6,5,.65); backdrop-filter: blur(4px);
  padding: 4px 8px;
}

.g1{ grid-column: span 3; grid-row: span 2; }
.g2{ grid-column: span 3; grid-row: span 1; }
.g3{ grid-column: span 2; grid-row: span 1; }
.g4{ grid-column: span 2; grid-row: span 1; }
.g5{ grid-column: span 2; grid-row: span 1; }

@media (max-width: 880px){
  .gal{ grid-template-columns: repeat(2, 1fr); grid-auto-rows: 160px; }
  .g1,.g2,.g3,.g4,.g5{ grid-column: span 1; grid-row: span 1; }
  .g1{ grid-column: span 2; grid-row: span 2; }
}

/* ─── VISIT ─── */
.visit-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: minmax(0, auto);
  gap: 16px;
}
.card{
  border:1px solid var(--line);
  padding: clamp(24px, 3vw, 38px);
  background: linear-gradient(180deg, #0c0a08, #080706);
  position:relative;
}
.card::before{
  content:""; position:absolute; top:14px; left:14px; width:24px; height:24px;
  border-top:1px solid var(--brass-lo); border-left:1px solid var(--brass-lo);
}
.card::after{
  content:""; position:absolute; bottom:14px; right:14px; width:24px; height:24px;
  border-bottom:1px solid var(--brass-lo); border-right:1px solid var(--brass-lo);
}
.card h3{
  font-family: var(--font-display);
  font-weight:400; font-size: 26px; margin: 8px 0 22px;
  color: var(--parchment);
}
.card .fineprint{
  font-family:var(--font-sans); font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color: var(--muted); margin-top:18px;
}

.hours dl{ margin:0; padding:0; }
.hours dl > div{
  display:flex; justify-content:space-between; align-items:baseline;
  padding: 10px 0;
  border-bottom: 1px dashed var(--line);
  font-size: 16px;
}
.hours dl > div:last-child{ border-bottom:none; }
.hours dt{ color: var(--cream); }
.hours dd{ margin:0; font-family: var(--font-sans); font-size:13px; letter-spacing:.18em; color: var(--brass-hi); }

.address .addr{
  font-family: var(--font-display); font-style:italic;
  font-size: 24px; line-height:1.4; color:var(--parchment);
  margin: 0 0 14px;
}
.address .link{
  display:inline-flex; gap:8px;
  font-family:var(--font-sans); font-size:11px; letter-spacing:.3em; text-transform:uppercase;
  color: var(--brass-hi);
  border-bottom:1px solid var(--brass-lo);
  padding: 4px 0;
  margin-top: 8px;
}

.contact .big-link{
  display:block;
  font-family: var(--font-display); font-weight:400;
  font-size: clamp(28px, 3vw, 40px);
  color: var(--parchment);
  letter-spacing:-.01em;
  margin: 0 0 8px;
  transition: color .3s;
}
.contact .big-link:hover{ color: var(--brass-hi); }
.contact .big-link.sub{
  font-size: 16px; font-style:italic; color: var(--muted); letter-spacing:0;
  word-break: break-all;
}

.mapplate{
  grid-column: 1 / -1;
  margin: 4px 0 0;
  border:1px solid var(--line);
  position:relative; overflow:hidden;
}
.mapplate svg{ display:block; width:100%; height: clamp(220px, 36vh, 320px); }
.mapplate::after{
  content:"— View on Google Maps ↗";
  position:absolute; right:18px; bottom:14px;
  font-family:var(--font-sans); font-size:10.5px; letter-spacing:.28em; text-transform:uppercase;
  color: var(--brass-hi);
  pointer-events:none;
}

@media (max-width: 880px){
  .visit-grid{ grid-template-columns: 1fr; }
}

/* ─── FOOTER ─── */
.foot{
  border-top: 1px solid var(--line);
  padding: clamp(60px, 8vh, 90px) var(--pad) 32px;
  background: linear-gradient(180deg, #060504 0%, #030302 100%);
  margin-top: 0;
}
.foot-mark{
  text-align:center; color: var(--brass-hi);
  margin-bottom: 50px;
}
.foot-mark .motto{
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(20px, 2.4vw, 30px);
  color: var(--parchment);
  margin: 14px 0 0;
}
.foot-cols{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  max-width: var(--maxw); margin: 0 auto;
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  padding: 30px 0;
}
.foot-cols > div{ display:flex; flex-direction:column; gap:8px; }
.foot-h{
  font-family:var(--font-sans); font-size:10.5px; letter-spacing:.3em; text-transform:uppercase;
  color: var(--brass);
  margin-bottom: 6px;
}
.foot-cols a, .foot-cols span{
  font-size: 15px; color: var(--cream); opacity:.78;
  transition: color .3s;
}
.foot-cols a:hover{ color: var(--brass-hi); opacity:1; }

.foot-bot{
  max-width: var(--maxw); margin: 22px auto 0;
  display:flex; align-items:center; gap:18px; flex-wrap:wrap; justify-content:space-between;
  font-family:var(--font-sans); font-size:10.5px; letter-spacing:.28em; text-transform:uppercase;
  color: var(--muted-2);
}
.foot-bot .rule{ flex:1; height:1px; background: var(--line); min-width: 40px; }

@media (max-width: 720px){
  .foot-cols{ grid-template-columns: 1fr; }
}

/* ─── REVEAL ─── */
.reveal{ opacity:0; transform: translateY(28px); transition: opacity 1s ease, transform 1s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform: none; }

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation: none !important; transition: none !important; }
  .reveal{ opacity:1; transform:none; }
}
