/* Typography & Base inspired by a61.ru: stark black/white with neon-accent */
:root{
  --bg:#ffffff;
  --text:#000000;
  --muted:#6a6a6a;
  --accent:#c7ff00; /* neon lime similar to screenshots */
  --line:#e6e6e6;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter',system-ui,-apple-system,"Segoe UI",Roboto,Arial,Helvetica,sans-serif;
  color:var(--text);
  background:var(--bg);
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* Respect reduced motion preferences globally */
@media (prefers-reduced-motion: reduce){
  html:focus-within { scroll-behavior: auto; }
  *, *::before, *::after { animation: none !important; transition: none !important; }
}

/* Exception: allow gentle reveal for Telegram follow on mobile, even with reduced motion */
@media (prefers-reduced-motion: reduce) and (max-width: 768px) {
  .telegram-follow .container {
    transition: opacity .9s cubic-bezier(0.22, 1, 0.36, 1), transform .9s cubic-bezier(0.22, 1, 0.36, 1) !important;
  }
}

/* Mobile performance optimizations */
@media (max-width: 768px) {
  /* Reduce paint complexity */
  .hero-slides .slide,
  .story-media,
  .project-hero-slides .slide {
    transform: translateZ(0);
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
  }
  
  /* Optimize fonts for mobile */
  body {
    font-display: swap;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
  
  /* Reduce animation complexity on mobile */
  .service::before,
  .service-overlay {
    transition: opacity 0.2s ease !important;
  }
  
  /* Optimize story sections for mobile */
  .story {
    min-height: 50vh;
  }
  
  .story .story-box {
    padding: 20px 16px;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    background: rgba(255,255,255,0.9);
  }
}

.container{width:min(1160px,92%);margin:0 auto}

/* Header */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100}
.site-header.transparent{background:linear-gradient(180deg,rgba(0,0,0,.45),rgba(0,0,0,0));color:#fff}
.header-bar{display:flex;align-items:center;justify-content:space-between;padding:14px 16px}
.weather{display:flex;gap:10px;align-items:center;font-weight:600;background:rgba(0,0,0,.1);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:10px 14px;border-radius:0;border:1px solid rgba(255,255,255,.1)}
.weather .w-city{padding:0 6px;border-radius:0}
.weather .w-icon{filter:drop-shadow(0 1px 0 rgba(0,0,0,.2))}
.weather .w-temp{font-size:18px}
.weather .w-minmax{opacity:.85;font-size:12px}
.brand-top{position:absolute;left:50%;transform:translateX(-50%);top:10px;text-align:center;background:rgba(0,0,0,.1);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:12px 24px;border-radius:0;border:1px solid rgba(255,255,255,.1);min-width:280px}
.brand-top .brand-title{font-size:28px;letter-spacing:.02em}
.brand-top .brand-sub{font-size:12px;opacity:.9;margin-top:2px}

/* Mobile header layout adjustments */
@media (max-width: 768px) {
  /* Use grid to align weather (left) and burger (right) on one row, brand below */
  .header-bar {
    display: grid;
    grid-template-columns: 1fr auto 1fr; /* left spacer, centered weather, burger */
    grid-template-areas:
      "spacer weather burger"
      "brand  brand   brand";
    align-items: center;
    gap: 10px 14px; /* ensure distance from burger */
    padding: 12px 16px;
  }
  .weather { grid-area: weather; margin-bottom: 0; width: max-content; max-width: 90vw; justify-self: center; padding: 6px 10px; }
  .weather .w-temp{font-size:16px}
  .weather .w-minmax{font-size:11px}
  .brand-top {
    grid-area: brand;
    position: static;
    transform: none;
    top: auto;
    min-width: auto;
    padding: 6px 12px;
    margin-top: 0;
    max-width: 90vw;
    box-sizing: border-box;
    justify-self: center;
  }
  .brand-top .brand-title { font-size: clamp(14px, 5.2vw, 18px); }
  .brand-top .brand-sub { font-size: clamp(8px, 2.8vw, 10px); }
  .burger {
    grid-area: burger;
    position: static;
    align-self: center; /* vertically center relative to weather */
    justify-self: end;
  }
}

/* Tablet layout (iPad Mini/Air portrait/landscape) */
@media (min-width: 769px) and (max-width: 1024px) {
  .header-bar{
    display:grid;
    grid-template-columns:1fr auto 1fr;
    grid-template-areas:
      "spacer weather burger"
      "brand  brand   brand";
    align-items:center;
    gap:12px 16px;
    padding:14px 20px;
  }
  .weather{grid-area:weather; width:max-content; justify-self:center}
  .brand-top{grid-area:brand; position:static; transform:none; justify-self:center; padding:10px 18px}
  .burger{grid-area:burger; position:static; align-self:center; justify-self:end}

  /* Center CTA content and button on tablets */
  .cta-inner{justify-content:center; gap:20px}
  .cta-inner .btn{margin:0 auto}
}
.burger{width:42px;height:32px;display:grid;place-items:center;gap:6px;background:transparent;border:0;cursor:pointer}
.burger span{display:block;width:28px;height:2px;background:#fff;transition:transform .3s,opacity .3s}
.burger.active span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger.active span:nth-child(2){opacity:0}
.burger.active span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
.menu-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.45);opacity:0;pointer-events:none;transition:opacity .3s}
.menu-backdrop.open{opacity:1;pointer-events:auto}
.side-menu{position:fixed;top:0;right:0;height:100vh;width:min(360px,50vw);background:rgba(10,25,15,.55);backdrop-filter:blur(10px) saturate(140%);-webkit-backdrop-filter:blur(10px) saturate(140%);color:#fff;transform:translateX(100%);transition:transform .35s cubic-bezier(.2,.8,.2,1);padding:16px 18px 22px;display:flex;flex-direction:column;gap:16px;border-left:1px solid rgba(255,255,255,.08);box-shadow:-10px 0 30px rgba(0,0,0,.2);overflow:auto}
.side-menu.open{transform:translateX(0)}
.menu-close{align-self:flex-end;background:transparent;border:0;color:#fff;font-size:32px;line-height:1;cursor:pointer}
.menu-nav{display:flex;flex-direction:column;gap:16px;margin-top:12px}
.menu-nav a{position:relative;font-size:22px;border-bottom:1px solid rgba(255,255,255,.1);padding:12px 4px;white-space:normal;word-break:break-word;text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:10px;overflow:hidden}
@media (max-width:768px){
  .menu-nav a{font-size:clamp(13px,3.8vw,17px);line-height:1.25;letter-spacing:.04em;padding:10px 4px}
}
.menu-item .mi-arrow{transform:translateX(-120%);opacity:0;transition:transform .3s ease, opacity .3s ease;color:var(--accent);font-weight:800}
.menu-item .mi-label{display:inline-block;transform:translateX(-20px);transition:transform .3s ease, color .3s ease}
.menu-item:hover .mi-arrow,.menu-item:focus-visible .mi-arrow{transform:translateX(0);opacity:1}
.menu-item:hover .mi-label,.menu-item:focus-visible .mi-label{transform:translateX(0);color:var(--accent)}
.menu-item:active .mi-label{transform:translateX(2px)}

/* Sections */
.section{padding:80px 0}
.section.transition{position:relative;overflow:hidden}
.section.transition .container{opacity:0;transform:translateY(80px)}
/* Ensure sections without .transition are visible by default */
.section:not(.transition) .container{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  .section.transition .container{opacity:1;transform:none}
}
/* disable snap to avoid jerky jumps */
.section-title{font-size:42px;letter-spacing:-.02em;margin:0 0 28px}

/* Hero */
.animated-image-text{margin-bottom:100px}
.full-viewport{min-height:100vh;position:relative;background:#0a0a0a}
.hero-slides{position:absolute;inset:0;margin:0;padding:0;list-style:none;z-index:1}
.hero-slides .slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.0s ease}
@media (prefers-reduced-motion: reduce){
  .hero-slides .slide{transition:none}
}
.hero-slides .slide.active{opacity:1}
.hero-overlay{position:absolute;inset:0;display:grid;place-items:center;text-align:center;color:#fff;padding:20vh 16px 16px;z-index:2}
.hero-overlay::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.55),rgba(0,0,0,.35));z-index:-1}
.brand-title{font-family:'Montserrat', 'Inter', sans-serif;font-weight:600;letter-spacing:.02em;text-transform:uppercase;font-size:72px}
.brand-sub{margin-top:10px;font-size:18px;opacity:.9;font-weight:600;text-transform:uppercase;letter-spacing:.08em}
.btn{display:inline-block;background:#0a0a0a;color:#fff;padding:14px 18px;border-radius:0;border:1px solid #0a0a0a;transition:transform .2s}
.btn:hover{transform:translateY(-1px)}
.btn.ghost{background:transparent;color:#0a0a0a;border-color:#0a0a0a}
.media-box{position:relative;overflow:hidden;border-radius:0}

/* Mobile: align hero text to left */
@media (max-width:768px){
  .hero-overlay{place-items:start !important;justify-items:start !important;text-align:left !important;padding:20vh 16px 16px}
  .hero-overlay > *{justify-self:start !important;text-align:left !important}
}

/* Mobile: make gap between Projects and CTA match Services→Projects */
@media (max-width:768px){
  .cta{padding-top:24px !important; padding-bottom:24px !important}
  .cta-inner{padding:16px 16px; flex-direction:column; align-items:center; justify-content:center; gap:20px}
  .cta-inner .btn{margin:0 auto}
}

/* Mobile: force left alignment for project page titles */
@media (max-width:768px){
  .project-title-section{justify-content:flex-start !important}
  .project-main-title{display:block;text-align:left !important}
}
.media-box::after{content:"";position:absolute;inset:0;border:1px solid var(--line);border-radius:0;pointer-events:none}

/* About */
.about-inner{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center}

/* A61-style split layout: large black headline at left, image at right with lime overlay title */
#about .about-block{background:#fff}
#about .about-block .about-content{display:flex;flex-direction:column;gap:0}
#about .about-block .overlap-title{margin:0}
#about .about-block .img-title-lime{left:20px;top:20px;right:20px}

/* Services */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.service{border:1px solid var(--line);border-radius:0;padding:20px;position:relative;background-image:var(--img);background-size:cover;background-position:center;background-repeat:no-repeat;min-height:220px}
.service::before{content:none}
/* Ensure image child can render as background replacement */
.service .service-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;filter:brightness(.72) saturate(.98);transform:scale(1.02);transition:filter .35s ease,transform .4s ease}
@media (max-width:768px){
  /* Keep a consistent tile shape and prevent vertical stretching */
  .service{min-height:auto;aspect-ratio:16/9}
  .service .service-bg{filter:brightness(.94) saturate(1);transform:none;object-position:center}
  /* Let content own readability with its own gradient */
  #services .service-overlay{background:rgba(0,0,0,0.12)}
  /* Pin content to bottom with readable gradient (slightly lighter) */
  #services .service-content{position:absolute;left:0;right:0;bottom:0;height:auto;padding:14px 16px;background:linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.45) 48%, rgba(0,0,0,.78) 100%)}
  #services .service-top{margin-bottom:6px}
  #services .service-title{font-size:clamp(16px,4.4vw,18px)}
  #services .service-desc{font-size:14px;max-width:100%;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
}
.service h3{margin:8px 0 6px}
.service p{margin:0;color:#eaeaea}
.service-num{display:inline-block;background:#6a6a6a;font-weight:700;padding:4px 8px;border-radius:0;color:#c7ff00}

/* Projects */
.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.project{border-radius:0;overflow:hidden}

/* CTA */
.cta{background:#0a0a0a;color:#fff}
.cta-inner{display:flex;align-items:center;justify-content:space-between;border-radius:0;padding:28px 24px;background:linear-gradient(180deg,#0a0a0a 0%,#101010 100%);will-change:transform,opacity;contain:paint;} 
.cta .btn{background:var(--accent);color:#0a0a0a;border-color:var(--accent)}

/* Story narrative (split-screen, scroll) */
.story{position:relative;min-height:90vh;display:grid;grid-template-columns:1fr;place-items:stretch;background:#ffffff}
.story{margin-bottom:24px}
.story .story-media{position:absolute;inset:0;background-size:cover;background-position:center;filter:grayscale(8%) contrast(1.05) brightness(.92);transform:scale(1.06);will-change:transform}
.story .story-media .story-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.story .story-text{position:relative;z-index:2;display:flex;align-items:center;justify-content:flex-end;width:100vw;max-width:100vw;margin-left:calc(-50vw + 50%)}
.story[data-align="left"] .story-text{justify-content:flex-start}
.story .story-box{width:min(820px,48vw);margin:0 40px;background:rgba(255,255,255,.78);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid rgba(0,0,0,.08);padding:36px 28px}
.story[data-align="left"] .story-box{margin-left:40px;margin-right:auto}
.story[data-align="right"] .story-box{margin-right:40px;margin-left:auto}
.story .story-ribbon{display:inline-block;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#0a0a0a;background:var(--accent);padding:4px 10px;border:none}
.story .story-title{margin:14px 0 8px;font-size:clamp(1.6rem,4vw,3rem);font-weight:300;line-height:1.1;text-transform:uppercase}
.story .story-lead{margin:0;color:#000000;font-size:clamp(1rem,2vw,1.25rem);line-height:1.6}

/* Subtle theme tints per story */
.story[data-theme="water"] .story-box{background:linear-gradient( to bottom, rgba(231, 247, 255,.85), rgba(255,255,255,.82) )}
.story[data-theme="sewage"] .story-box{background:linear-gradient( to bottom, rgba(242,242,242,.9), rgba(255,255,255,.82) )}
.story[data-theme="power"] .story-box{background:linear-gradient( to bottom, rgba(255,255,230,.88), rgba(255,255,255,.82) )}
.story[data-theme="heat"] .story-box{background:linear-gradient( to bottom, rgba(255,240,220,.88), rgba(255,255,255,.82) )}

/* Scroll reveal for story */
.story .story-box{opacity:0;transform:translateY(28px);transition:opacity .8s ease, transform .9s ease}
.story.is-visible .story-box{opacity:1;transform:translateY(0)}
@media (prefers-reduced-motion: reduce){
  .story .story-box{opacity:1;transform:none;transition:none}
}

@media (max-width: 1024px){
  .story{min-height:70vh}
  .story .story-box{width:min(920px,92vw)}
}
@media (max-width: 720px){
  .story{min-height:64vh}
  .story .story-text{justify-content:center}
  .story .story-box{margin:0 16px;padding:22px 16px}
}

/* Match gap: last Story ⇄ CTA equals About ⇄ Services (12px + 12px) */
.story:last-of-type{padding-bottom:16px}
/* Next generic section (button) after stories */
.story:last-of-type + .section{padding-top:24px !important; margin-top:0px !important}
/* Normalize inner container margins for the button section */
.story:last-of-type + .section > .container{margin-top:0 !important; margin-bottom:0 !important}
/* Also normalize if there are multiple stories before */
.story + .section{margin-top:0 !important}
.story + .section > .container{margin-top:0 !important; margin-bottom:0 !important}

/* CTA Button specific styling */
.cta-button {
  padding: 24px 0 12px 0 !important; /* more gap above the button from Heat block */
  margin: 0 !important;
  display: block; /* use normal flow to avoid artificial vertical centering */
}

.cta-button .container {
  text-align: center;
  margin: 0 auto;
  display: block;
  width: 100%;
}

.cta-button .btn {
  display: block;
  background: transparent;
  color: #0a0a0a;
  padding: 14px 24px;
  border-radius: 0;
  border: 1px solid #0a0a0a;
  text-decoration: none;
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  font-size: 22px;
  transition: transform 0.2s;
  width: 100%;
  max-width: 600px;
  margin: 0 auto;
}

.cta-button .btn:hover {
  transform: translateY(-1px);
}

/* Mobile: tighter gap between Heat story and CTA button */
@media (max-width: 768px){
  .story:last-of-type{padding-bottom:8px}
  .story:last-of-type + .section{padding-top:8px !important}
  .cta-button{padding:12px 0 8px 0 !important}
}

/* Contacts */
.contacts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:768px){
  .contacts-grid{row-gap:16px}
  .contacts .big-link{font-size:clamp(18px,6vw,24px)}
}
.big-link{font-size:28px;text-decoration:underline}

/* Footer */
.site-footer{border-top:1px solid var(--line);padding:18px 0}
.footer-inner{display:flex;align-items:center;justify-content:space-between}
.footer-note{color:var(--muted)}

/* Animations base (GSAP will target attributes) */
[data-animate="reveal"],[data-animate="image-reveal"],[data-animate="split"]{opacity:0;transform:translateY(24px)}
@media (prefers-reduced-motion: reduce){
  [data-animate="reveal"],[data-animate="image-reveal"],[data-animate="split"]{opacity:1;transform:none}
}

/* Animated text block per-word weights */
.animated-text-block .word{
  font-weight:230;
  font-variation-settings: "wght" 230, "opsz" 28;
  transition: font-weight .2s ease, font-variation-settings .2s ease;
}
.animated-text-block .word.active{
  font-weight:430;
  font-variation-settings: "wght" 430, "opsz" 28;
}

/* Scroller wrapper to keep animated block pinned while stepping words */
.animated-text-scroller{position:relative}
.animated-text-scroller .animated-text-block{will-change: position; position: sticky; top: 0}
@media (max-width:768px){
  .animated-text-scroller .animated-text-block{top: 8px}
}

/* Responsive */
@media (max-width:1024px){
  .brand-title{font-size:52px}
  .services-grid,.projects-grid{grid-template-columns:repeat(2,1fr)}
  .contacts-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
  .about-inner{grid-template-columns:1fr}
  .services-grid,.projects-grid{grid-template-columns:1fr}
  .section{padding:56px 0}
  .brand-title{font-size:36px}
}

/* Project pages: halve spacing between title and text on mobile */
@media (max-width:768px){
  .project-description-container{gap:16px !important}
  .project-title-section{margin-bottom:8px !important}
  .project-main-title{margin:0 0 8px 0 !important}
  .project-description-content{margin-top:0 !important}
}



/* Disable lime overlay masking inside sticky blocks in #about */
#about .about-block .overlap-title{position:relative}
#about .about-block .overlap-title .ot-lime{position:relative !important; inset:auto !important; clip-path:none !important}

/* Ensure no transforms or transitions cause overlay-like movement in sticky blocks (blocks 1-4) */
#about .about-block .overlap-title,
#about .about-block .overlap-title .ot-lime{
  transform:none !important;
  transition:none !important;
  top:auto !important; right:auto !important; bottom:auto !important; left:auto !important;
}

/* Additionally lock non-animated blocks (2-4) */
#about .about-block.no-animate .overlap-title,
#about .about-block.no-animate .overlap-title .ot-lime{
  position:relative !important;
  inset:auto !important;
  clip-path:none !important;
}

/* Hide lime layer entirely for non-animated blocks (2-4) */
#about .about-block.no-animate .overlap-title .ot-lime{display:none !important}

/* Make non-animated blocks non-sticky to fully remove overlay behavior */
#about .about-block.no-animate{position:relative !important; top:auto !important; height:auto !important; z-index:auto !important}

/* Force pure black text within explicitly white-background sections */
.section[style*="background-color: white"]{color:#000000 !important}
.section[style*="background-color: white"] a{color:#000000 !important}
.telegram-follow{color:#000000}
.telegram-follow a{color:#000000 !important}
/* Telegram reveal: CSS-based transition, mobile-first */
.telegram-follow .container{opacity:1; transform:none; transition:opacity .9s cubic-bezier(0.22, 1, 0.36, 1), transform .9s cubic-bezier(0.22, 1, 0.36, 1)}
@media (max-width:768px){
  .telegram-follow .container{opacity:0; transform:translateY(24px)}
  .telegram-follow .container.is-visible{opacity:1 !important; transform:none !important}
}
/* Desktop: prevent initial flash while JS prepares animation */
@media (min-width:769px){
  html.tg-ready .telegram-follow .container{opacity:0; transform:translateY(40px)}
  html.tg-ready .telegram-follow .container.is-visible{opacity:1 !important; transform:none !important}
}

/* Apply button styling under heat block */
.apply-btn{
  display:inline-block;
  min-width: min(680px, 80%);
  padding: 18px 24px;
  font-family:'Inter',sans-serif;
  font-size: 22px;
  font-weight: 500;
  color:#000000;
  background:transparent;
  border:1px solid #000000;
  border-radius:0;
  transition: background-color .25s ease, color .25s ease, border-color .25s ease, transform .2s ease;
}
.apply-btn:hover{
  background:#c7ff00;
  border-color:#c7ff00;
  color:#000000;
  transform: translateY(-1px);
}

/* Mixed color for water-artery sentence: lime over image area, black over white area */
.artery-block-container .full-width-text,
.electric-block-container .full-width-text,
.heat-block-container .full-width-text{
  background-image: linear-gradient(to right, #c7ff00 var(--artery-cut, 66%), #000000 0);
  -webkit-background-clip: text;
  background-clip: text;
}
@media (max-width: 1200px){
  .artery-block-container .full-width-text,
  .electric-block-container .full-width-text,
  .heat-block-container .full-width-text{ --artery-cut: 72%; }
}
@media (max-width: 992px){
  .artery-block-container .full-width-text,
  .electric-block-container .full-width-text,
  .heat-block-container .full-width-text{ --artery-cut: 80%; }
}
@media (max-width: 768px){
  .artery-block-container .full-width-text,
  .electric-block-container .full-width-text,
  .heat-block-container .full-width-text{ --artery-cut: 88%; }
}

/* Fine-tune cutoff for Electricity block to keep middle phrase black */
.electric-block-container .full-width-text{ --artery-cut: 52%; }
@media (max-width: 1200px){
  .electric-block-container .full-width-text{ --artery-cut: 48%; }
}
@media (max-width: 992px){
  .electric-block-container .full-width-text{ --artery-cut: 44%; }
}
@media (max-width: 768px){
  .electric-block-container .full-width-text{ --artery-cut: 40%; }
}

/* Heat block uses explicit spans to color exact words */
.heat-block-container .full-width-text{ background:none; -webkit-background-clip: initial; background-clip: border-box; color:inherit; -webkit-text-fill-color: initial; }
.heat-block-container .full-width-text .hb-black{ color:#000000 !important; -webkit-text-fill-color:#000000 !important; }
.heat-block-container .full-width-text .hb-lime{ color:#c7ff00 !important; -webkit-text-fill-color:#c7ff00 !important; }

.heat-block-text-style {
  font-family: 'Inter', sans-serif;
  font-size: clamp(2rem, 2.6vw, 5rem);
  font-weight: 200;
  line-height: 1.1;
  text-transform: uppercase;
  text-align: left;
  padding-left: 40px;
  padding-right: 0;
}

/* Scroll Reveal Animation */
.scroll-reveal-text {
  opacity: 0;
  transform: translateY(100%); /* Start from below */
  transition: opacity 1.8s ease-in-out, transform 1.8s ease-in-out; /* Animation duration and timing */
}

.scroll-reveal-text.is-visible {
  opacity: 1;
  transform: translateY(0); /* Move to original position */
}

/* Mirrored mixed color for sewer sentence: lime over right image area, black on left */
.sewer-block-container .full-width-text{
  background-image: linear-gradient(to left, #c7ff00 var(--sewer-cut, 35%), #000000 0);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent !important;
  -webkit-text-fill-color: transparent !important;
}
@media (max-width: 1200px){
  .sewer-block-container .full-width-text{ --sewer-cut: 42%; }
}
@media (max-width: 992px){
  .sewer-block-container .full-width-text{ --sewer-cut: 52%; }
}
@media (max-width: 768px){
  .sewer-block-container .full-width-text{ --sewer-cut: 64%; }
}

.blue-artery-text {
  color: #199AD3 !important;
  background: none !important;
}

/* Mobile overrides for all project pages: tighten title↔text spacing */
@media (max-width:768px){
  .project-description-section{padding:24px 0 !important; min-height:auto !important}
  .project-description-container{gap:16px !important; padding-left:20px !important; padding-right:20px !important}
  .project-title-section{height:auto !important; min-height:12vh !important; padding-top:0 !important; margin-bottom:8px !important}
  .project-main-title{position:static !important; transform:none !important; top:auto !important; margin:0 0 8px 0 !important; font-size:clamp(1.8rem, 6.5vw, 2.6rem) !important}
  .project-description-content{margin-top:0 !important; font-size:16px !important; line-height:1.6 !important}
  /* Override inline styles on specific project pages */
  .project-description-container{padding:0 20px !important; gap:16px !important}
}