/* ============================================================
   Plyx Studio — Editorial, premium, serif-led
   ============================================================ */

:root{
  --paper:        #F8F8F8;   /* pale grey — primary page background */
  --paper-2:      #FFFFFF;   /* uniform white — cards and section variations */
  --ink:          #161412;   /* deep ink */
  --ink-soft:     #2A2521;
  --muted:        #6B645B;
  --rule:         rgba(22,20,18,.14);
  --rule-strong:  rgba(22,20,18,.32);
  --accent:       #B5421E;   /* terracotta */
  --accent-deep:  #8C2F12;

  --serif: "Fraunces", "Cormorant Garamond", "Times New Roman", serif;
  --sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --container: 1320px;
  --gutter: 32px;

  --t-fast:   .25s cubic-bezier(.2,.7,.2,1);
  --t-mid:    .55s cubic-bezier(.2,.7,.2,1);
  --t-slow:   1.1s cubic-bezier(.2,.7,.2,1);
}

*{ box-sizing:border-box; }
html,body{
  margin:0; padding:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body{
  overflow-x:hidden;
  background:
    radial-gradient(1200px 700px at 90% -10%, rgba(181,66,30,.07), transparent 60%),
    radial-gradient(900px 600px at -10% 30%, rgba(22,20,18,.05), transparent 60%),
    var(--paper);
}
img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:0; cursor:pointer; }

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

/* Page paper grain */
body::before{
  content:"";
  position:fixed; inset:0;
  pointer-events:none;
  z-index:1;
  opacity:.35;
  mix-blend-mode:multiply;
  background-image:
    radial-gradient(rgba(22,20,18,.05) 1px, transparent 1.2px);
  background-size: 3px 3px;
}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed; top:0; left:0; right:0;
  z-index:50;
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  align-items:center;
  padding: 22px clamp(20px, 4vw, 56px);
  transition: background var(--t-mid), border-color var(--t-mid), padding var(--t-mid);
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(248,248,248,.82);
  backdrop-filter: blur(14px) saturate(1.05);
  -webkit-backdrop-filter: blur(14px) saturate(1.05);
  border-bottom-color: var(--rule);
  padding-top:14px; padding-bottom:14px;
}

.brand{
  display:inline-flex; align-items:center; gap:12px;
  font-family:var(--serif);
  font-weight:500;
  font-size:22px;
  letter-spacing:-.01em;
  color:var(--ink);
}
.brand-mark{ width:30px; height:30px; }
.brand-word{ line-height:1; }
.brand-ital{ font-style:italic; font-weight:400; opacity:.85; }

.site-nav{
  justify-self:center;
  display:flex; gap:34px;
  font-family:var(--sans);
  font-size:13px;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--ink-soft);
}
.site-nav a{ position:relative; padding:6px 0; }
.site-nav a::after{
  content:""; position:absolute; left:0; right:100%;
  bottom:2px; height:1px; background:var(--ink);
  transition: right var(--t-mid);
}
.site-nav a:hover::after{ right:0; }

.header-cta{
  justify-self:end;
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 18px;
  border:1px solid var(--ink);
  border-radius: 999px;
  font-size:13px; letter-spacing:.04em; text-transform:uppercase;
  background:transparent;
  transition: background var(--t-fast), color var(--t-fast);
}
.header-cta svg{ width:14px; height:14px; }
.header-cta:hover{ background:var(--ink); color:var(--paper); }

@media (max-width: 820px){
  .site-header{ grid-template-columns: 1fr auto; padding:16px 20px; }
  .site-nav{ display:none; }
  .header-cta{ padding:9px 14px; font-size:12px; }
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;
  padding: 180px clamp(20px, 4vw, 56px) 60px;
  max-width: var(--container);
  margin: 0 auto;
}

.hero-meta{
  display:flex; align-items:center; gap:14px;
  font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--muted);
  margin-bottom:64px;
  opacity:0; transform: translateY(8px);
  animation: rise .9s var(--t-mid) .1s forwards;
}
.hero-meta .dot{
  width:7px; height:7px; border-radius:50%;
  background:var(--accent);
  box-shadow: 0 0 0 4px rgba(181,66,30,.18);
  animation: pulse 2.2s ease-in-out infinite;
}
.meta-sep{ opacity:.45; }

.hero-title{
  font-family:var(--serif);
  font-weight:300;
  font-variation-settings:"opsz" 144;
  font-size: clamp(56px, 10vw, 160px);
  line-height:.95;
  letter-spacing:-.035em;
  color:var(--ink);
  margin:0 0 80px;
  max-width: 18ch;
}
.hero-title em{
  font-style:italic; font-weight:300;
  color:var(--accent-deep);
}
.hero-title .line{
  display:block;
  overflow:hidden;
}
.hero-title .line > *,
.hero-title .line{ will-change: transform; }
.hero-title .line{
  animation: rise 1.1s cubic-bezier(.2,.75,.2,1) forwards;
  opacity:0; transform: translateY(40%);
}
.hero-title .line:nth-child(1){ animation-delay:.10s; }
.hero-title .line:nth-child(2){ animation-delay:.22s; }
.hero-title .line:nth-child(3){ animation-delay:.34s; }
.hero-title .line:nth-child(4){ animation-delay:.46s; }

.hero-foot{
  display:grid;
  grid-template-columns: 1fr auto;
  align-items:end;
  gap:48px;
  padding-top:48px;
  border-top:1px solid var(--rule);
}
.hero-lede{
  margin:0;
  max-width: 52ch;
  font-size: clamp(16px, 1.25vw, 19px);
  line-height:1.55;
  color: var(--ink-soft);
}
.hero-arrow{
  display:inline-flex; align-items:center; justify-content:center;
  width:74px; height:74px;
  border-radius:50%;
  border:1px solid var(--ink);
  color:var(--ink);
  transition: background var(--t-fast), color var(--t-fast), transform var(--t-mid);
}
.hero-arrow svg{ width:24px; height:24px; }
.hero-arrow:hover{
  background:var(--ink); color:var(--paper);
  transform: translateY(4px);
}

/* Ticker */
.ticker{
  margin-top:120px;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  overflow:hidden;
  padding: 22px 0;
  font-family:var(--serif);
  font-style:italic;
  font-weight:400;
  font-size: clamp(26px, 3.4vw, 46px);
  color:var(--ink);
}
.ticker-track{
  display:flex; align-items:center; gap:36px;
  white-space:nowrap;
  width:max-content;
  animation: marquee 38s linear infinite;
}
.ticker-track span{ flex:0 0 auto; }
.ticker-track span + span{ /* spacing handled by gap */ }
.ticker-track span:nth-child(2n){
  font-family:var(--sans); font-style:normal; font-size:.5em; color:var(--muted);
}

/* ============================================================
   SECTION HEADINGS
   ============================================================ */
.section-head{
  padding: 140px clamp(20px, 4vw, 56px) 56px;
  max-width: var(--container);
  margin:0 auto;
}
.eyebrow{
  display:inline-block;
  font-family:var(--sans);
  font-size:12px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--muted);
  padding-bottom:14px;
  margin-bottom:28px;
  border-bottom:1px solid var(--rule);
}
.section-title{
  font-family:var(--serif);
  font-weight:400;
  font-size: clamp(40px, 6vw, 88px);
  line-height:1.02;
  letter-spacing:-.025em;
  margin:0 0 22px;
  max-width: 16ch;
}
.section-title em{
  font-style:italic; color:var(--accent-deep); font-weight:400;
}
.section-sub{
  margin:0;
  max-width: 56ch;
  font-size:17px;
  color:var(--muted);
  line-height:1.6;
}

/* ============================================================
   SERVICES
   ============================================================ */
.services{
  padding-bottom: 60px;
}
.service-list{
  list-style:none; padding: 0 clamp(20px, 4vw, 56px); margin: 0 auto;
  max-width:var(--container);
  border-top:1px solid var(--rule-strong);
}
.service{
  display:grid;
  grid-template-columns: 100px 1fr;
  gap:48px;
  padding: 56px 0 60px;
  border-bottom:1px solid var(--rule);
  position:relative;
  transition: background var(--t-mid);
}
.service .num{
  font-family:var(--serif);
  font-style:italic; font-weight:300;
  font-size:36px;
  color:var(--accent);
  line-height:1;
  padding-top:8px;
}
.svc-body{
  display:grid;
  grid-template-columns: 2fr 3fr;
  gap:56px;
  align-items:start;
}
.svc-body h3{
  font-family:var(--serif);
  font-weight:400;
  font-size: clamp(28px, 3.4vw, 44px);
  line-height:1.05;
  letter-spacing:-.02em;
  margin:0;
}
.svc-body p{
  margin:0 0 22px;
  font-size:17px;
  line-height:1.6;
  color:var(--ink-soft);
  max-width:48ch;
}
.tags{
  display:flex; flex-wrap:wrap; gap:8px;
  list-style:none; padding:0; margin:0;
}
.tags li{
  font-size:12px;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--ink-soft);
  padding:7px 13px;
  border:1px solid var(--rule-strong);
  border-radius:999px;
  background:rgba(255,255,255,.35);
}

@media (max-width: 820px){
  .service{ grid-template-columns: 60px 1fr; gap:20px; padding:36px 0; }
  .service .num{ font-size:24px; }
  .svc-body{ grid-template-columns: 1fr; gap:18px; }
}

/* ============================================================
   WORK
   ============================================================ */
.work{
  padding-bottom: 60px;
}
.case{
  display:grid;
  gap:28px;
  padding: 0 clamp(20px, 4vw, 56px);
  max-width: var(--container);
  margin: 0 auto 80px;
}
.case.feature{
  grid-template-columns: 1.4fr 1fr;
  gap:64px;
  align-items:end;
}
.case-row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  padding: 0 clamp(20px, 4vw, 56px);
  max-width: var(--container);
  margin: 0 auto 80px;
}
.case-row .case{ padding:0; max-width:none; margin:0; }

.case-media{
  display:block;
  position:relative;
  aspect-ratio: 4/5;
  overflow:hidden;
  border-radius: 4px;
  border:1px solid var(--rule);
  transition: transform var(--t-mid);
}
.case.feature .case-media{ aspect-ratio: 5/6; }
.case-media:hover{ transform: translateY(-3px); }

.case-meta{
  display:flex; flex-direction:column; gap:12px;
}
.case-year{
  font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--muted);
}
.case-title{
  font-family:var(--serif);
  font-weight:400;
  font-size: clamp(26px, 2.6vw, 38px);
  line-height:1.1;
  letter-spacing:-.02em;
  margin:0;
}
.case-title em{ font-style:italic; color:var(--muted); font-weight:300; }
.case-meta p{
  margin:0; color:var(--ink-soft); font-size:16px; line-height:1.55; max-width: 46ch;
}
.case-tags{
  list-style:none; padding:0; margin:6px 0 0;
  display:flex; flex-wrap:wrap; gap:8px;
  font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--muted);
}
.case-tags li{ padding-right:8px; border-right:1px solid var(--rule-strong); }
.case-tags li:last-child{ border-right:0; }
.case-cta{
  display:inline-flex; align-items:center; gap:10px;
  font-size:13px; letter-spacing:.06em; text-transform:uppercase;
  margin-top:14px;
}
.case-cta svg{ width:14px; height:14px; transition: transform var(--t-fast); }
.case:hover .case-cta svg{ transform: translateX(4px); }

@media (max-width: 900px){
  .case.feature, .case-row{ grid-template-columns: 1fr; gap:24px; }
  .case-row{ gap:60px; }
}

/* Case media art (CSS-only artwork) */
.art{
  position:absolute; inset:0;
  display:flex; flex-direction:column; justify-content:space-between;
  padding: 36px;
  font-family:var(--serif);
  color:var(--ink);
  overflow:hidden;
}
.art::after{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(120% 80% at 50% -10%, rgba(255,255,255,.6), transparent 60%),
    radial-gradient(60% 40% at 100% 100%, rgba(22,20,18,.08), transparent 60%);
  pointer-events:none;
}

/* Maren — soft cream with grid */
.art-maren{
  background: linear-gradient(180deg, #E9DDC9 0%, #D8C7AC 100%);
}
.art-maren .art-grid{
  display:grid; grid-template-columns:repeat(4, 1fr);
  gap:1px;
  position:absolute; inset:28px;
  border:1px solid rgba(22,20,18,.18);
}
.art-maren .art-grid span{
  background:
    linear-gradient(180deg, rgba(255,255,255,.12), rgba(22,20,18,.04));
  border:1px solid rgba(22,20,18,.06);
}
.art-maren .art-tag{
  position:relative;
  font-style:italic; font-size:22px; letter-spacing:.02em;
  align-self:start;
  background:rgba(242,236,225,.85);
  padding:6px 12px; border-radius:2px;
  width:max-content;
  z-index:2;
}
.art-maren .art-rule{
  position:absolute; left:36px; right:36px; bottom:88px;
  height:1px; background: rgba(22,20,18,.4);
  z-index:2;
}
.art-maren .art-cap{
  position:relative; z-index:2;
  font-family:var(--sans);
  font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-soft);
}

/* Halden — paper with big serif */
.art-halden{
  background: linear-gradient(180deg, #F4ECDB 0%, #E6D6B6 100%);
}
.art-halden .art-headline{
  font-family:var(--serif);
  font-style:italic; font-weight:300;
  font-size: clamp(50px, 8vw, 110px);
  line-height:.9;
  letter-spacing:-.03em;
  align-self:start;
  position:relative; z-index:2;
}
.art-halden .art-meta{
  position:relative; z-index:2;
  display:flex; gap:10px;
  font-family:var(--sans);
  font-size:12px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-soft);
}
.art-halden .art-num{
  position:absolute; right:30px; top:30px;
  font-family:var(--serif);
  font-weight:300;
  font-size:18px; letter-spacing:.06em;
  border:1px solid rgba(22,20,18,.4);
  padding:6px 10px; border-radius:2px;
  z-index:2;
}

/* Northform — deep ink with arcs */
.art-northform{
  background: linear-gradient(180deg, #1F1B17 0%, #2D261F 100%);
  color:#F2ECE1;
}
.art-northform::after{
  background: radial-gradient(60% 40% at 50% 0%, rgba(255,255,255,.12), transparent 60%);
}
.art-northform .art-arc{
  position:absolute;
  width:140%; height:140%;
  left:50%; top:60%;
  transform: translate(-50%, 0);
  border:1px solid rgba(242,236,225,.18);
  border-radius:50%;
}
.art-northform .art-arc-2{
  width:90%; height:90%;
  border-color: rgba(181,66,30,.5);
}
.art-northform .art-mono{
  position:relative; z-index:2;
  font-family:var(--serif);
  font-weight:300;
  font-size: clamp(60px, 9vw, 120px);
  align-self:start;
  letter-spacing:-.04em;
}
.art-northform .art-cap{
  position:relative; z-index:2;
  font-family:var(--sans);
  font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  color: rgba(242,236,225,.7);
}

/* Solène — terracotta wash with circle */
.art-solene{
  background:
    radial-gradient(60% 60% at 50% 60%, #D86A3F 0%, #B5421E 50%, #7E2A0F 100%);
  color:#F4E9DC;
}
.art-solene::after{
  background:
    radial-gradient(80% 60% at 50% 20%, rgba(255,255,255,.18), transparent 60%);
}
.art-solene .art-circle{
  position:absolute;
  width:60%; aspect-ratio:1;
  left:50%; top:55%; transform: translate(-50%, -50%);
  border:1px solid rgba(244,233,220,.6);
  border-radius:50%;
}
.art-solene .art-word{
  position:relative; z-index:2;
  align-self:flex-end;
  font-family:var(--serif);
  font-style:italic; font-weight:300;
  font-size: clamp(50px, 7vw, 96px);
  letter-spacing:-.02em;
}
.art-solene .art-cap{
  position:relative; z-index:2;
  font-family:var(--sans);
  font-size:12px; letter-spacing:.18em; text-transform:uppercase;
}

/* Ostra — paper-2 stacked O */
.art-ostra{
  background: linear-gradient(180deg, #EDE5D6 0%, #D9CDB8 100%);
}
.art-ostra .art-stack{
  position:relative; z-index:2;
  display:flex; flex-direction:column;
  font-family:var(--serif);
  font-weight:300;
  font-size: clamp(70px, 9vw, 130px);
  line-height:.85;
  letter-spacing:-.04em;
  color:var(--ink);
  align-self:flex-start;
}
.art-ostra .art-stack span:nth-child(1){ opacity:1; }
.art-ostra .art-stack span:nth-child(2){ opacity:.55; padding-left:.4em; }
.art-ostra .art-stack span:nth-child(3){ opacity:.25; padding-left:.8em; }
.art-ostra .art-cap{
  position:relative; z-index:2;
  font-family:var(--sans);
  font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-soft);
}

.work-foot{
  max-width: var(--container);
  margin: 0 auto;
  padding: 24px clamp(20px, 4vw, 56px) 40px;
  border-top:1px solid var(--rule);
  display:flex; justify-content:flex-end;
}
.link-arrow{
  display:inline-flex; align-items:center; gap:12px;
  font-family:var(--serif);
  font-style:italic;
  font-size: clamp(22px, 2.4vw, 32px);
  color:var(--ink);
}
.link-arrow svg{ width:22px; height:22px; transition: transform var(--t-fast); }
.link-arrow:hover svg{ transform: translateX(6px); }

/* ============================================================
   CONTACT
   ============================================================ */
.contact{
  padding-bottom: 140px;
  position:relative;
}
.contact .section-head{ padding-bottom: 40px; }
.contact-title{
  max-width: 14ch;
  font-size: clamp(48px, 8vw, 124px);
  line-height:1.0;
}

.contact-grid{
  display:grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 80px;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 clamp(20px, 4vw, 56px);
}
.contact-form{
  display:flex; flex-direction:column;
  gap:28px;
  padding-top: 24px;
  border-top: 1px solid var(--rule-strong);
}
.row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:28px;
}
.field{ display:flex; flex-direction:column; gap:8px; }
.field label{
  font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--muted);
}
.field input,
.field textarea{
  font-family:var(--serif);
  font-weight:300;
  font-size:22px;
  line-height:1.3;
  color:var(--ink);
  background:transparent;
  border:0;
  border-bottom:1px solid var(--rule-strong);
  padding: 10px 2px 12px;
  outline:none;
  transition: border-color var(--t-fast);
  resize:vertical;
}
.field input:focus,
.field textarea:focus{
  border-bottom-color:var(--ink);
}

.chips{
  display:flex; flex-wrap:wrap; gap:8px;
  padding-top:6px;
}
.chip{
  font-family:var(--sans);
  font-size:13px; letter-spacing:.04em;
  padding:9px 16px;
  border:1px solid var(--rule-strong);
  border-radius:999px;
  background:transparent;
  color:var(--ink-soft);
  transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
}
.chip:hover{ border-color:var(--ink); }
.chip.active{
  background:var(--ink); color:var(--paper); border-color:var(--ink);
}

.submit{
  align-self:flex-start;
  display:inline-flex; align-items:center; gap:14px;
  margin-top: 12px;
  padding: 18px 28px;
  border-radius: 999px;
  background:var(--ink);
  color:var(--paper);
  font-size:13px; letter-spacing:.16em; text-transform:uppercase;
  transition: background var(--t-fast), transform var(--t-fast);
}
.submit:hover{ background:var(--accent-deep); transform: translateY(-1px); }
.submit svg{ width:16px; height:16px; }

.form-note{
  margin: 4px 0 0; font-size:13px; color:var(--accent-deep);
  min-height:18px;
}

.contact-side{
  display:flex; flex-direction:column;
  gap:36px;
  padding-top:24px;
  border-top:1px solid var(--rule-strong);
}
.side-block{ display:flex; flex-direction:column; gap:6px; }
.side-label{
  font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--muted);
}
.side-mail{
  font-family:var(--serif);
  font-style:italic;
  font-size: clamp(24px, 2.4vw, 30px);
  border-bottom:1px solid transparent;
  transition: border-color var(--t-fast);
  align-self:flex-start;
}
.side-mail:hover{ border-bottom-color: var(--ink); }
.side-block p{ margin:0; color:var(--ink-soft); line-height:1.5; }
.elsewhere{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column; gap:6px;
}
.elsewhere a{
  display:inline-flex; gap:8px;
  font-size:15px;
  border-bottom:1px solid var(--rule);
  padding:6px 0;
  width: max-content;
}
.elsewhere a span{ color:var(--muted); }
.elsewhere a:hover{ border-bottom-color: var(--ink); }

@media (max-width: 900px){
  .contact-grid{ grid-template-columns:1fr; gap:48px; }
  .row{ grid-template-columns:1fr; }
}

/* ============================================================
   FOOTER
   ============================================================ */
.site-foot{
  border-top: 1px solid var(--rule-strong);
  padding: 36px clamp(20px, 4vw, 56px) 28px;
  max-width: var(--container);
  margin: 0 auto;
  font-size:13px;
  color:var(--muted);
}
.foot-row{
  display:flex; justify-content:space-between; align-items:center; gap:24px;
  padding: 14px 0;
  flex-wrap:wrap;
}
.foot-row + .foot-row{ border-top:1px solid var(--rule); }
.foot-brand{
  font-family:var(--serif); font-style:italic; font-weight:400;
  color:var(--ink); font-size:18px;
}
.foot-tag{ color:var(--muted); }
.foot-row-2{ font-size:12px; letter-spacing:.08em; text-transform:uppercase; }
.foot-row-2 a{ border-bottom:1px solid var(--rule-strong); padding-bottom:2px; }
.foot-row-2 a:hover{ border-bottom-color: var(--ink); color:var(--ink); }

/* ============================================================
   Cursor blob (desktop only)
   ============================================================ */
.cursor{
  position:fixed; top:0; left:0;
  width:22px; height:22px;
  border-radius:50%;
  background: rgba(181,66,30,.7);
  pointer-events:none;
  z-index:60;
  transform: translate(-50%, -50%);
  mix-blend-mode: multiply;
  transition: width .25s ease, height .25s ease, background .25s ease, opacity .25s;
  opacity:0;
}
@media (hover:hover) and (pointer:fine){
  .cursor{ opacity:.85; }
  .cursor.is-link{
    width:48px; height:48px;
    background: rgba(22,20,18,.85);
  }
}

/* ============================================================
   Reveal-on-scroll
   ============================================================ */
.reveal{
  opacity:0;
  transform: translateY(28px);
  transition: opacity .9s var(--t-mid), transform .9s var(--t-mid);
}
.reveal.in{
  opacity:1;
  transform: none;
}

/* ============================================================
   Keyframes
   ============================================================ */
@keyframes rise{
  from{ opacity:0; transform: translateY(40%); }
  to  { opacity:1; transform: translateY(0); }
}
@keyframes pulse{
  0%,100%{ box-shadow: 0 0 0 4px rgba(181,66,30,.18); }
  50%   { box-shadow: 0 0 0 9px rgba(181,66,30,0);  }
}
@keyframes marquee{
  from{ transform: translateX(0); }
  to  { transform: translateX(-50%); }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *,
  *::before,
  *::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
  }
}
