/* ==========================================================================
   PDG BLUE METAL — Stylesheet
   A construction-materials supplier site built around the brand's own
   quarry badge. Signature motif: the "gradation bar" — a graded strip of
   swatches echoing how aggregate is sieved and sold by size (40mm down to
   dust). It marks section breaks and product cards throughout the site.
   ========================================================================== */

/* -------------------------------- Icon system (Lucide) -------------------------------- */
/* Lucide icons inherit currentColor by default and default to a 2px stroke;
   thinning to 1.75px keeps the same light, premium line weight the original
   sprite icons used. Existing size rules (svg{...}) elsewhere in this file
   continue to apply unchanged since Lucide renders a plain <svg> in place
   of each <i data-lucide> element. */
svg.lucide{
  stroke-width: 1.75px;
  display: inline-block;
  vertical-align: middle;
  flex-shrink: 0;
}

/* -------------------------------- Tokens -------------------------------- */
:root{
  /* Brand palette (from brief) */
  --color-primary:        #0B3D91;   /* dark blue   */
  --color-primary-dark:   #082a68;   /* pressed/hover state of primary */
  --color-secondary:      #F7931E;   /* construction orange */
  --color-secondary-dark: #d97a0a;
  --color-bg:              #FFFFFF;
  --color-accent-light:   #F4F5F7;   /* light grey section bg */

  /* Supporting neutrals, derived from the primary blue so everything
     reads as one family rather than bolted-on greys */
  --color-ink:      #101A2E;   /* body copy / headings */
  --color-ink-soft: #45506B;   /* secondary copy */
  --color-stone:    #8891A3;   /* captions, meta */
  --color-line:     #E3E6EC;   /* hairline borders */
  --color-line-soft:#EEF0F4;

  /* Gradation-bar swatch tones (coarse -> fine) */
  --grade-1: #0B3D91;
  --grade-2: #345BA0;
  --grade-3: #6B7FA8;
  --grade-4: #C9A46B;
  --grade-5: #F7931E;

  /* Type */
  --font-display: 'Montserrat', 'Segoe UI', Arial, sans-serif;
  --font-body: 'Inter', 'Segoe UI', Arial, sans-serif;

  /* Layout */
  --container-max: 1240px;
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 18px;
  --shadow-sm: 0 2px 10px rgba(11,61,145,0.07);
  --shadow-md: 0 12px 32px rgba(11,61,145,0.12);
  --shadow-lg: 0 24px 60px rgba(11,61,145,0.18);
  --header-h: 84px;
  --ease: cubic-bezier(.4,0,.2,1);
}

/* -------------------------------- Reset ---------------------------------- */
*, *::before, *::after{ box-sizing: border-box; }
html{
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--header-h) + 16px);
}
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior: auto; }
  *, *::before, *::after{
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
body{
  margin:0;
  font-family: var(--font-body);
  color: var(--color-ink);
  background: var(--color-bg);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img{ max-width:100%; display:block; }
a{ color: inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
button{ font-family: inherit; cursor:pointer; }
h1,h2,h3,h4{
  font-family: var(--font-display);
  color: var(--color-ink);
  margin: 0 0 .6em;
  line-height: 1.15;
  letter-spacing: -0.015em;
}
p{ margin: 0 0 1.1em; color: var(--color-ink-soft); }
.container{
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: 24px;
}
:focus-visible{
  outline: 3px solid var(--color-secondary);
  outline-offset: 3px;
  border-radius: 2px;
}
.skip-link{
  position:absolute; left:-999px; top:0; z-index:2000;
  background:var(--color-primary); color:#fff; padding:12px 20px;
  border-radius:0 0 8px 0; font-weight:600;
}
.skip-link:focus{ left:0; }

/* ------------------------------ Type scale ------------------------------- */
.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-family: var(--font-body);
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--color-secondary-dark);
  margin-bottom: 14px;
}
.eyebrow::before{
  content:"";
  width: 26px; height: 3px;
  background: var(--color-secondary);
  border-radius: 2px;
  display:inline-block;
}
h1{ font-weight: 800; font-size: clamp(2.3rem, 4.6vw, 3.85rem); }
h2{ font-weight: 800; font-size: clamp(1.85rem, 3vw, 2.55rem); }
h3{ font-weight: 700; font-size: 1.3rem; }
.section-head{ max-width: 640px; margin-bottom: 44px; }
.section-head.centered{ margin-inline:auto; text-align:center; }
.lede{ font-size: 1.1rem; color: var(--color-ink-soft); }

/* -------------------------------- Buttons -------------------------------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: .92rem;
  letter-spacing: .03em;
  padding: 15px 28px;
  border-radius: var(--radius-sm);
  border: 2px solid transparent;
  transition: transform .22s var(--ease), box-shadow .22s var(--ease), background .22s var(--ease), color .22s var(--ease), border-color .22s var(--ease);
  white-space: nowrap;
}
.btn svg{ width:18px; height:18px; flex-shrink:0; }
.btn-primary{
  background: var(--color-secondary);
  color: #17130B;
}
.btn-primary:hover{
  background: var(--color-secondary-dark);
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(247,147,30,0.35);
}
.btn-outline{
  background: transparent;
  border-color: rgba(255,255,255,0.55);
  color: currentColor;
}
.btn-outline:hover{
  background: rgba(255,255,255,0.12);
  border-color: #fff;
  transform: translateY(-2px);
}
.btn-outline.on-light{ border-color: var(--color-primary); color: var(--color-primary); }
.btn-outline.on-light:hover{ background: var(--color-primary); color:#fff; }
.btn-quote{
  background: var(--color-primary);
  color: #fff;
  padding: 12px 22px;
  font-size: .85rem;
  width: 100%;
}
.btn-quote:hover{
  background: var(--color-secondary);
  color: #17130B;
  transform: translateY(-2px);
  box-shadow: 0 10px 22px rgba(247,147,30,0.3);
}
.btn-block{ width:100%; }

/* ---------------------------- Gradation bar ------------------------------
   Signature element. A row of tone/texture swatches running coarse -> fine,
   used as a divider and as a card accent. Purely decorative to assistive
   tech (aria-hidden). */
.gradation-bar{
  display:flex; width:100%; height:16px; border-radius: 4px; overflow:hidden;
  box-shadow: inset 0 0 0 1px rgba(11,61,145,0.08);
}
.gradation-bar span{ flex:1; }
.gradation-bar span:nth-child(1){ background: var(--grade-1); }
.gradation-bar span:nth-child(2){ background: var(--grade-2); }
.gradation-bar span:nth-child(3){ background: var(--grade-3); }
.gradation-bar span:nth-child(4){ background: var(--grade-4); }
.gradation-bar span:nth-child(5){ background: var(--grade-5); }
.gradation-divider{
  display:flex; align-items:center; gap:18px;
  margin: 0 auto;
  max-width: var(--container-max);
  padding-inline: 24px;
}
.gradation-divider .gradation-bar{ height:10px; }
.gradation-divider .grade-labels{
  display:flex; justify-content:space-between;
  font-size:.68rem; font-weight:700; letter-spacing:.1em;
  color: var(--color-stone); text-transform:uppercase;
  margin-top:8px;
}
.grade-chip{
  width:34px; height:34px; border-radius:8px; flex-shrink:0;
  background: linear-gradient(135deg, var(--grade-1), var(--grade-5));
}

/* --------------------------------- Header --------------------------------- */
.site-header{
  position: sticky; top:0; z-index:1000;
  background: #fff;
  height: var(--header-h);
  display:flex; align-items:center;
  border-bottom: 1px solid transparent;
  transition: box-shadow .25s var(--ease), border-color .25s var(--ease);
}
.site-header.is-scrolled{
  box-shadow: 0 6px 24px rgba(11,61,145,0.1);
  border-bottom-color: var(--color-line);
}
.site-header .container{
  display:flex; align-items:center; justify-content:space-between; gap:24px;
}
.brand{ display:flex; align-items:center; gap:12px; flex-shrink:0; }
.brand img{ height: 56px; width:auto; }
.brand-text{ display:flex; flex-direction:column; line-height:1.15; }
.brand-text strong{
  font-family: var(--font-display); font-weight:800; font-size:1.05rem;
  color: var(--color-primary); letter-spacing:.01em;
}
.brand-text span{
  font-size:.66rem; font-weight:700; letter-spacing:.14em;
  text-transform:uppercase; color: var(--color-secondary-dark);
}
.main-nav{ display:flex; align-items:center; gap:40px; }
.nav-links{ display:flex; align-items:center; gap:34px; }
.nav-links a{
  font-weight:600; font-size:.95rem; color: var(--color-ink);
  position:relative; padding: 8px 2px;
}
.nav-links a::after{
  content:""; position:absolute; left:0; right:100%; bottom:2px; height:2px;
  background: var(--color-secondary); transition: right .25s var(--ease);
}
.nav-links a:hover::after, .nav-links a.active::after{ right:0; }
.nav-links a.active{ color: var(--color-primary); }
.header-cta{ display:flex; align-items:center; gap:16px; }
.nav-toggle{
  display:none; width:46px; height:46px; border:1px solid var(--color-line);
  border-radius: var(--radius-sm); background:#fff; align-items:center; justify-content:center;
  flex-direction:column; gap:5px; flex-shrink:0;
}
.nav-toggle span{ width:20px; height:2px; background: var(--color-primary); border-radius:2px; transition: transform .25s var(--ease), opacity .25s var(--ease); }
.nav-toggle.is-open span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
.nav-toggle.is-open span:nth-child(2){ opacity:0; }
.nav-toggle.is-open span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 960px){
  .nav-toggle{ display:flex; }
  .main-nav{
    position: fixed; inset: var(--header-h) 0 0 0;
    background: #fff;
    flex-direction: column; align-items:stretch; justify-content:flex-start;
    padding: 28px 24px 40px;
    gap: 28px;
    transform: translateX(100%);
    transition: transform .32s var(--ease);
    overflow-y:auto;
  }
  .main-nav.is-open{ transform: translateX(0); }
  .nav-links{ flex-direction:column; align-items:flex-start; gap:4px; }
  .nav-links a{ display:block; width:100%; padding:14px 4px; border-bottom:1px solid var(--color-line-soft); font-size:1.05rem; }
  .header-cta{ flex-direction:column; align-items:stretch; }
  .header-cta .btn{ width:100%; }
  .brand-text strong{ font-size:.95rem; }
}

/* --------------------------------- Hero ----------------------------------- */
.hero{
  position:relative;
  background: linear-gradient(150deg, var(--color-primary) 0%, #123f8f 46%, #0a2f6e 100%);
  color:#fff;
  overflow:hidden;
  padding: 76px 0 0;
}
.hero .container{
  display:grid; grid-template-columns: 1.05fr 1fr; align-items:center; gap:40px;
  padding-bottom: 40px;
}
.hero-copy p.lede{ color: rgba(255,255,255,0.82); }
.hero-copy h1{ color:#fff; }
.hero-copy .eyebrow{ color: var(--color-secondary); }
.hero-copy .eyebrow::before{ background:#fff; }
.hero-actions{ display:flex; gap:16px; flex-wrap:wrap; margin-top: 30px; }
.hero-art{ position:relative; }
.hero-art svg{ width:100%; height:auto; }
.hero-stats{
  display:flex; gap:28px; margin-top:44px; flex-wrap:wrap;
}
.hero-stats div{ min-width:110px; }
.hero-stats strong{
  display:block; font-family: var(--font-display); font-size:1.7rem; font-weight:800; color:#fff;
}
.hero-stats span{ font-size:.78rem; color: rgba(255,255,255,0.7); letter-spacing:.04em; }

.page-hero{
  background: linear-gradient(150deg, var(--color-primary) 0%, #123f8f 55%, #0a2f6e 100%);
  color:#fff; padding: 68px 0 56px; position:relative; overflow:hidden;
}
.page-hero .container{ position:relative; z-index:2; max-width: 760px; }
.page-hero h1{ color:#fff; margin-bottom:.4em; }
.page-hero .lede{ color: rgba(255,255,255,0.85); margin-bottom:0; }
.page-hero .eyebrow{ color: var(--color-secondary); }
.page-hero .eyebrow::before{ background:#fff; }
.page-hero-pattern{
  position:absolute; inset:0; z-index:1; opacity:.16; pointer-events:none;
}

/* -------------------------------- Sections -------------------------------- */
section{ padding: 88px 0; }
.section-alt{ background: var(--color-accent-light); }
.two-col{ display:grid; grid-template-columns: 1fr 1fr; gap:64px; align-items:center; }

/* About preview on home */
.about-preview .art-frame{
  position:relative; border-radius: var(--radius-lg); overflow:hidden;
  background: var(--color-accent-light);
  aspect-ratio: 4/3.1;
}
.about-preview .art-frame svg{ width:100%; height:100%; }
.about-preview .checklist{ margin:26px 0 30px; }
.about-preview .checklist li{
  display:flex; gap:12px; align-items:flex-start; margin-bottom:14px; color: var(--color-ink-soft); font-weight:500;
}
.about-preview .checklist svg{ width:22px; height:22px; flex-shrink:0; color: var(--color-secondary); margin-top:2px; }

/* -------------------------------- Product cards ---------------------------- */
.product-grid{
  display:grid; grid-template-columns: repeat(4, 1fr); gap:26px;
}
.product-grid.compact{ grid-template-columns: repeat(4, 1fr); }
.product-card{
  background:#fff; border:1px solid var(--color-line); border-radius: var(--radius-md);
  padding: 30px 24px 26px; display:flex; flex-direction:column;
  transition: transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease);
}
.product-card:hover{ transform: translateY(-6px); box-shadow: var(--shadow-md); border-color: transparent; }
.product-icon{
  width:64px; height:64px; border-radius: 14px;
  background: var(--color-accent-light);
  display:flex; align-items:center; justify-content:center; margin-bottom:20px;
  color: var(--color-primary);
}
.product-icon svg{ width:34px; height:34px; }
.product-card h3{ margin-bottom:.4em; }
.product-card p{ font-size:.94rem; flex-grow:1; }
.product-card .grade-chip{ width:100%; height:6px; border-radius:3px; margin: 4px 0 18px; }

@media (max-width: 1180px){
  .product-grid, .product-grid.compact{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 620px){
  .product-grid, .product-grid.compact{ grid-template-columns: 1fr; }
}

/* -------------------------------- Feature cards ---------------------------- */
.feature-grid{ display:grid; grid-template-columns: repeat(4, 1fr); gap:24px; }
.feature-card{
  background:#fff; border:1px solid var(--color-line); border-radius: var(--radius-md);
  padding: 30px 26px;
}
.feature-card .num{
  font-family: var(--font-display); font-weight:800; font-size:.78rem;
  color:#fff; background: var(--color-primary);
  width:32px; height:32px; border-radius:8px; display:flex; align-items:center; justify-content:center;
  margin-bottom:20px;
}
.feature-card h3{ font-size:1.1rem; }
.feature-card p{ font-size:.92rem; margin-bottom:0; }
@media (max-width: 960px){ .feature-grid{ grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px){ .feature-grid{ grid-template-columns: 1fr; } }

/* -------------------------------- Value / core cards ------------------------ */
.value-grid{ display:grid; grid-template-columns: repeat(4,1fr); gap:24px; }
.value-card{ text-align:left; padding: 8px 0; }
.value-card .product-icon{ background:#fff; box-shadow: var(--shadow-sm); }
@media (max-width: 960px){ .value-grid{ grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px){ .value-grid{ grid-template-columns: 1fr; } }

.split-panel{ display:grid; grid-template-columns: repeat(2,1fr); gap:28px; }
.panel-card{
  background:#fff; border:1px solid var(--color-line); border-radius: var(--radius-lg);
  padding: 36px 34px;
}
.panel-card .product-icon{ margin-bottom:22px; }
@media (max-width: 800px){ .split-panel{ grid-template-columns:1fr; } }

/* --------------------------------- CTA band -------------------------------- */
.cta-band{
  background: var(--color-primary);
  color:#fff; text-align:center; position:relative; overflow:hidden;
}
.cta-band .container{ position:relative; z-index:2; max-width:680px; }
.cta-band h2{ color:#fff; }
.cta-band p{ color: rgba(255,255,255,0.82); }
.cta-band .btn-row{ display:flex; gap:16px; justify-content:center; flex-wrap:wrap; margin-top:26px; }
.cta-band .bg-bar{ position:absolute; inset:auto 0 0 0; height:14px; display:flex; }

/* --------------------------------- Footer ---------------------------------- */
.site-footer{ background: #081F49; color: rgba(255,255,255,0.78); padding: 68px 0 0; }
.footer-grid{
  display:grid; grid-template-columns: 1.4fr 1fr 1fr 1.3fr; gap:40px;
  padding-bottom: 50px; border-bottom: 1px solid rgba(255,255,255,0.1);
}
.footer-brand img{ height:58px; margin-bottom:16px; }
.footer-brand p{ color: rgba(255,255,255,0.62); font-size:.92rem; max-width:280px; }
.footer-col h4{
  color:#fff; font-family: var(--font-body); font-size:.82rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.1em; margin-bottom:18px;
}
.footer-col ul li{ margin-bottom:12px; }
.footer-col a{ color: rgba(255,255,255,0.7); font-size:.94rem; transition: color .2s var(--ease); }
.footer-col a:hover{ color: var(--color-secondary); }
.footer-contact li{ display:flex; gap:12px; font-size:.92rem; color: rgba(255,255,255,0.75); align-items:flex-start; }
.footer-contact svg{ width:18px; height:18px; flex-shrink:0; margin-top:3px; color: var(--color-secondary); }
.footer-bottom{
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px;
  padding: 24px 0; font-size:.82rem; color: rgba(255,255,255,0.55);
}
@media (max-width: 900px){
  .footer-grid{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px){
  .footer-grid{ grid-template-columns: 1fr; }
}

/* ----------------------------- Floating actions ----------------------------- */
.float-stack{ position: fixed; right: 22px; bottom: 22px; z-index: 1200; display:flex; flex-direction:column; gap:14px; align-items:flex-end; }
.whatsapp-fab{
  width:60px; height:60px; border-radius:50%;
  background: var(--color-secondary); color:#17130B;
  display:flex; align-items:center; justify-content:center;
  box-shadow: 0 10px 30px rgba(247,147,30,0.45);
  position:relative;
}
.whatsapp-fab svg{ width:28px; height:28px; }
.whatsapp-fab::before{
  content:""; position:absolute; inset:0; border-radius:50%;
  border: 2px solid var(--color-secondary); opacity:.6;
  animation: pulse-ring 2.6s var(--ease) infinite;
}
@keyframes pulse-ring{
  0%{ transform: scale(1); opacity:.55; }
  80%{ transform: scale(1.55); opacity:0; }
  100%{ opacity:0; }
}
.to-top-fab{
  width:44px; height:44px; border-radius:50%;
  background:#fff; color: var(--color-primary); border:1px solid var(--color-line);
  display:flex; align-items:center; justify-content:center; box-shadow: var(--shadow-sm);
  opacity:0; pointer-events:none; transform: translateY(8px);
  transition: opacity .25s var(--ease), transform .25s var(--ease);
}
.to-top-fab.is-visible{ opacity:1; pointer-events:auto; transform:translateY(0); }
.to-top-fab svg{ width:18px; height:18px; }
@media (prefers-reduced-motion: reduce){
  .whatsapp-fab::before{ animation:none; }
}

/* -------------------------------- Contact page ------------------------------ */
.contact-layout{ display:grid; grid-template-columns: .95fr 1.15fr; gap:48px; align-items:flex-start; }
.contact-card-list{ display:flex; flex-direction:column; gap:18px; margin-bottom: 30px; }
.contact-info-card{
  display:flex; gap:16px; align-items:flex-start;
  background:#fff; border:1px solid var(--color-line); border-radius: var(--radius-md);
  padding: 22px;
}
.contact-info-card .product-icon{ width:50px; height:50px; margin-bottom:0; flex-shrink:0; }
.contact-info-card .product-icon svg{ width:26px; height:26px; }
.contact-info-card h3{ font-size:1rem; margin-bottom:.25em; }
.contact-info-card p{ margin-bottom:0; font-size:.94rem; }
.contact-info-card a{ font-weight:600; color: var(--color-primary); }

.hours-card{
  background: var(--color-primary); color:#fff; border-radius: var(--radius-md);
  padding: 24px 26px; margin-bottom:8px;
}
.hours-card h3{ color:#fff; font-size:1rem; margin-bottom:14px; }
.hours-row{ display:flex; justify-content:space-between; font-size:.9rem; padding:8px 0; border-bottom:1px solid rgba(255,255,255,0.14); color: rgba(255,255,255,0.85); }
.hours-row:last-child{ border-bottom:none; }
.hours-row strong{ color:#fff; font-weight:600; }

.contact-form-panel{
  background:#fff; border:1px solid var(--color-line); border-radius: var(--radius-lg);
  padding: 40px;
}
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.form-field{ display:flex; flex-direction:column; gap:8px; margin-bottom:20px; }
.form-field.full{ grid-column: 1 / -1; }
.form-field label{ font-size:.85rem; font-weight:700; color: var(--color-ink); }
.form-field input, .form-field select, .form-field textarea{
  font-family: var(--font-body); font-size:.96rem; padding:13px 15px;
  border:1.5px solid var(--color-line); border-radius: var(--radius-sm);
  background: var(--color-accent-light); color: var(--color-ink);
  transition: border-color .2s var(--ease), background .2s var(--ease);
}
.form-field input:focus, .form-field select:focus, .form-field textarea:focus{
  outline:none; border-color: var(--color-secondary); background:#fff;
}
.form-field textarea{ resize: vertical; min-height:120px; }
.form-note{ font-size:.82rem; color: var(--color-stone); margin-top:-8px; margin-bottom:18px; }
.form-success{
  display:none; align-items:center; gap:10px; background:#EAF7EE; color:#1F7A3D;
  padding:14px 16px; border-radius: var(--radius-sm); font-size:.9rem; font-weight:600; margin-top:16px;
}
.form-success.is-visible{ display:flex; }
.form-success svg{ width:20px; height:20px; flex-shrink:0; }

@media (max-width: 980px){
  .contact-layout{ grid-template-columns: 1fr; }
}
@media (max-width: 560px){
  .form-grid{ grid-template-columns: 1fr; }
  .contact-form-panel{ padding: 26px; }
}

/* -------------------------------- Responsive: hero/sections ----------------- */
@media (max-width: 980px){
  .hero .container{ grid-template-columns: 1fr; }
  .hero-art{ order:-1; max-width:420px; margin-inline:auto; }
  .two-col{ grid-template-columns: 1fr; gap:36px; }
  .about-preview .art-frame{ order:-1; }
  .product-grid, .product-grid.compact{ grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 768px){
  section{ padding: 60px 0; }
  .hero{ padding-top: 52px; }
  .hero-stats{ gap:22px; }
}
@media (max-width: 480px){
  .container{ padding-inline: 18px; }
  .btn{ padding: 13px 22px; font-size:.86rem; }
}

/* -------------------------------- Reveal-on-scroll --------------------------- */
.reveal{ opacity:0; transform: translateY(22px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.is-visible{ opacity:1; transform:none; }
.reveal-stagger .reveal:nth-child(1){ transition-delay: .02s; }
.reveal-stagger .reveal:nth-child(2){ transition-delay: .08s; }
.reveal-stagger .reveal:nth-child(3){ transition-delay: .14s; }
.reveal-stagger .reveal:nth-child(4){ transition-delay: .2s; }
.reveal-stagger .reveal:nth-child(5){ transition-delay: .26s; }
.reveal-stagger .reveal:nth-child(6){ transition-delay: .32s; }
.reveal-stagger .reveal:nth-child(7){ transition-delay: .38s; }
.reveal-stagger .reveal:nth-child(8){ transition-delay: .44s; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
}

/* -------------------------------- Utilities ---------------------------------- */
.text-center{ text-align:center; }
.mt-0{ margin-top:0; }
.visually-hidden{
  position:absolute !important; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}
