/* ═══════════════════════════════════════════════════
   LUXURIANCE STUDIO — Multi-Page Design System
   Font: Inter (Light · Regular · Medium · Bold)
   Dark Luxury Theme — Gold Accent, Warm Rhythm
   ═══════════════════════════════════════════════════ */

/* ── FONTS — Inter (body/UI) + Fraunces (display serif, editorial accents) ── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@100;200;300;400;500;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;1,9..144,400&display=swap');

/* ── RESET & BASE ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  /* ── DARK PALETTE (primary) ── */
  --cream:#0E0E10;              /* cool near-black — replaces #0A0A0A */
  --black:#0E0E10;
  --surface:#17171A;            /* elevated dark surface — cards, featured */
  --surface-warm:#0E0E10;
  --divider-dark:#2A2A2E;

  /* ── TEXT ON DARK ── */
  --dark:#E8E4DF;
  --white:#E8E4DF;
  --text-dark:#E8E4DF;
  --text-body:#A09890;          /* replaces #A0A0A0 — warmer, passes AAA */
  --text-light:#E8E4DF;
  --text-muted:#A09890;         /* FIX: was #666 (failed WCAG AA on dark) */

  /* ── LIGHT PALETTE (editorial body sections) ── */
  --bg-light:#F6F4EF;           /* bone / ivory — Aesop, Kinfolk reference */
  --surface-light:#ECE8E0;      /* secondary light surface */
  --surface-light-elevated:#FFFFFF;
  --text-on-light:#1A1A1C;      /* warm near-black, never pure #000 */
  --text-body-light:#3A3A3C;
  --text-muted-light:#6B6862;
  --divider-light:#D8D3C8;

  /* ── ACCENTS ── */
  --coral:#B8923A;              /* muted editorial gold — replaces #C9A84C */
  --coral-strong:#9C7B2E;       /* ≈ 4.9:1 on #F6F4EF — use for small text on light */
  --blue:#B8923A;
  --green:#B8923A;
  --purple:#B8923A;
  --amber:#B8923A;
  --terracotta:#B8923A;
  --gold:#B8923A;
  --forest:#2F3B33;             /* optional 2nd accent — sparingly */
  --sans:'Inter',sans-serif;
  --serif:'Fraunces','Times New Roman',Georgia,serif;
  --serif-display:'Fraunces','Times New Roman',Georgia,serif;
  --body:'Inter',sans-serif;

  /* De-monochrome palette — new secondary tones */
  --bronze:#8B6F3E;       /* muted bronze for secondary accents */
  --warm-black:#1C1915;   /* cinema-warm off-black for section backgrounds */
  --oxblood:#5C2A2A;      /* optional deep red accent, sparingly */
  --ease:cubic-bezier(.19,1,.22,1);
  --nav-h:72px;
}

html{
  scroll-behavior:smooth;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

body{
  font-family:var(--body);
  background:#0A0A0A;
  color:var(--text-body);
  line-height:1.6;
  overflow-x:hidden;
}

::selection{background:var(--coral);color:var(--white)}

img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}

.container{
  width:100%;
  max-width:1440px;
  margin:0 auto;
  padding:0 clamp(20px,4vw,48px);
}

/* Fraunces display italic — used as editorial accent (hero words, pull-quotes, H2 accents).
   Ration: max 3 moments per page. */
.serif{
  font-family:var(--serif-display);
  font-style:italic;
  font-weight:400;
  letter-spacing:0;
  font-optical-sizing:auto;
}

/* ── COLOR UTILITIES ── */
.color-coral{color:var(--coral)}
.color-blue{color:var(--blue)}
.color-green{color:var(--green)}
.color-purple{color:var(--purple)}
.color-amber{color:var(--amber)}
.dot{color:var(--coral);transition:color .4s var(--ease)}

/* ── SECTIONS ── */
.section-light,
.section-dark{
  background:var(--cream);
  color:var(--text-body);
  padding:clamp(80px,10vw,160px) 0;
}
.section-warm{
  background:var(--surface-warm);
}

/* ══════════════════════════════════════════════════
   .section-bone — LIGHT EDITORIAL SECTION UTILITY
   Apply to any <section> to shift it to bone/ivory palette.
   Follows Aesop / Kinfolk / Cereal / Toteme pattern:
   warm ivory ground, editorial whitespace, gold rationed,
   NO hairline dividers between consecutive bone sections.
   ══════════════════════════════════════════════════ */
.section-bone{
  background:var(--bg-light) !important;
  color:var(--text-on-light);
  position:relative;
}

/* Typography on bone */
.section-bone .section-title,
.section-bone .editorial-title{
  color:var(--text-on-light);
}
.section-bone .editorial-title em.serif{
  color:var(--coral);
}
.section-bone p,
.section-bone .section-text,
.section-bone .section-text p{
  color:var(--text-body-light);
}

/* Eyebrow labels — larger, darker gold for legibility on bone */
.section-bone .label{
  color:var(--coral-strong);
  border-bottom-color:rgba(156,123,46,.35);
  font-size:.9rem;
  font-weight:500;
  letter-spacing:.18em;
  padding-bottom:.65rem;
}

/* Service rows (universal — home, content-creation, other pages) */
.section-bone .service-row{border-bottom-color:var(--divider-light)}
.section-bone .service-row:first-child{border-top-color:var(--divider-light)}
.section-bone .service-num{color:var(--text-muted-light)}
.section-bone .service-name{color:var(--text-on-light)}
.section-bone .service-desc{color:var(--text-body-light)}
.section-bone .service-arrow{color:var(--text-muted-light)}
.section-bone .service-row[data-color="coral"]:hover .service-num,
.section-bone .service-row[data-color="coral"]:hover .service-name,
.section-bone .service-row[data-color="coral"]:hover .service-arrow{color:var(--coral)}

/* Gallery items (universal — every portfolio page) */
.section-bone .gallery-item{
  box-shadow:0 2px 8px rgba(0,0,0,.06);
}
.section-bone .gallery-tag.tag-coral,
.section-bone .gallery-tag.tag-purple,
.section-bone .gallery-tag.tag-blue,
.section-bone .gallery-tag.tag-green,
.section-bone .gallery-tag.tag-amber{
  background:var(--coral);
  color:var(--bg-light);
}

/* Filter bar on bone */
.section-bone .filter-btn{
  color:var(--text-muted-light);
  border-color:rgba(26,26,28,.12);
}
.section-bone .filter-btn:hover{
  color:var(--coral);
  border-color:var(--coral);
}
.section-bone .filter-btn.active{
  background:var(--coral);
  color:var(--bg-light);
  border-color:var(--coral);
}

/* Form inputs (contact, content-creation audit, courses waitlist) */
.section-bone .form-group label{color:var(--coral-strong);font-weight:600}
.section-bone .form-input,
.section-bone .form-textarea,
.section-bone .form-select{
  background:#fff;
  border-color:var(--divider-light);
  color:var(--text-on-light);
}
.section-bone .form-input:focus,
.section-bone .form-textarea:focus,
.section-bone .form-select:focus{border-color:var(--coral)}
.section-bone .form-select option{background:#fff;color:var(--text-on-light)}

/* Buttons — default .btn-pill on bone needs dark text + dark border */
.section-bone .btn-pill{
  color:var(--text-on-light);
  border-color:rgba(26,26,28,.3);
}
.section-bone .btn-pill:hover{
  background:var(--coral);
  color:var(--bg-light);
  border-color:var(--coral);
}

/* Breadcrumb on bone */
.section-bone .breadcrumb,
.section-bone + .breadcrumb{
  background:var(--bg-light);
  border-bottom-color:var(--divider-light);
}
.section-bone .breadcrumb-back,
.section-bone .breadcrumb-current{color:var(--text-muted-light)}
.section-bone .breadcrumb-back:hover{color:var(--coral)}
.section-bone .breadcrumb-sep{color:rgba(26,26,28,.25)}

/* About grid on bone */
.section-bone .about-text p{color:var(--text-body-light)}
.section-bone .stat-number{color:var(--coral)}
.section-bone .stat-label{color:var(--coral-strong)}
.section-bone .about-stats{border-top-color:var(--divider-light)}

/* Contact grid on bone */
.section-bone .contact-heading{color:var(--text-on-light)}
.section-bone .contact-text{color:var(--text-body-light)}
.section-bone .contact-email{color:var(--text-on-light);border-bottom-color:var(--coral)}
.section-bone .contact-email:hover{color:var(--coral)}
.section-bone .contact-info{
  background:#fff;
  border-color:var(--divider-light);
}
.section-bone .contact-info-label{color:var(--coral-strong)}
.section-bone .contact-info-value{color:var(--text-body-light)}
.section-bone .contact-socials a{color:var(--text-on-light)}
.section-bone .contact-socials a:hover{color:var(--coral)}

/* Page hero labels on bone (if any page hero goes light) */
.section-bone .page-hero-label{color:var(--coral-strong)}
.section-bone .page-hero-title{color:var(--text-on-light)}
.section-bone .page-hero-desc{color:var(--text-body-light)}

/* Client logo strip on bone — monochrome silhouette treatment.
   Reference: Aesop, Toteme, Kinfolk. Logos originally designed for dark bg
   (white / light) auto-convert to pure black via brightness(0). */
.section-bone .clients-track img,
.section-bone .client-logos img,
.section-bone .logo-strip img{
  filter:brightness(0);
  opacity:.85;       /* was .65 — thin line-art needs more presence on ivory */
  mix-blend-mode:normal;  /* cancel home.css .clients-track screen blend (dark-bg era) */
  transition:opacity .4s var(--ease);
}
.section-bone .clients-track img:hover,
.section-bone .client-logos img:hover,
.section-bone .logo-strip img:hover{
  opacity:1;
}

/* Already-dark line-art logos — skip the brightness flatten, keep
   original crispness (the filter adds nothing on black-on-transparent
   and can make delicate detail read as softer due to premultiplied alpha). */
.section-bone .clients-track img[alt="Teatro Nacional de Costa Rica"],
.section-bone .clients-track img[alt="Wanderlust Women"],
.section-bone .clients-track img[alt="Andean Experience"]{
  filter:none;
  opacity:.85;
}
/* MD Prescriptives stays under the brightness(0) filter — Kris wants it black
   like the others, not in its natural forest green. */

/* ── FOREST accent variant (only for about §2 philosophy, documentaries §2)
   — swaps gold for a muted forest green on select editorial moments. */
.section-bone.section-bone-forest .label{
  color:var(--forest);
  border-bottom-color:rgba(47,59,51,.35);
}
.section-bone.section-bone-forest .editorial-title em.serif,
.section-bone.section-bone-forest .section-title{color:var(--forest)}

/* ── Blog-specific overrides on bone — blog.css hardcodes white text
   for the dark-bg era. These restore readability on ivory sections. */
.section-bone .blog-article-title,
.section-bone .blog-featured-title,
.section-bone .blog-card-title,
.section-bone .blog-author-name{color:var(--text-on-light)}

.section-bone .blog-article-body p,
.section-bone .blog-featured-excerpt,
.section-bone .blog-card-excerpt{color:var(--text-body-light)}

.section-bone .blog-article-body h2{color:var(--text-on-light)}

.section-bone .blog-lead{color:var(--text-body-light) !important}

.section-bone .blog-meta,
.section-bone .blog-date,
.section-bone .blog-read,
.section-bone .blog-author-role,
.section-bone .blog-back{color:var(--text-muted-light)}

.section-bone .blog-back:hover{color:var(--coral-strong)}

.section-bone .blog-tag{
  color:var(--coral-strong);
  background:transparent;
  border:1px solid rgba(156,123,46,.35);
}

.label{
  font-family:var(--sans);
  font-size:.7rem;
  font-weight:400;
  text-transform:uppercase;
  letter-spacing:.15em;
  margin-bottom:1.2rem;
  color:var(--terracotta);
  padding-bottom:.5rem;
  border-bottom:1px solid rgba(201,168,76,.2);
  display:inline-block;
}

.section-title{
  font-family:var(--sans);
  font-size:clamp(1.8rem,3.5vw,3rem);
  font-weight:300;
  line-height:.95;
  margin-bottom:1.5rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--text-light);
}

/* ── EDITORIAL UTILITIES ── */
.editorial-title{
  font-family:var(--sans);
  font-size:clamp(2.2rem,6vw,5rem);
  font-weight:200;
  line-height:.92;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--coral);
}
.layout-asymmetric{
  display:grid;
  grid-template-columns:3fr 2fr;
  gap:clamp(2rem,4vw,5rem);
  align-items:start;
}
.img-offset{
  margin-top:-3rem;
}

/* ── NAV ── */
.nav{
  position:fixed;
  top:0;left:0;right:0;
  height:var(--nav-h);
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 clamp(20px,4vw,48px);
  z-index:1000;
  transition:background .4s var(--ease),box-shadow .4s var(--ease);
}

/* Transparent nav on hero pages */
body[data-nav-style="transparent"] .nav{
  background:transparent;
}
body[data-nav-style="transparent"] .nav.scrolled{
  background:rgba(10,10,10,.95);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  box-shadow:0 1px 0 rgba(255,255,255,.06);
}

/* Solid nav on subpages */
body[data-nav-style="solid"] .nav{
  background:rgba(10,10,10,.95);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  box-shadow:0 1px 0 rgba(255,255,255,.06);
}

.nav-logo{
  display:flex;
  align-items:center;
}
.nav-logo-img{
  height:40px;
  width:auto;
  display:block;
}
.nav-logo{
  margin-left:-10px;
  text-decoration:none;
}
.nav-logo-text{
  font-family:var(--sans);
  font-size:.95rem;
  font-weight:200;
  letter-spacing:.28em;
  color:var(--coral);
  display:flex;
  align-items:baseline;
  gap:.5rem;
}
.nav-logo-sub{
  font-size:.65rem;
  font-weight:300;
  letter-spacing:.22em;
  color:var(--text-body);
}
.footer-logo-text{
  font-family:var(--sans);
  font-size:1.1rem;
  font-weight:200;
  letter-spacing:.28em;
  color:var(--coral);
  display:flex;
  align-items:baseline;
  gap:.6rem;
}
.footer-logo-sub{
  font-size:.7rem;
  font-weight:300;
  letter-spacing:.22em;
  color:var(--text-body);
}

.nav-right{display:flex;align-items:center;gap:2rem}

.nav-links{
  display:flex;gap:2rem;
}
.nav-links a{
  font-family:var(--sans);
  font-size:.8rem;
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:.06em;
  position:relative;
  transition:color .4s var(--ease);
  color:var(--text-dark);
}
.nav-links a:hover{color:var(--text-dark)}
.nav-links a::after{
  content:'';
  position:absolute;
  bottom:-4px;left:0;
  width:0;height:2px;
  background:var(--coral);
  transition:width .3s var(--ease);
}
.nav-links a:hover::after,
.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--coral)}

/* ── NAV DROPDOWN ── */
.nav-dropdown{position:relative}
.nav-dropdown > a{cursor:default}
.nav-submenu{
  position:absolute;
  top:calc(100% + 12px);
  left:50%;
  transform:translateX(-50%);
  min-width:200px;
  background:#141414;
  border-radius:12px;
  padding:.6rem 0;
  box-shadow:0 12px 40px rgba(0,0,0,.12),0 2px 8px rgba(0,0,0,.06);
  opacity:0;
  visibility:hidden;
  transform:translateX(-50%) translateY(8px);
  transition:all .3s var(--ease);
  z-index:1001;
}
.nav-dropdown:hover .nav-submenu{
  opacity:1;
  visibility:visible;
  transform:translateX(-50%) translateY(0);
}
.nav-submenu li a{
  display:block;
  padding:.55rem 1.4rem;
  font-size:.75rem;
  font-weight:600;
  color:var(--text-dark) !important;
  text-transform:uppercase;
  letter-spacing:.06em;
  transition:all .2s var(--ease);
}
.nav-submenu li a::after{display:none}
.nav-submenu li a:hover{
  color:var(--coral) !important;
  padding-left:1.8rem;
}
.nav-submenu li a.active{color:var(--coral) !important}

.lang-switcher{display:flex;gap:.3rem}
.lang-btn{
  font-family:var(--sans);
  font-size:.7rem;font-weight:700;
  padding:.3rem .5rem;
  border:1.5px solid var(--text-dark);
  border-radius:50px;
  background:none;color:var(--text-dark);
  cursor:pointer;
  transition:all .4s var(--ease);
}
.lang-btn.active{
  background:var(--coral);
  color:var(--cream);
  border-color:var(--coral);
}
.lang-btn:hover{background:var(--coral);color:var(--cream);border-color:var(--coral)}

/* Nav toggle (mobile) */
.nav-toggle{
  display:none;
  flex-direction:column;
  gap:6px;
  background:none;border:none;cursor:pointer;
  width:28px;padding:4px 0;
  z-index:1001;
}
.nav-toggle span{
  display:block;height:2px;
  background:var(--text-dark);
  border-radius:2px;
  transition:all .4s var(--ease);
}
.nav-toggle.active span:first-child{
  transform:translateY(4px) rotate(45deg);
}
.nav-toggle.active span:last-child{
  transform:translateY(-4px) rotate(-45deg);
}

/* ── CTA PILL BUTTON ── */
.btn-pill{
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  font-family:var(--sans);
  font-size:.75rem;
  font-weight:400;
  text-transform:uppercase;
  letter-spacing:.14em;
  padding:.75rem 1.6rem;
  border-radius:100px;
  background:transparent;
  color:var(--text-dark);
  transition:all .4s var(--ease);
  flex-shrink:0;
  border:1.5px solid rgba(255,255,255,.3);
  cursor:pointer;
}
.btn-pill svg{
  width:16px;height:16px;
  transition:transform .3s var(--ease);
}
.btn-pill:hover{background:var(--coral);color:var(--cream);border-color:var(--coral);transform:scale(1.02)}
.btn-pill:hover svg{transform:translate(3px,-3px)}

/* Light variant for on-video CTA */
.btn-pill-light{
  background:rgba(255,255,255,.15);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1.5px solid rgba(255,255,255,.3);
}
.btn-pill-light:hover{
  background:var(--coral);
  border-color:var(--coral);
}

/* ── MARQUEE ── */
.marquee{
  padding:clamp(16px,2.5vw,28px) 0;
  border-top:1.5px solid rgba(255,255,255,.1);
  border-bottom:1.5px solid rgba(255,255,255,.1);
  overflow:hidden;
  background:var(--cream);
}
.marquee-track{
  display:flex;
  align-items:center;
  gap:clamp(1.5rem,3vw,3rem);
  white-space:nowrap;
  animation:marqueeScroll 25s linear infinite;
  width:max-content;
}
.marquee-track span{
  font-family:var(--sans);
  font-size:clamp(.9rem,1.6vw,1.3rem);
  font-weight:300;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--text-body);
}
.marquee-dot{
  display:inline-block;
  width:8px;height:8px;
  border-radius:50%;
  background:var(--text-body);
  flex-shrink:0;
}
.marquee-star{
  font-size:clamp(1.2rem,2.4vw,2rem);
  color:var(--white);
}
.marquee-reverse .marquee-track{animation-direction:reverse}
.marquee-accent{
  background:var(--surface);
  border-color:rgba(255,255,255,.1);
}
.marquee-accent .marquee-track span{color:var(--white)}
@keyframes marqueeScroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

/* ── PAGE HERO (Subpages) ── */
.page-hero{
  position:relative;
  min-height:35vh;
  display:flex;
  align-items:flex-end;
  padding:calc(var(--nav-h) + clamp(24px,4vw,48px)) 0 clamp(24px,4vw,48px);
  overflow:hidden;
  background:var(--cream);
}
.page-hero-bg{
  position:absolute;
  top:5%;right:0;
  width:55%;
  height:90%;
  object-fit:contain;
  object-position:right center;
  border-radius:0;
  z-index:0;
  border-radius:12px;
}
.page-hero-overlay{
  display:none;
}
.page-hero-content{
  position:relative;
  z-index:2;
}
.page-hero-label{
  font-family:var(--sans);
  font-size:.7rem;
  font-weight:400;
  text-transform:uppercase;
  letter-spacing:.2em;
  margin-bottom:1rem;
  color:var(--terracotta);
}
.page-hero-title{
  font-family:var(--sans);
  font-size:clamp(2.5rem,7vw,5.5rem);
  font-weight:200;
  line-height:.95;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--coral);
  margin-bottom:1.5rem;
}
.page-hero-desc{
  max-width:600px;
  font-size:clamp(.95rem,1.2vw,1.1rem);
  color:var(--text-body);
  line-height:1.65;
}

/* ── SECTION HEADER ── */
.section-header{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  margin-bottom:clamp(2.5rem,5vw,4rem);
}

/* ── GALLERY / WORK ── */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(12px,1.5vw,20px);
}
.gallery-item{
  position:relative;
  overflow:hidden;
  border-radius:0;
  cursor:pointer;
  transition:opacity .3s var(--ease),transform .3s var(--ease);
}
.gallery-item img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .6s var(--ease);
}
.gallery-item:hover img{transform:scale(1.06)}

.gallery-tall{grid-row:span 2}
.gallery-wide{grid-column:span 2}

.gallery-overlay{
  position:absolute;
  bottom:0;left:0;right:0;
  padding:clamp(16px,2vw,24px);
  background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 100%);
  display:flex;
  flex-direction:column;
  gap:.4rem;
  transform:translateY(10px);
  opacity:0;
  transition:all .4s var(--ease);
}
.gallery-item:hover .gallery-overlay{
  transform:translateY(0);
  opacity:1;
}

.gallery-tag{
  display:inline-block;
  width:fit-content;
  font-family:var(--sans);
  font-size:.65rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.1em;
  padding:.25rem .7rem;
  border-radius:50px;
  color:var(--white);
}
.tag-coral{background:var(--coral)}
.tag-blue{background:var(--blue)}
.tag-green{background:var(--green);color:var(--dark)}
.tag-purple{background:var(--purple)}
.tag-amber{background:var(--amber)}

.gallery-name{
  font-family:var(--sans);
  font-size:clamp(.9rem,1.2vw,1.1rem);
  font-weight:600;
  color:var(--white);
}

/* ── FILTER BAR ── */
.filter-bar{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  margin-bottom:clamp(2rem,3vw,3rem);
}
.filter-btn{
  font-family:var(--sans);
  font-size:.75rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.08em;
  padding:.55rem 1.2rem;
  border:1.5px solid rgba(255,255,255,.15);
  border-radius:100px;
  background:none;
  color:var(--coral);
  cursor:pointer;
  transition:all .3s var(--ease);
}
.filter-btn:hover{
  border-color:var(--coral);
  color:var(--coral);
}
.filter-btn.active{
  background:var(--coral);
  color:var(--white);
  border-color:var(--coral);
}

/* ── SERVICES ── */
.services-list{margin-top:1rem}
.service-row{
  display:grid;
  grid-template-columns:auto 1fr 2fr auto;
  align-items:center;
  gap:clamp(1.5rem,3vw,3rem);
  padding:clamp(1.5rem,2.5vw,2.2rem) 0;
  border-bottom:1px solid rgba(255,255,255,.1);
  cursor:pointer;
  transition:all .3s var(--ease);
}
.service-row:first-child{border-top:1px solid rgba(255,255,255,.1)}
.service-row:hover{padding-left:1rem}
.service-num{
  font-family:var(--sans);
  font-size:clamp(.8rem,1vw,.95rem);
  font-weight:200;
  color:var(--gold);
  transition:color .3s;
}
.service-name{
  font-family:var(--sans);
  font-size:clamp(1.4rem,2.8vw,2.2rem);
  font-weight:400;
  letter-spacing:-.01em;
  text-transform:uppercase;
  transition:color .3s;
}
.service-desc{
  font-size:clamp(.85rem,1vw,.95rem);
  color:var(--text-body);
  line-height:1.55;
}
.service-arrow{
  font-size:1.3rem;
  opacity:.3;
  transition:all .3s var(--ease);
}
.service-row[data-color="coral"]:hover .service-num,
.service-row[data-color="coral"]:hover .service-name{color:var(--coral)}
.service-row[data-color="coral"]:hover .service-arrow{opacity:1;color:var(--coral);transform:translateX(4px)}
.service-row[data-color="blue"]:hover .service-num,
.service-row[data-color="blue"]:hover .service-name{color:var(--blue)}
.service-row[data-color="blue"]:hover .service-arrow{opacity:1;color:var(--blue);transform:translateX(4px)}
.service-row[data-color="green"]:hover .service-num,
.service-row[data-color="green"]:hover .service-name{color:var(--green)}
.service-row[data-color="green"]:hover .service-arrow{opacity:1;color:var(--green);transform:translateX(4px)}
.service-row[data-color="purple"]:hover .service-num,
.service-row[data-color="purple"]:hover .service-name{color:var(--purple)}
.service-row[data-color="purple"]:hover .service-arrow{opacity:1;color:var(--purple);transform:translateX(4px)}
.service-row[data-color="amber"]:hover .service-num,
.service-row[data-color="amber"]:hover .service-name{color:var(--amber)}
.service-row[data-color="amber"]:hover .service-arrow{opacity:1;color:var(--amber);transform:translateX(4px)}

/* ── VIDEO SHOWCASE ── */
.showreel{
  position:relative;
  border-radius:0;
  overflow:hidden;
  cursor:pointer;
  margin-top:1rem;
}
.showreel img{
  width:100%;
  aspect-ratio:16/9;
  object-fit:cover;
  transition:transform .6s var(--ease),filter .6s;
}
.showreel:hover img{
  transform:scale(1.03);
  filter:brightness(.75);
}
.showreel-play{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:1rem;
}
.play-circle{
  width:clamp(60px,8vw,90px);
  height:clamp(60px,8vw,90px);
  border-radius:50%;
  background:var(--white);
  display:flex;
  align-items:center;
  justify-content:center;
  transition:transform .4s var(--ease),background .3s;
}
.play-circle svg{
  width:28%;height:28%;
  color:var(--dark);
  margin-left:3px;
}
.showreel:hover .play-circle{
  transform:scale(1.12);
  background:var(--coral);
}
.showreel:hover .play-circle svg{color:var(--white)}
.showreel-label{
  font-family:var(--sans);
  font-size:.8rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--white);
}

.video-featured{margin-bottom:clamp(2.5rem,4vw,4rem)}
.video-embed{
  position:relative;
  border-radius:0;
  overflow:hidden;
  cursor:pointer;
}
.video-embed img{
  width:100%;
  aspect-ratio:16/9;
  object-fit:cover;
  transition:transform .6s var(--ease),filter .6s;
}
.video-embed:hover img{
  transform:scale(1.03);
  filter:brightness(.75);
}

.video-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(16px,2vw,24px);
}
.video-card{cursor:pointer}
.video-thumb{
  position:relative;
  border-radius:0;
  overflow:hidden;
  margin-bottom:.8rem;
}
.video-thumb img,
.video-thumb video{
  width:100%;
  aspect-ratio:16/9;
  object-fit:cover;
  transition:transform .5s var(--ease);
  display:block;
}
.video-card:hover .video-thumb img,
.video-card:hover .video-thumb video{transform:scale(1.05)}
.video-preview{
  width:100%;
  aspect-ratio:16/9;
  object-fit:cover;
  transition:transform .5s var(--ease);
}
.video-card:hover .video-preview{transform:scale(1.05)}
.video-play-sm{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  transition:opacity .3s var(--ease);
}
.video-card:hover .video-play-sm{opacity:1}
.video-thumb-playable:hover .video-play-sm{opacity:0}
.video-play-sm svg{
  width:36px;height:36px;
  color:var(--white);
  filter:drop-shadow(0 2px 8px rgba(0,0,0,.4));
}
.video-duration{
  position:absolute;
  bottom:8px;right:8px;
  font-family:var(--sans);
  font-size:.7rem;
  font-weight:600;
  padding:.2rem .5rem;
  border-radius:4px;
  background:rgba(0,0,0,.7);
  color:var(--white);
}
.video-info{padding:0 .2rem}
.video-cat{
  font-family:var(--sans);
  font-size:.65rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--coral);
}
.video-title{
  font-family:var(--sans);
  font-size:clamp(.9rem,1.1vw,1rem);
  font-weight:500;
  margin-top:.25rem;
  line-height:1.3;
  color:var(--text-body);
}

/* ── VIDEO LIGHTBOX ── */
.lightbox{
  position:fixed;
  inset:0;
  z-index:9999;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(0,0,0,.92);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  opacity:0;
  visibility:hidden;
  transition:opacity .4s var(--ease),visibility .4s;
}
.lightbox.active{opacity:1;visibility:visible}
.lightbox-close{
  position:absolute;
  top:clamp(16px,3vw,32px);
  right:clamp(16px,3vw,32px);
  width:48px;height:48px;
  border:none;
  background:rgba(255,255,255,.1);
  color:var(--white);
  font-size:1.8rem;
  border-radius:50%;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:background .3s,transform .3s;
  z-index:10000;
}
.lightbox-close:hover{background:var(--coral);transform:scale(1.1)}
.lightbox-content{
  width:90vw;
  max-width:1200px;
  transform:scale(.9);
  transition:transform .4s var(--ease);
}
.lightbox.active .lightbox-content{transform:scale(1)}
.lightbox-video{
  width:100%;
  border-radius:0;
  background:var(--black);
  outline:none;
}

/* ── ABOUT ── */
.about-grid{
  display:grid;
  grid-template-columns:1fr 1.3fr;
  gap:clamp(2rem,4vw,3.5rem);
  align-items:center;
}
.about-image{
  position:relative;
  border-radius:0;
  overflow:hidden;
}
.about-image img{
  width:100%;
  height:auto;
  aspect-ratio:3/4;
  object-fit:cover;
}
.about-image-accent{
  position:absolute;
  bottom:-10px;right:-10px;
  width:100%;height:100%;
  border:2px solid var(--coral);
  border-radius:0;
  z-index:-1;
}
.about-text p{
  font-size:clamp(.95rem,1.1vw,1.05rem);
  line-height:1.75;
  color:var(--text-body);
  margin-bottom:1.2rem;
}
.about-stats{
  display:flex;
  gap:clamp(2rem,4vw,4rem);
  margin-top:2.5rem;
  padding-top:2rem;
  border-top:1px solid rgba(255,255,255,.1);
}
.stat-number{
  font-family:var(--sans);
  font-size:clamp(1.8rem,3vw,2.6rem);
  font-weight:200;
  line-height:1;
  margin-bottom:.3rem;
  color:var(--coral);
}
.stat-label{
  font-size:.7rem;
  color:var(--terracotta);
  text-transform:uppercase;
  letter-spacing:.12em;
  font-weight:400;
}

/* ── CONTACT ── */
.contact-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:clamp(2rem,4vw,3.5rem);
  align-items:start;
}
.contact-heading{
  font-family:var(--sans);
  font-size:clamp(1.8rem,4vw,3.2rem);
  font-weight:200;
  line-height:1.05;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--coral);
  margin-bottom:1.5rem;
}
.contact-text{
  font-size:clamp(.95rem,1.1vw,1.05rem);
  color:var(--coral);
  line-height:1.7;
  margin-bottom:2rem;
}
.contact-email{
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  font-family:var(--sans);
  font-size:clamp(1.1rem,1.8vw,1.5rem);
  font-weight:700;
  border-bottom:2px solid var(--coral);
  padding-bottom:.3rem;
  transition:color .3s;
}
.contact-email svg{transition:transform .3s var(--ease)}
.contact-email:hover{color:var(--coral)}
.contact-email:hover svg{transform:translate(3px,-3px)}
.contact-socials{
  display:flex;
  gap:1.5rem;
  margin-top:2.5rem;
}
.contact-socials a{
  font-family:var(--sans);
  font-size:.85rem;
  font-weight:600;
  display:flex;
  align-items:center;
  gap:.3rem;
  transition:color .3s;
}
.contact-socials a span{transition:transform .3s var(--ease)}
.contact-socials a:hover{color:var(--coral)}
.contact-socials a:hover span{transform:translateX(4px)}
.contact-info{
  display:flex;
  flex-direction:column;
  gap:2.5rem;
  padding:2.5rem;
  border:1px solid rgba(255,255,255,.1);
  border-radius:16px;
}
.contact-info-label{
  font-family:var(--sans);
  font-size:.7rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.15em;
  color:var(--coral);
  margin-bottom:.5rem;
}
.contact-info-value{
  font-size:.95rem;
  line-height:1.6;
  color:var(--text-body);
}

/* ── CONTACT FORM ── */
.contact-form{display:flex;flex-direction:column;gap:1.2rem}
.form-group{display:flex;flex-direction:column;gap:.4rem}
.form-group label{
  font-family:var(--sans);
  font-size:.75rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--coral);
}
.form-input,.form-textarea,.form-select{
  font-family:var(--body);
  font-size:.95rem;
  padding:.8rem 1rem;
  border:1px solid rgba(255,255,255,.12);
  border-radius:10px;
  background:#141414;
  color:var(--text-dark);
  transition:border-color .3s var(--ease);
  outline:none;
}
.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--coral)}
.form-textarea{resize:vertical;min-height:140px}
.form-select{cursor:pointer;appearance:none}
.form-select option{background:#141414;color:#E8E4DF}

/* Coming soon badge */
.coming-soon{
  font-family:var(--sans);
  font-size:.65rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.1em;
  padding:.3rem .8rem;
  border-radius:100px;
  background:rgba(255,255,255,.05);
  color:var(--coral);
}

/* ── BREADCRUMB ── */
.breadcrumb{
  background:var(--cream);
  border-bottom:1px solid rgba(255,255,255,.06);
  padding:.7rem 0;
  padding-top:calc(var(--nav-h) + .7rem);
}
.breadcrumb .container{
  display:flex;
  align-items:center;
  gap:.6rem;
}
.breadcrumb-back{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  font-family:var(--sans);
  font-size:.75rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--coral);
  transition:color .3s var(--ease);
}
.breadcrumb-back:hover{color:var(--coral)}
.breadcrumb-back svg{transition:transform .3s var(--ease)}
.breadcrumb-back:hover svg{transform:translateX(-3px)}
.breadcrumb-sep{
  color:rgba(255,255,255,.2);
  font-size:.75rem;
}
.breadcrumb-current{
  font-family:var(--sans);
  font-size:.75rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--coral);
}

/* ── FOOTER ── */
footer{
  padding:clamp(2rem,4vw,3rem) 0;
  background:var(--surface-warm);
  border-top:1px solid rgba(201,168,76,.15);
}
.footer-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  font-size:.8rem;
  color:var(--text-body);
  text-transform:uppercase;
}
.footer-inner>div:first-child{
  font-family:var(--sans);
  font-weight:700;
  color:var(--text-body);
}
.footer-brand{display:flex;align-items:center;gap:.75rem}
.footer-logo-img{height:38px;width:auto;display:block}

/* ── SCROLL REVEAL — Ciel Rose–inspired ── */

/* Base fade-up reveal (default for simple elements) */
.reveal{
  opacity:0;
  transform:translateY(40px);
  transition:opacity 1.2s var(--ease),transform 1.5s var(--ease);
}
.reveal.visible{
  opacity:1;
  transform:translateY(0);
}
.reveal-delay-1{transition-delay:.15s}
.reveal-delay-2{transition-delay:.3s}
.reveal-delay-3{transition-delay:.45s}
.reveal-delay-4{transition-delay:.6s}

/* Word-split text reveal (headings, titles) */
[data-animation="words"]{
  opacity:1;
  transform:none;
}
[data-animation="words"] .word{
  display:inline-block;
  overflow:hidden;
  vertical-align:bottom;
  padding-bottom:.06em;
}
[data-animation="words"] .word-inner{
  display:inline-block;
  transform:translateY(105%);
  transition:transform 1.5s var(--ease);
  will-change:transform;
}
[data-animation="words"].visible .word-inner{
  transform:translateY(0);
}

/* Clip reveal (images, media blocks) */
[data-animation="clip"]{
  overflow:hidden;
  opacity:1;
  transform:none;
}
[data-animation="clip"] .reveal-inner{
  transform:translateY(100%);
  transition:transform 1.5s var(--ease);
  will-change:transform;
}
[data-animation="clip"].visible .reveal-inner{
  transform:translateY(0);
}

/* Line/divider scale reveal */
[data-animation="line"]{
  opacity:1;
  transform:none;
  transform-origin:left;
  will-change:transform;
}
[data-animation="line"]::after{
  transform:scaleX(0);
  transform-origin:left;
  transition:transform 1.5s var(--ease);
}
[data-animation="line"].visible::after{
  transform:scaleX(1);
}

/* Stagger container */
.reveal-stagger .stagger-child{
  opacity:0;
  transform:translateY(40px);
  transition:opacity 1.2s var(--ease),transform 1.5s var(--ease);
}
.reveal-stagger.visible .stagger-child{
  opacity:1;
  transform:translateY(0);
}
.reveal-stagger.visible .stagger-child.visible{
  opacity:1;
  transform:translateY(0);
}

/* Smooth scroll body wrapper */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:hidden}

/* ── MOBILE MENU OVERLAY ── */
body.menu-open::after{
  content:'';
  position:fixed;
  inset:0;
  background:var(--cream);
  z-index:999;
  pointer-events:none;
  animation:fadeIn .35s var(--ease) forwards;
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

body.menu-open .nav-links{
  position:fixed;
  inset:0;
  z-index:1000;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:1.8rem;
  display:flex;
  overflow-y:auto;
  padding:calc(var(--nav-h) + 1rem) 2rem 6rem;
}
body.menu-open .nav-links > li > a{
  font-size:clamp(1.6rem,5vw,2.2rem);
  font-weight:300;
  letter-spacing:.12em;
  color:var(--text-dark);
}
body.menu-open .nav-links a::after{display:none}
body.menu-open .nav-dropdown{text-align:center}
body.menu-open .nav-submenu{
  position:static !important;
  transform:none !important;
  background:none !important;
  box-shadow:none !important;
  padding:.6rem 0 0 !important;
  opacity:1 !important;
  visibility:visible !important;
  min-width:auto;
  display:flex !important;
  flex-direction:row;
  flex-wrap:wrap;
  justify-content:center;
  gap:.4rem .6rem;
}
body.menu-open .nav-submenu li a{
  font-size:.7rem !important;
  font-weight:500 !important;
  padding:.35rem .8rem;
  color:var(--text-muted) !important;
  border:1px solid rgba(255,255,255,.12);
  border-radius:50px;
  letter-spacing:.08em;
}
body.menu-open .nav-submenu li a:hover,
body.menu-open .nav-submenu li a.active{
  color:var(--coral) !important;
  border-color:var(--coral);
  padding-left:.8rem;
}
body.menu-open .lang-switcher{
  position:fixed;
  bottom:2.5rem;
  left:50%;
  transform:translateX(-50%);
  z-index:1001;
  background:rgba(20,20,20,.9);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  padding:.6rem 1rem;
  border-radius:50px;
  border:1px solid rgba(255,255,255,.1);
}
body.menu-open .lang-btn{
  border-color:var(--text-dark);
  color:var(--text-dark);
}
body.menu-open .lang-btn.active{
  background:var(--coral);
  color:var(--cream);
  border-color:var(--coral);
}

/* ══════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════ */

@media(max-width:1024px){
  .about-grid{grid-template-columns:1fr;gap:2.5rem}
  .about-image{max-width:400px}
  .contact-grid{grid-template-columns:1fr;gap:3rem}
  .service-row{
    grid-template-columns:auto 1fr auto;
    grid-template-rows:auto auto;
  }
  .service-desc{
    grid-column:2 / -1;
    grid-row:2;
    font-size:.85rem;
    line-height:1.6;
    padding-top:.25rem;
    padding-bottom:.25rem;
    color:var(--text-muted);
  }
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-tall{grid-row:span 1}
  .gallery-wide{grid-column:span 1}
  .video-grid{grid-template-columns:repeat(2,1fr)}
  .layout-asymmetric{grid-template-columns:1fr}
  .page-hero-bg{position:relative;width:100%;height:auto;margin-top:2rem;border-radius:0}
}

@media(max-width:768px){
  :root{--nav-h:60px}

  .section-light,.section-dark{padding:clamp(48px,8vw,80px) 0}

  .nav-links,.nav .lang-switcher{display:none}
  .nav-toggle{display:flex}
  .nav-dropdown:hover .nav-submenu{
    opacity:0;visibility:hidden;
  }
  body.menu-open .nav-dropdown:hover .nav-submenu{
    opacity:1;visibility:visible;
  }

  body.menu-open .nav-links{display:flex}
  body.menu-open .lang-switcher{display:flex}

  .page-hero{
    min-height:auto;
    padding-top:calc(var(--nav-h) + 2rem);
  }
  .page-hero-bg{position:relative;width:100%;height:auto;margin-top:2rem}

  .about-stats{flex-direction:column;gap:1.5rem}

  .gallery-grid{
    grid-template-columns:1fr 1fr;
    gap:10px;
  }

  .service-row{
    grid-template-columns:auto 1fr auto;
    grid-template-rows:auto auto;
    gap:.75rem 1rem;
  }
  .service-desc{
    font-size:.8rem;
  }

  .contact-socials{flex-wrap:wrap;gap:1rem}
  .contact-info{padding:1.5rem}
  .editorial-title{font-size:clamp(1.8rem,6vw,3rem)}
}

@media(max-width:480px){
  .gallery-grid{grid-template-columns:1fr}
  .gallery-wide{grid-column:span 1}
  .video-grid{grid-template-columns:1fr}
  .filter-bar{gap:.4rem}
  .filter-btn{font-size:.65rem;padding:.45rem .9rem}
  .about-image{max-width:100%}
  .contact-heading{font-size:clamp(1.4rem,6vw,2.2rem)}
  .page-hero-title{font-size:clamp(2rem,8vw,3.5rem)}
  .editorial-title{font-size:clamp(1.5rem,6vw,2.5rem)}
  .footer-inner{
    flex-direction:column;
    gap:.8rem;
    text-align:center;
  }
}

/* ══════════════════════════════════════
   PHOTO LIGHTBOX
   ══════════════════════════════════════ */
.photo-lightbox{
  position:fixed;inset:0;z-index:10000;
  background:rgba(0,0,0,0);
  display:flex;align-items:center;justify-content:center;
  transition:background .3s;
  cursor:pointer;
}
.photo-lightbox.active{background:rgba(0,0,0,.92)}
.photo-lightbox-img{
  max-width:90vw;max-height:88vh;
  display:block;
  object-fit:contain;
  transition:opacity .15s;
  cursor:default;
}
.photo-lightbox-close{
  position:absolute;top:20px;right:24px;
  background:none;border:none;
  color:#fff;font-size:2.2rem;
  cursor:pointer;opacity:.6;
  transition:opacity .2s;line-height:1;
  z-index:2;
}
.photo-lightbox-close:hover{opacity:1}
.photo-lightbox-prev,
.photo-lightbox-next{
  position:absolute;top:50%;
  transform:translateY(-50%);
  background:rgba(255,255,255,.08);
  border:none;border-radius:50%;
  width:48px;height:48px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;opacity:.6;
  transition:opacity .2s,background .2s;
  z-index:2;
}
.photo-lightbox-prev{left:20px}
.photo-lightbox-next{right:20px}
.photo-lightbox-prev:hover,
.photo-lightbox-next:hover{opacity:1;background:rgba(255,255,255,.15)}
.photo-lightbox-counter{
  position:absolute;bottom:24px;left:50%;
  transform:translateX(-50%);
  font-family:var(--sans);font-size:.8rem;font-weight:500;
  color:rgba(255,255,255,.5);
  letter-spacing:.08em;
}

/* ══════════════════════════════════════════
   PAGE TRANSITIONS — Slide-Up Reveal
   The new page rises smoothly from below.
   ══════════════════════════════════════════ */

/* Prevent scroll during transition */
html.transition-leaving,
html.transition-entering{overflow:hidden}

/* ── Phase A: Current page fades and drifts up ── */
html.transition-leaving body{
  animation:pageFadeOut .5s cubic-bezier(.4,0,.2,1) forwards;
}

@keyframes pageFadeOut{
  0%  {transform:translateY(0) scale(1);opacity:1;filter:blur(0)}
  100%{transform:translateY(-4vh) scale(.98);opacity:0;filter:blur(4px)}
}

/* ── Phase B: New page starts below viewport ── */
html.transition-entering body{
  transform:translateY(100vh);
}

/* ── Phase B: Slide up into view ── */
html.transition-slide-up body{
  animation:pageSlideUp 1s cubic-bezier(.16,1,.3,1) forwards;
}

@keyframes pageSlideUp{
  0%  {transform:translateY(80vh) scale(.97);opacity:.5}
  100%{transform:translateY(0) scale(1);opacity:1}
}

/* ── Nav slides down from top after page arrives ── */
html.transition-entering nav{
  opacity:0;
  transform:translateY(-100%);
}
html.transition-slide-up nav{
  animation:navSlideDown 1.4s cubic-bezier(.19,1,.22,1) .35s forwards;
}
@keyframes navSlideDown{
  0%  {opacity:0;transform:translateY(-100%)}
  100%{opacity:1;transform:translateY(0)}
}

/* ── Enhanced reveals after page transition ── */
html.transition-entering .reveal{
  opacity:0;
  transform:translateY(60px);
}
html.transition-entering .reveal.visible{
  transition-duration:1.5s;
  transition-timing-function:var(--ease);
}
html.transition-entering [data-animation="words"] .word-inner{
  transform:translateY(115%);
}
html.transition-entering .reveal-delay-1{transition-delay:.2s}
html.transition-entering .reveal-delay-2{transition-delay:.4s}
html.transition-entering .reveal-delay-3{transition-delay:.6s}
html.transition-entering .reveal-delay-4{transition-delay:.8s}

