/* ================================================================
   SignatureForensics Australia — Redesign v2.0
   Design System: Swiss Modernism × Trust Authority × Glassmorphism
   Dials: VARIANCE:6 / MOTION:4 / DENSITY:4
   Palette: Burgundy #7B1A2D | Navy #0F172A | Gold #C9A84C | Slate #F8FAFC
   Fonts: Lexend (headings) + Source Sans 3 (body)
   ================================================================ */

/* --- GOOGLE FONTS --- */
@import url('https://fonts.googleapis.com/css2?family=Lexend:wght@300;400;500;600;700;800&family=Source+Sans+3:wght@300;400;500;600;700&display=swap');

/* --- RESET & BASE --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{
  font-family:'Source Sans 3','Inter',-apple-system,sans-serif;
  font-weight:400;
  font-size:16px;
  line-height:1.65;
  color:#0F172A;
  background:#F8FAFC;
  overflow-x:hidden;
}

/* --- CSS CUSTOM PROPERTIES --- */
:root{
  /* Brand */
  --color-primary:#7B1A2D;
  --color-primary-dark:#4A1024;
  --color-primary-light:#A52A3E;
  --color-secondary:#0F172A;
  --color-accent:#C9A84C;
  --color-accent-light:#E8D48B;

  /* Surfaces */
  --color-bg:#F8FAFC;
  --color-bg-alt:#F1F5F9;
  --color-surface:#FFFFFF;
  --color-surface-hover:#F8FAFC;
  --color-dark:#0A0B0F;
  --color-dark-surface:#111318;
  --color-dark-elevated:#171A21;

  /* Text */
  --color-text-primary:#0F172A;
  --color-text-secondary:#475569;
  --color-text-muted:#94A3B8;
  --color-text-on-dark:#E2E8F0;
  --color-text-on-brand:#FFFFFF;

  /* Borders */
  --color-border:#E2E8F0;
  --color-border-light:rgba(226,232,240,0.5);
  --color-border-dark:rgba(51,65,85,0.3);

  /* Glass */
  --glass-bg:rgba(255,255,255,0.7);
  --glass-border:rgba(255,255,255,0.3);
  --glass-blur:12px;
  --glass-dark-bg:rgba(15,23,42,0.85);
  --glass-dark-border:rgba(255,255,255,0.08);

  /* Spacing — 8px base unit */
  --space-xs:4px;
  --space-sm:8px;
  --space-md:16px;
  --space-lg:24px;
  --space-xl:32px;
  --space-2xl:48px;
  --space-3xl:64px;
  --space-4xl:96px;
  --space-section:clamp(4rem,8vw,8rem);

  /* Typography scale (1.25 ratio) */
  --text-xs:0.75rem;
  --text-sm:0.875rem;
  --text-base:1rem;
  --text-lg:1.125rem;
  --text-xl:1.25rem;
  --text-2xl:1.563rem;
  --text-3xl:1.953rem;
  --text-4xl:2.441rem;
  --text-5xl:3.052rem;
  --text-6xl:3.815rem;
  --text-hero:clamp(2.5rem,6vw,4.5rem);

  /* Radii */
  --radius-sm:6px;
  --radius-md:10px;
  --radius-lg:16px;
  --radius-xl:24px;
  --radius-full:9999px;

  /* Shadows */
  --shadow-sm:0 1px 2px rgba(0,0,0,0.05);
  --shadow-md:0 4px 6px rgba(0,0,0,0.07);
  --shadow-lg:0 10px 25px rgba(0,0,0,0.08);
  --shadow-xl:0 20px 50px rgba(0,0,0,0.12);
  --shadow-glow:0 0 30px rgba(123,26,45,0.15);
  --shadow-card-hover:0 8px 30px rgba(0,0,0,0.12);
  --shadow-gold-glow:0 0 20px rgba(201,168,76,0.15);

  /* Transitions */
  --ease-out:cubic-bezier(0.16,1,0.3,1);
  --ease-in-out:cubic-bezier(0.4,0,0.2,1);
  --transition-fast:150ms var(--ease-out);
  --transition-base:300ms var(--ease-out);
  --transition-slow:500ms var(--ease-out);

  /* Layout */
  --content-max:1280px;
  --content-narrow:780px;
}

/* --- TYPOGRAPHY --- */
h1,h2,h3,h4,h5,h6{
  font-family:'Lexend','Georgia',serif;
  font-weight:700;
  line-height:1.15;
  letter-spacing:-0.02em;
  color:var(--color-secondary);
  text-wrap:balance;
}
h1{font-size:var(--text-hero)}
h2{font-size:clamp(1.8rem,4vw,3rem)}
h3{font-size:var(--text-2xl)}
h4{font-size:var(--text-xl)}
h5{font-size:var(--text-lg)}
p{color:var(--color-text-secondary);margin-bottom:1rem}
.text-lead{font-size:var(--text-xl);font-weight:300;color:var(--color-text-secondary);max-width:65ch}
.text-muted{color:var(--color-text-muted)}
.text-accent{color:var(--color-accent)}

/* --- UTILITY CLASSES --- */
.container{width:100%;max-width:var(--content-max);margin-inline:auto;padding-inline:clamp(1rem,5vw,2rem)}
.container--narrow{max-width:var(--content-narrow)}
.section{padding-block:var(--space-section)}
.section--dark{background:var(--color-secondary);color:var(--color-text-on-dark)}
.section--primary{background:var(--color-primary);color:var(--color-text-on-brand)}
.section--alt{background:var(--color-bg-alt)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}

/* --- NAVIGATION --- */
.nav{
  position:fixed;
  top:0;left:0;right:0;
  z-index:1000;
  padding:clamp(0.5rem,1.5vw,1rem) 0;
  transition:all var(--transition-base);
}
.nav--scrolled{
  background:var(--glass-bg);
  backdrop-filter:blur(var(--glass-blur));
  -webkit-backdrop-filter:blur(var(--glass-blur));
  border-bottom:1px solid var(--glass-border);
  box-shadow:var(--shadow-sm);
}
.nav__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  max-width:var(--content-max);
  margin:0 auto;
  padding:0 clamp(1rem,5vw,2rem);
}
.nav__logo{display:flex;align-items:center;gap:var(--space-sm);text-decoration:none}
.nav__logo svg,.nav__logo img{height:44px;width:auto}
.nav__logo-text{font-family:'Lexend',serif;font-weight:700;font-size:1.1rem;color:var(--color-secondary)}
.nav__links{display:flex;align-items:center;gap:var(--space-lg);list-style:none}
.nav__links a{
  text-decoration:none;
  color:var(--color-text-secondary);
  font-weight:500;
  font-size:var(--text-sm);
  position:relative;
  padding:var(--space-xs) 0;
  transition:color var(--transition-fast);
}
.nav__links a::after{
  content:'';
  position:absolute;
  bottom:-2px;left:0;
  width:0;height:2px;
  background:var(--color-primary);
  transition:width var(--transition-base);
}
.nav__links a:hover{color:var(--color-primary)}
.nav__links a:hover::after{width:100%}
.nav__cta{
  background:var(--color-primary);
  color:white!important;
  padding:10px 24px!important;
  border-radius:var(--radius-full);
  font-weight:600!important;
  transition:all var(--transition-base)!important;
}
.nav__cta:hover{
  background:var(--color-primary-dark)!important;
  transform:translateY(-1px);
  box-shadow:var(--shadow-glow);
}
.nav__cta::after{display:none!important}
.nav__cta:hover::after{display:none!important}
.nav__mobile-toggle{
  display:none;
  background:none;border:none;
  cursor:pointer;
  padding:var(--space-sm);
}
.nav__mobile-toggle span{
  display:block;
  width:24px;height:2px;
  background:var(--color-secondary);
  margin:5px 0;
  transition:all var(--transition-base);
  border-radius:2px;
}

/* --- HERO --- */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  overflow:hidden;
  background:var(--color-secondary);
}
.hero__bg{
  position:absolute;
  inset:0;
  z-index:0;
}
.hero__bg img{
  width:100%;height:100%;
  object-fit:cover;
  opacity:0.45;
  filter:brightness(0.6) saturate(0.8);
}
.hero__overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(15,23,42,0.92) 0%,rgba(74,16,36,0.75) 50%,rgba(15,23,42,0.85) 100%);
  z-index:1;
}
.hero__accent-orb{
  position:absolute;
  border-radius:50%;
  filter:blur(80px);
  opacity:0.15;
  z-index:1;
  pointer-events:none;
}
.hero__accent-orb--top{
  width:500px;height:500px;
  background:var(--color-primary);
  top:-200px;right:-100px;
  animation:orbFloat 20s ease-in-out infinite;
}
.hero__accent-orb--bottom{
  width:400px;height:400px;
  background:var(--color-accent);
  bottom:-150px;left:-100px;
  animation:orbFloat 25s ease-in-out infinite reverse;
}
@keyframes orbFloat{
  0%,100%{transform:translate(0,0)}
  33%{transform:translate(30px,-30px)}
  66%{transform:translate(-20px,20px)}
}
.hero__content{
  position:relative;
  z-index:2;
  max-width:var(--content-max);
  margin:0 auto;
  padding:clamp(1rem,5vw,2rem);
  padding-top:120px;
}
.hero__badge{
  display:inline-flex;
  align-items:center;
  gap:var(--space-sm);
  background:var(--glass-dark-bg);
  backdrop-filter:blur(var(--glass-blur));
  border:1px solid var(--glass-dark-border);
  border-radius:var(--radius-full);
  padding:6px 18px;
  font-size:var(--text-sm);
  font-weight:500;
  color:var(--color-accent-light);
  margin-bottom:var(--space-xl);
  animation:fadeInUp 0.6s var(--ease-out);
}
.hero__badge-dot{
  width:8px;height:8px;
  border-radius:50%;
  background:var(--color-accent);
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:0.5;transform:scale(1.5)}
}
.hero__title{
  font-size:var(--text-hero);
  color:white;
  margin-bottom:var(--space-lg);
  line-height:1.08;
  animation:fadeInUp 0.6s var(--ease-out) 0.1s both;
}
.hero__title span{
  display:block;
  color:var(--color-accent-light);
  font-weight:300;
}
.hero__subtitle{
  font-size:var(--text-xl);
  color:var(--color-text-on-dark);
  max-width:600px;
  margin-bottom:var(--space-2xl);
  font-weight:300;
  animation:fadeInUp 0.6s var(--ease-out) 0.2s both;
}
.hero__actions{
  display:flex;
  gap:var(--space-md);
  flex-wrap:wrap;
  animation:fadeInUp 0.6s var(--ease-out) 0.3s both;
}
.hero__stats{
  display:flex;
  gap:var(--space-3xl);
  margin-top:var(--space-4xl);
  padding-top:var(--space-2xl);
  border-top:1px solid rgba(255,255,255,0.1);
  animation:fadeInUp 0.6s var(--ease-out) 0.4s both;
}
.hero__stat-number{
  font-family:'Lexend',serif;
  font-size:var(--text-4xl);
  font-weight:800;
  color:white;
  line-height:1;
}
.hero__stat-label{
  font-size:var(--text-sm);
  color:var(--color-text-muted);
  margin-top:var(--space-xs);
}

/* --- BUTTONS --- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:var(--space-sm);
  padding:14px 32px;
  border-radius:var(--radius-full);
  font-family:'Lexend',serif;
  font-weight:600;
  font-size:var(--text-sm);
  text-decoration:none;
  cursor:pointer;
  border:none;
  transition:all var(--transition-base);
  letter-spacing:0.02em;
  min-height:48px;
}
.btn--primary{
  background:var(--color-primary);
  color:white;
}
.btn--primary:hover{
  background:var(--color-primary-dark);
  transform:translateY(-2px);
  box-shadow:var(--shadow-glow);
}
.btn--secondary{
  background:transparent;
  color:white;
  border:1.5px solid rgba(255,255,255,0.3);
}
.btn--secondary:hover{
  border-color:white;
  background:rgba(255,255,255,0.08);
  transform:translateY(-2px);
}
.btn--outline{
  background:transparent;
  color:var(--color-primary);
  border:2px solid var(--color-primary);
}
.btn--outline:hover{
  background:var(--color-primary);
  color:white;
  transform:translateY(-2px);
}
.btn--ghost{
  background:transparent;
  color:var(--color-text-secondary);
  padding:8px 16px;
}
.btn--ghost:hover{color:var(--color-primary);background:var(--color-bg-alt)}
.btn--accent{
  background:var(--color-accent);
  color:var(--color-secondary);
}
.btn--accent:hover{
  background:var(--color-accent-light);
  transform:translateY(-2px);
  box-shadow:var(--shadow-gold-glow);
}
.btn__arrow{
  transition:transform var(--transition-fast);
  display:inline-flex;
}
.btn:hover .btn__arrow{transform:translateX(4px)}

/* --- SECTION HEADERS --- */
.section-header{
  text-align:center;
  margin-bottom:var(--space-3xl);
  max-width:700px;
  margin-inline:auto;
}
.section-header__label{
  font-family:'Lexend',serif;
  font-size:var(--text-sm);
  font-weight:600;
  color:var(--color-primary);
  text-transform:uppercase;
  letter-spacing:0.1em;
  margin-bottom:var(--space-md);
}
.section-header__title{
  margin-bottom:var(--space-md);
}
.section-header__description{
  color:var(--color-text-secondary);
  font-size:var(--text-lg);
  font-weight:300;
}

/* --- TRUST BADGES ROW --- */
.trust-badges{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:var(--space-2xl);
  flex-wrap:wrap;
  padding:var(--space-2xl) 0;
  opacity:0.7;
}
.trust-badges img{height:40px;width:auto;filter:grayscale(1);transition:all var(--transition-base)}
.trust-badges img:hover{filter:grayscale(0);opacity:1}

/* --- SERVICE CARDS (Glassmorphism) --- */
.services-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:var(--space-xl);
}
.service-card{
  position:relative;
  background:var(--color-surface);
  border:1px solid var(--color-border);
  border-radius:var(--radius-lg);
  padding:var(--space-2xl);
  transition:all var(--transition-base);
  overflow:hidden;
}
.service-card::before{
  content:'';
  position:absolute;
  top:0;left:0;
  width:100%;height:4px;
  background:linear-gradient(90deg,var(--color-primary),var(--color-accent));
  opacity:0;
  transition:opacity var(--transition-base);
}
.service-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-card-hover);
  border-color:transparent;
}
.service-card:hover::before{opacity:1}
.service-card__icon{
  width:56px;height:56px;
  border-radius:var(--radius-md);
  background:var(--color-bg-alt);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:var(--space-lg);
  transition:all var(--transition-base);
}
.service-card:hover .service-card__icon{
  background:var(--color-primary);
  color:white;
}
.service-card__icon svg{width:28px;height:28px}
.service-card__title{
  font-size:var(--text-xl);
  margin-bottom:var(--space-sm);
}
.service-card__desc{
  color:var(--color-text-secondary);
  font-size:var(--text-base);
  line-height:1.6;
  margin-bottom:var(--space-lg);
}
.service-card__link{
  font-family:'Lexend',serif;
  font-weight:600;
  font-size:var(--text-sm);
  color:var(--color-primary);
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:var(--space-xs);
  transition:gap var(--transition-fast);
}
.service-card__link:hover{gap:var(--space-sm)}

/* --- INSIGHT CARDS --- */
.insights-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(340px,1fr));
  gap:var(--space-xl);
}
.insight-card{
  background:var(--color-surface);
  border-radius:var(--radius-lg);
  overflow:hidden;
  border:1px solid var(--color-border);
  transition:all var(--transition-base);
}
.insight-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-card-hover);
  border-color:transparent;
}
.insight-card__image{
  width:100%;
  height:220px;
  object-fit:cover;
}
.insight-card__body{padding:var(--space-xl)}
.insight-card__tag{
  display:inline-block;
  font-size:var(--text-xs);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.05em;
  padding:4px 12px;
  border-radius:var(--radius-full);
  background:var(--color-bg-alt);
  color:var(--color-primary);
  margin-bottom:var(--space-md);
}
.insight-card__title{
  font-size:var(--text-xl);
  margin-bottom:var(--space-sm);
  line-height:1.3;
}
.insight-card__desc{
  color:var(--color-text-secondary);
  font-size:var(--text-sm);
  line-height:1.6;
  margin-bottom:var(--space-lg);
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.insight-card__meta{
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:var(--text-sm);
  color:var(--color-text-muted);
}

/* --- STATS BANNER --- */
.stats-banner{
  background:var(--color-secondary);
  padding:var(--space-3xl) 0;
  position:relative;
  overflow:hidden;
}
.stats-banner::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 20% 50%,rgba(123,26,45,0.2) 0%,transparent 50%),
    radial-gradient(circle at 80% 50%,rgba(201,168,76,0.1) 0%,transparent 50%);
}
.stats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:var(--space-xl);
  position:relative;
  z-index:1;
}
.stat-item{text-align:center}
.stat-item__number{
  font-family:'Lexend',serif;
  font-size:var(--text-5xl);
  font-weight:800;
  color:var(--color-accent-light);
  line-height:1;
}
.stat-item__label{
  font-size:var(--text-sm);
  color:var(--color-text-on-dark);
  margin-top:var(--space-sm);
  font-weight:400;
  opacity:0.7;
}

/* --- CTA BANNER --- */
.cta-banner{
  position:relative;
  background:var(--color-primary);
  border-radius:var(--radius-xl);
  padding:var(--space-3xl);
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--space-2xl);
  flex-wrap:wrap;
}
.cta-banner::before{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 70% 30%,rgba(201,168,76,0.15) 0%,transparent 60%);
}
.cta-banner__content{position:relative;z-index:1;flex:1}
.cta-banner__title{
  color:white;
  font-size:var(--text-3xl);
  margin-bottom:var(--space-sm);
}
.cta-banner__desc{color:rgba(255,255,255,0.8);font-size:var(--text-lg)}
.cta-banner__action{position:relative;z-index:1}

/* --- LOCATIONS GRID --- */
.locations-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:var(--space-md);
}
.location-card{
  background:var(--color-surface);
  border:1px solid var(--color-border);
  border-radius:var(--radius-md);
  padding:var(--space-lg);
  text-align:center;
  text-decoration:none;
  transition:all var(--transition-base);
  cursor:pointer;
}
.location-card:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
  border-color:var(--color-primary);
}
.location-card__city{
  font-family:'Lexend',serif;
  font-weight:600;
  font-size:var(--text-base);
  color:var(--color-secondary);
  margin-bottom:var(--space-xs);
}
.location-card__state{
  font-size:var(--text-sm);
  color:var(--color-text-muted);
}

/* --- FOOTER --- */
.footer{
  background:var(--color-dark);
  color:var(--color-text-on-dark);
  padding:var(--space-3xl) 0 var(--space-xl);
}
.footer__grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:var(--space-2xl);
  margin-bottom:var(--space-3xl);
}
.footer__brand-desc{
  color:var(--color-text-muted);
  font-size:var(--text-sm);
  margin-top:var(--space-md);
  max-width:300px;
}
.footer__heading{
  font-family:'Lexend',serif;
  font-weight:600;
  font-size:var(--text-sm);
  color:white;
  text-transform:uppercase;
  letter-spacing:0.05em;
  margin-bottom:var(--space-lg);
}
.footer__links{list-style:none}
.footer__links li{margin-bottom:var(--space-sm)}
.footer__links a{
  color:var(--color-text-muted);
  text-decoration:none;
  font-size:var(--text-sm);
  transition:color var(--transition-fast);
}
.footer__links a:hover{color:white}
.footer__bottom{
  border-top:1px solid var(--color-border-dark);
  padding-top:var(--space-xl);
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:var(--space-md);
  font-size:var(--text-sm);
  color:var(--color-text-muted);
}
.footer__social{display:flex;gap:var(--space-md)}
.footer__social a{
  width:40px;height:40px;
  border-radius:50%;
  border:1px solid var(--color-border-dark);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--color-text-muted);
  text-decoration:none;
  transition:all var(--transition-fast);
}
.footer__social a:hover{
  border-color:var(--color-accent);
  color:var(--color-accent);
  background:rgba(201,168,76,0.1);
}

/* --- SCROLL REVEAL ANIMATIONS --- */
.reveal{
  opacity:0;
  transform:translateY(30px);
  transition:opacity 0.7s var(--ease-out),transform 0.7s var(--ease-out);
}
.reveal--visible{opacity:1;transform:translateY(0)}
.reveal--delay-1{transition-delay:0.1s}
.reveal--delay-2{transition-delay:0.2s}
.reveal--delay-3{transition-delay:0.3s}
.reveal--delay-4{transition-delay:0.4s}

@keyframes fadeInUp{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}

/* --- PARALLAX --- */
.parallax-bg{
  background-attachment:fixed;
  background-position:center;
  background-repeat:no-repeat;
  background-size:cover;
}

/* --- MOBILE --- */
@media(max-width:1024px){
  .footer__grid{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .hero__stats{flex-wrap:wrap;gap:var(--space-xl)}
}
@media(max-width:768px){
  .nav__links{display:none}
  .nav__mobile-toggle{display:block}
  .nav__links--open{
    display:flex;
    flex-direction:column;
    position:absolute;
    top:100%;left:0;right:0;
    background:var(--glass-bg);
    backdrop-filter:blur(var(--glass-blur));
    padding:var(--space-xl);
    gap:var(--space-md);
    border-bottom:1px solid var(--glass-border);
  }
  .hero__content{padding-top:100px}
  .services-grid{grid-template-columns:1fr}
  .insights-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr}
  .cta-banner{flex-direction:column;text-align:center;padding:var(--space-2xl)}
  .footer__grid{grid-template-columns:1fr}
  .locations-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:480px){
  .hero__actions{flex-direction:column}
  .hero__actions .btn{width:100%;justify-content:center}
  .locations-grid{grid-template-columns:repeat(2,1fr)}
  .trust-badges{gap:var(--space-lg)}
}

/* --- REDUCED MOTION --- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:0.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:0.01ms!important;
  }
  html{scroll-behavior:auto}
  .parallax-bg{background-attachment:scroll}
  .reveal{opacity:1;transform:none}
}

/* --- FOCUS VISIBLE --- */
:focus-visible{
  outline:2px solid var(--color-primary);
  outline-offset:2px;
  border-radius:2px;
}

/* --- SELECTION --- */
::selection{background:var(--color-primary);color:white}
