/* ============================================================
   SRI MAYA DIGITAL — Premium Stylesheet (Multi-Page Edition)
   Fonts: Syne (display) + DM Sans (body)
   ============================================================ */

:root {
  --brand-red:   #e53935;
  --brand-red-dk:#b71c1c;
  --brand-gold:  #f59e0b;
  --brand-gold-lt:#fef3c7;
  --brand-green: #16a34a;
  --brand-blue:  #1d4ed8;

  --ink:    #0a0a0f;
  --ink-2:  #1c1c27;
  --ink-3:  #2e2e3e;
  --muted:  #64647a;
  --muted-lt:#9898ad;
  --border:    rgba(0,0,0,.08);
  --border-dk: rgba(0,0,0,.14);

  --surface:   #ffffff;
  --surface-2: #f8f8fb;
  --surface-3: #f2f2f7;

  --grad-hero: linear-gradient(160deg,#fffbeb 0%,#fef3c7 35%,#fde68a 65%,#fbbf24 100%);
  --grad-dark: linear-gradient(135deg,#0a0a1a 0%,#0f0f2a 50%,#141430 100%);

  --shadow-xs: 0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --shadow-sm: 0 4px 12px rgba(0,0,0,.07),0 1px 3px rgba(0,0,0,.04);
  --shadow-md: 0 8px 28px rgba(0,0,0,.10),0 2px 6px rgba(0,0,0,.05);
  --shadow-lg: 0 20px 48px rgba(0,0,0,.13),0 4px 12px rgba(0,0,0,.06);
  --shadow-xl: 0 32px 72px rgba(0,0,0,.18);
  --glow-gold: 0 0 48px rgba(251,191,36,.28);
  --glow-red:  0 8px 32px rgba(229,57,53,.4);

  /* ── FIX: marquee height token so hero knows the offset ── */
  --marquee-h: 46px;
  --nav-h:     68px;

  --content-w: 1200px;
  --radius-sm: 10px;
  --radius:    16px;
  --radius-lg: 24px;
  --radius-xl: 32px;

  --font-display: 'Syne', system-ui, sans-serif;
  --font-body:    'DM Sans', system-ui, sans-serif;

  --ease-out:    cubic-bezier(0.22,1,0.36,1);
  --ease-spring: cubic-bezier(0.34,1.56,0.64,1);
}

/* ── Reset ── */
*,*::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:var(--font-body);color:var(--ink);background:var(--surface);overflow-x:hidden;line-height:1.6}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}


/* ══════════════════════════════════════════
   PREMIUM CINEMATIC LOADER
══════════════════════════════════════════ */
.loader{position:fixed;inset:0;z-index:10000;background:#f8f4ee;overflow:hidden;display:flex;align-items:center;justify-content:center;transition:opacity .6s var(--ease-out),visibility .6s}
.loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader__ink{position:absolute;inset:0;transform-origin:top}
.loader__ink--c{background:rgba(0,174,239,.55);clip-path:polygon(0 0,100% 0,100% 0,0 0);animation:inkRevealC 2.6s cubic-bezier(.76,0,.24,1) forwards}
.loader__ink--m{background:rgba(236,0,140,.45);clip-path:polygon(0 0,100% 0,100% 0,0 0);animation:inkRevealM 2.6s cubic-bezier(.76,0,.24,1) .08s forwards}
.loader__ink--y{background:rgba(255,242,0,.55);clip-path:polygon(0 0,100% 0,100% 0,0 0);animation:inkRevealY 2.6s cubic-bezier(.76,0,.24,1) .16s forwards}
.loader__ink--k{background:#0a0a0f;clip-path:polygon(0 0,100% 0,100% 0,0 0);animation:inkRevealK 2.6s cubic-bezier(.76,0,.24,1) .24s forwards}
@keyframes inkRevealC{0%{clip-path:polygon(0 0,100% 0,100% 0,0 0);opacity:1}28%{clip-path:polygon(0 0,100% 0,100% 100%,0 100%);opacity:1}72%{clip-path:polygon(0 0,100% 0,100% 100%,0 100%);opacity:1}100%{clip-path:polygon(0 0,100% 0,100% 0,0 0);opacity:0}}
@keyframes inkRevealM{0%{clip-path:polygon(0 0,100% 0,100% 0,0 0);opacity:1}28%{clip-path:polygon(0 0,100% 0,100% 100%,0 100%);opacity:1}72%{clip-path:polygon(0 0,100% 0,100% 100%,0 100%);opacity:1}100%{clip-path:polygon(0 0,100% 0,100% 0,0 0);opacity:0}}
@keyframes inkRevealY{0%{clip-path:polygon(0 0,100% 0,100% 0,0 0);opacity:1}28%{clip-path:polygon(0 0,100% 0,100% 100%,0 100%);opacity:1}72%{clip-path:polygon(0 0,100% 0,100% 100%,0 100%);opacity:1}100%{clip-path:polygon(0 0,100% 0,100% 0,0 0);opacity:0}}
@keyframes inkRevealK{0%{clip-path:polygon(0 0,100% 0,100% 0,0 0);opacity:1}36%{clip-path:polygon(0 0,100% 0,100% 100%,0 100%);opacity:.9}78%{clip-path:polygon(0 0,100% 0,100% 100%,0 100%);opacity:.9}100%{clip-path:polygon(0 0,100% 0,100% 0,0 0);opacity:0}}

.loader__scanline{position:absolute;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent 0%,rgba(229,57,53,.9) 30%,rgba(251,191,36,1) 50%,rgba(229,57,53,.9) 70%,transparent 100%);box-shadow:0 0 20px rgba(229,57,53,.6),0 0 60px rgba(251,191,36,.4);z-index:2;animation:scanMove 1.8s cubic-bezier(.4,0,.6,1) .5s both}
@keyframes scanMove{0%{top:0;opacity:0}5%{opacity:1}95%{opacity:1}100%{top:100%;opacity:0}}

.loader__stage{position:relative;z-index:10;display:flex;flex-direction:column;align-items:center;gap:2rem;opacity:0;animation:stageFadeIn .5s ease 1.5s forwards}
@keyframes stageFadeIn{to{opacity:1}}

.loader__reg{position:absolute;width:20px;height:20px;opacity:0;animation:regPop .3s ease 1.6s forwards}
.loader__reg::before,.loader__reg::after{content:'';position:absolute;background:rgba(229,57,53,.7)}
.loader__reg::before{width:100%;height:1px;top:50%}
.loader__reg::after{height:100%;width:1px;left:50%}
.loader__reg--tl{top:-60px;left:-80px}
.loader__reg--tr{top:-60px;right:-80px}
.loader__reg--bl{bottom:-60px;left:-80px}
.loader__reg--br{bottom:-60px;right:-80px}
@keyframes regPop{to{opacity:1}}

.loader__logo-wrap{position:relative;width:140px;height:140px;display:flex;align-items:center;justify-content:center}
.loader__logo-mask{width:110px;height:110px;border-radius:24px;overflow:hidden;position:relative;z-index:2;box-shadow:0 20px 60px rgba(0,0,0,.15),0 0 0 1.5px rgba(255,255,255,.8);clip-path:inset(100% 0 0 0);animation:logoReveal .6s cubic-bezier(.22,1,.36,1) 1.7s forwards}
@keyframes logoReveal{to{clip-path:inset(0% 0 0 0)}}
.loader__logo{width:110px;height:110px;object-fit:contain;background:transparent}
.loader__logo-ring{position:absolute;inset:0;border-radius:50%;border:1.5px solid rgba(229,57,53,.25);animation:ringPulse 2s ease-in-out 2s infinite}
.loader__logo-ring--2{inset:-14px;border-color:rgba(251,191,36,.2);animation-delay:2.3s}
@keyframes ringPulse{0%,100%{transform:scale(1);opacity:.5}50%{transform:scale(1.06);opacity:1}}

.loader__title-wrap{display:flex;flex-direction:column;align-items:center;gap:.5rem;text-align:center}
.loader__title-line{display:flex;gap:.04em;overflow:hidden}
.loader__title-line--2{margin-top:-.15em}
.loader__title-char{display:inline-block;font-family:var(--font-display);font-weight:800;font-size:clamp(2rem,7vw,3.5rem);letter-spacing:.18em;text-transform:uppercase;color:var(--ink);transform:translateY(110%);animation:charUp .55s cubic-bezier(.22,1,.36,1) both}
.loader__title-char--space{width:.35em}
.loader__title-line:first-child .loader__title-char:nth-child(1){animation-delay:calc(1.8s + 0*0.045s)}
.loader__title-line:first-child .loader__title-char:nth-child(2){animation-delay:calc(1.8s + 1*0.045s)}
.loader__title-line:first-child .loader__title-char:nth-child(3){animation-delay:calc(1.8s + 2*0.045s)}
.loader__title-line:first-child .loader__title-char:nth-child(4){animation-delay:calc(1.8s + 3*0.045s)}
.loader__title-line:first-child .loader__title-char:nth-child(5){animation-delay:calc(1.8s + 4*0.045s)}
.loader__title-line:first-child .loader__title-char:nth-child(6){animation-delay:calc(1.8s + 5*0.045s)}
.loader__title-line:first-child .loader__title-char:nth-child(7){animation-delay:calc(1.8s + 6*0.045s)}
.loader__title-line:first-child .loader__title-char:nth-child(8){animation-delay:calc(1.8s + 7*0.045s)}
.loader__title-line--2 .loader__title-char:nth-child(1){animation-delay:calc(2.0s + 0*0.045s)}
.loader__title-line--2 .loader__title-char:nth-child(2){animation-delay:calc(2.0s + 1*0.045s)}
.loader__title-line--2 .loader__title-char:nth-child(3){animation-delay:calc(2.0s + 2*0.045s)}
.loader__title-line--2 .loader__title-char:nth-child(4){animation-delay:calc(2.0s + 3*0.045s)}
.loader__title-line--2 .loader__title-char:nth-child(5){animation-delay:calc(2.0s + 4*0.045s)}
.loader__title-line--2 .loader__title-char:nth-child(6){animation-delay:calc(2.0s + 5*0.045s)}
.loader__title-line--2 .loader__title-char:nth-child(7){animation-delay:calc(2.0s + 6*0.045s)}
@keyframes charUp{to{transform:translateY(0)}}

.loader__subtitle-wrap{display:flex;flex-direction:column;align-items:center;gap:.65rem;opacity:0;animation:subtitleIn .5s ease 2.5s forwards}
@keyframes subtitleIn{to{opacity:1}}
.loader__subtitle{font-size:.75rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.loader__progress-track{width:120px;height:1.5px;background:rgba(0,0,0,.1);border-radius:2px;overflow:hidden}
.loader__progress-fill{height:100%;width:0;background:linear-gradient(90deg,var(--brand-red),var(--brand-gold));border-radius:2px;animation:progressFill 1.2s cubic-bezier(.4,0,.2,1) 2.5s forwards}
@keyframes progressFill{to{width:100%}}

.loader__dot-grid{position:absolute;inset:0;pointer-events:none;z-index:1;background-image:radial-gradient(circle,rgba(0,0,0,.06) 1px,transparent 1px);background-size:24px 24px;opacity:0;animation:dotGridFade .8s ease 1.4s forwards}
@keyframes dotGridFade{to{opacity:1}}


/* ══════════════════════════════════════════
   NAV
   FIX: links group moved right — flex layout adjusted
══════════════════════════════════════════ */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);background:rgba(255,255,255,.82);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);transition:background .3s,box-shadow .3s,border-color .3s}
.nav.scrolled{background:rgba(255,255,255,.96);box-shadow:var(--shadow-sm);border-color:var(--border-dk)}

.nav__wrap{
  width:100%; max-width:none;
  margin:0 auto; height:100%;
  padding:0 1.5rem;
  display:flex; align-items:center;
  /* FIX 2: brand left, links + cta grouped on the right */
  gap:0;
}

.nav__brand{display:flex;align-items:center;gap:.65rem;flex-shrink:0;margin-right:auto}
.nav__brand img{width:34px;height:34px;object-fit:contain;border-radius:7px}
.nav__brand-name{font-family:var(--font-display);font-weight:700;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brand-red-dk);white-space:nowrap}

/* Nav center is now right-aligned cluster */
.nav__center{display:flex;justify-content:flex-end;align-items:center;flex-shrink:0}
.nav__links{display:flex;align-items:center;gap:clamp(.4rem,1.4vw,1.25rem)}
.nav__links a{font-size:.875rem;font-weight:500;color:var(--ink-3);opacity:.8;transition:color .2s,opacity .2s;position:relative;white-space:nowrap}
.nav__links a::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:1.5px;background:var(--brand-red);border-radius:2px;transform:scaleX(0);transition:transform .25s var(--ease-out)}
.nav__links a:hover,.nav__links a.is-active{color:var(--brand-red);opacity:1}
.nav__links a:hover::after,.nav__links a.is-active::after{transform:scaleX(1)}

.nav__right{display:flex;align-items:center;gap:.65rem;flex-shrink:0;margin-left:.75rem}
.nav__cta{padding:.5rem 1.1rem;border-radius:999px;background:var(--brand-red);color:#fff;font-size:.8rem;font-weight:600;letter-spacing:.01em;box-shadow:var(--glow-red);transition:transform .2s,box-shadow .2s,background .2s;white-space:nowrap}
.nav__cta:hover{transform:translateY(-1px);background:var(--brand-red-dk);box-shadow:0 12px 36px rgba(229,57,53,.45)}

.nav__toggle{display:none;flex-direction:column;align-items:center;justify-content:center;gap:0;background:none;border:none;cursor:pointer;width:40px;height:40px;border-radius:10px;transition:background .2s;-webkit-tap-highlight-color:transparent}
.nav__toggle:hover{background:var(--surface-3)}
.nav__toggle-icon{display:flex;flex-direction:column;gap:5px}
.nav__bar{display:block;height:1.5px;background:var(--ink);border-radius:2px;transition:transform .4s var(--ease-out),opacity .3s,width .3s}
.nav__bar--1{width:22px}
.nav__bar--2{width:16px}
.nav__bar--3{width:22px}
.nav__toggle[aria-expanded="true"] .nav__bar--1{transform:translateY(6.5px) rotate(45deg);width:22px}
.nav__toggle[aria-expanded="true"] .nav__bar--2{opacity:0;transform:scaleX(0)}
.nav__toggle[aria-expanded="true"] .nav__bar--3{transform:translateY(-6.5px) rotate(-45deg);width:22px}

/* Drawer overlay */
.nav__overlay{position:fixed;inset:0;z-index:1099;background:rgba(10,10,15,.55);backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:opacity .45s var(--ease-out),visibility .45s}
.nav__overlay.is-open{opacity:1;visibility:visible}
.nav__drawer{position:fixed;top:0;right:0;bottom:0;z-index:1100;width:min(380px,100vw);background:#fff;box-shadow:-8px 0 60px rgba(0,0,0,.18);transform:translateX(100%);transition:transform .48s var(--ease-out);display:flex;flex-direction:column;overflow-y:auto;-webkit-overflow-scrolling:touch}
.nav__drawer.is-open{transform:translateX(0)}
.nav__drawer-inner{display:flex;flex-direction:column;min-height:100%;padding:0}
.nav__drawer-header{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}
.nav__drawer-header img{width:36px;height:36px;border-radius:8px}
.nav__drawer-brand{font-family:var(--font-display);font-weight:700;font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;color:var(--brand-red-dk);flex:1}
.nav__drawer-close{width:36px;height:36px;border-radius:10px;border:none;background:var(--surface-3);color:var(--ink-3);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .2s,color .2s}
.nav__drawer-close:hover{background:#fee2e2;color:var(--brand-red)}
.nav__drawer-nav{flex:1;padding:1.5rem 1rem}
.nav__drawer-links{display:flex;flex-direction:column;gap:.25rem}
.nav__drawer-links li{opacity:0;transform:translateX(20px);transition:opacity .4s var(--ease-out),transform .4s var(--ease-out);transition-delay:calc(var(--i)*0.06s + 0.05s)}
.nav__drawer.is-open .nav__drawer-links li{opacity:1;transform:translateX(0)}
.nav__drawer-links a{display:flex;align-items:center;gap:1rem;padding:.9rem 1rem;border-radius:var(--radius-sm);font-family:var(--font-display);font-size:1.05rem;font-weight:600;color:var(--ink);transition:background .2s,color .2s,padding-left .2s;position:relative}
.nav__drawer-links a:hover{background:#fff5f5;color:var(--brand-red);padding-left:1.4rem}
.nav__drawer-num{font-family:var(--font-body);font-size:.65rem;font-weight:600;letter-spacing:.08em;color:var(--muted-lt);min-width:1.8rem}
.nav__drawer-links a:hover .nav__drawer-num{color:rgba(229,57,53,.5)}
.nav__drawer-footer{padding:1.5rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.75rem}
.nav__drawer-cta{width:100%;justify-content:center}
.nav__drawer-address{font-size:.78rem;color:var(--muted);text-align:center;line-height:1.5}

@media(max-width:900px){
  .nav__center{display:none}
  .nav__toggle{display:flex}
  .nav__cta{display:none}
}
@media(max-width:480px){.nav__brand-name{font-size:.68rem;letter-spacing:.1em}}


/* ── Reveal ── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.reveal--delay-1{transition-delay:.1s}
.reveal--delay-2{transition-delay:.2s}
.reveal--delay-3{transition-delay:.3s}
.reveal--delay-4{transition-delay:.4s}
.reveal--delay-5{transition-delay:.5s}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.75rem;border-radius:999px;font-family:var(--font-display);font-weight:600;font-size:.9rem;border:none;cursor:pointer;transition:transform .2s var(--ease-spring),box-shadow .2s,background .2s;white-space:nowrap}
.btn:active{transform:scale(.97)!important}
.btn--solid{background:var(--brand-red);color:#fff;box-shadow:var(--glow-red)}
.btn--solid:hover{transform:translateY(-2px);background:var(--brand-red-dk);box-shadow:0 16px 40px rgba(229,57,53,.45)}
.btn--outline{background:transparent;color:var(--ink);border:1.5px solid var(--border-dk)}
.btn--outline:hover{transform:translateY(-2px);border-color:var(--brand-red);color:var(--brand-red);box-shadow:var(--shadow-md)}
.btn--wa{background:#25d366;color:#fff;box-shadow:0 8px 28px rgba(37,211,102,.4)}
.btn--wa:hover{transform:translateY(-2px);background:#1ebe5d;box-shadow:0 16px 40px rgba(37,211,102,.45)}

/* ── Accent text ── */
.text-accent{background:linear-gradient(135deg,var(--brand-red),#ff6b35);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.text-accent-gold{background:linear-gradient(135deg,var(--brand-gold),#f97316);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}


/* ══════════════════════════════════════════
   HERO
   FIX 1: fills exactly one viewport — marquee sits at bottom of first screen
══════════════════════════════════════════ */
.hero {
  /* Exactly one viewport: nav (68px) + this + marquee (46px) = 100vh */
  min-height: calc(100vh - var(--nav-h) - var(--marquee-h));
  /* Tight padding so all content fits without scrolling */
  padding: calc(var(--nav-h) + .8rem) clamp(.75rem,3vw,2rem) .8rem;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  position: relative; overflow: hidden;
  background: var(--grad-hero);
}
.hero__noise{position:absolute;inset:0;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");background-size:200px;opacity:.35}
.hero__grid-lines{position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(rgba(0,0,0,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.03) 1px,transparent 1px);background-size:48px 48px}
.hero__orbs{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.hero__orb{position:absolute;border-radius:50%;filter:blur(60px)}
.hero__orb--1{width:400px;height:400px;background:rgba(251,191,36,.35);top:-10%;right:-5%;animation:orbFloat 10s ease-in-out infinite}
.hero__orb--2{width:300px;height:300px;background:rgba(229,57,53,.18);bottom:10%;left:-8%;animation:orbFloat 13s ease-in-out infinite reverse}
.hero__orb--3{width:220px;height:220px;background:rgba(22,163,74,.15);top:55%;right:15%;animation:orbFloat 9s ease-in-out infinite 2s}
@keyframes orbFloat{0%,100%{transform:translate(0,0)}33%{transform:translate(20px,-25px)}66%{transform:translate(-15px,15px)}}

.hero__inner{position:relative;z-index:2;width:100%;max-width:var(--content-w);margin:0 auto;display:flex;flex-direction:column;align-items:center;text-align:center;gap:clamp(.45rem,.7vh,.75rem)}

.hero__heading{display:flex;flex-direction:column;gap:.15rem;line-height:1.05}
.hero__heading-top{font-family:var(--font-display);font-weight:500;font-size:clamp(1.2rem,3vw,1.6rem);color:var(--ink-3);letter-spacing:.02em}
.hero__heading-main{font-family:var(--font-display);font-weight:800;font-size:clamp(2.65rem,7.5vw,4.5rem);letter-spacing:-.025em;color:var(--ink);line-height:1}

/* Hero tagline em */
.hero__heading-em{font-style:normal;position:relative;display:inline-block;background:linear-gradient(135deg,var(--brand-red) 0%,#ff6b35 50%,var(--brand-gold) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;clip-path:inset(0 100% 0 0);transition:clip-path 1.1s cubic-bezier(.22,1,.36,1)}
.hero__heading-em.revealed{clip-path:inset(0 0% 0 0)}
.hero__heading-em::after{content:'';position:absolute;inset:0;background:linear-gradient(105deg,transparent 30%,rgba(255,255,255,.55) 50%,transparent 70%);background-size:220% 100%;opacity:0;pointer-events:none;animation:emSweep 2.2s ease 0s infinite;animation-play-state:paused}
.hero__heading-em.revealed::after{animation-play-state:running;animation-delay:1.3s}
@keyframes emSweep{0%{opacity:0;background-position:-50% 0}10%{opacity:1}50%{opacity:1;background-position:150% 0}60%{opacity:0}100%{opacity:0;background-position:150% 0}}
.hero__heading-em::before{content:'';position:absolute;bottom:-4px;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--brand-red),var(--brand-gold));border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform 1s cubic-bezier(.22,1,.36,1) .8s}
.hero__heading-em.revealed::before{transform:scaleX(1)}

.hero__sub{font-size:clamp(.9rem,2vw,1rem);color:var(--muted);max-width:480px;line-height:1.5}
.hero__sub strong{color:var(--ink);font-weight:600}
.hero__actions{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center}

/* ── FIX 3: 20 Years legacy highlight ── */
.hero__legacy {
  display: flex; flex-direction: column; align-items: center; gap: .55rem;
}
.hero__legacy-badge {
  display: inline-flex; align-items: center; gap: .4rem;
  padding: .3rem .85rem; border-radius: 999px;
  background: var(--ink);
  color: var(--brand-gold);
  font-size: .68rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase;
  font-family: var(--font-display);
  box-shadow: 0 4px 18px rgba(0,0,0,.25);
}
.hero__legacy-badge svg { flex-shrink:0; }
.hero__legacy-text {
  font-size: clamp(.95rem,2vw,1.05rem);
  color: var(--ink-3); font-weight: 500; line-height: 1.4;
}
.hero__years-em {
  font-style: normal;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.5em;
  letter-spacing: -.02em;
  background: linear-gradient(135deg, var(--brand-red) 0%, #ff6b35 40%, var(--brand-gold) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  position: relative; display: inline-block;
  /* pulsing glow under the number */
  filter: drop-shadow(0 0 8px rgba(229,57,53,.35));
  animation: yearsGlow 2.8s ease-in-out infinite;
}
@keyframes yearsGlow {
  0%,100% { filter: drop-shadow(0 0 6px rgba(229,57,53,.35)); }
  50%      { filter: drop-shadow(0 0 18px rgba(251,191,36,.65)); }
}

.hero__banner-wrap{position:relative;width:100%;max-width:840px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-xl),0 0 0 1px rgba(255,255,255,.35) inset;border:1px solid rgba(255,255,255,.65);background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.01))}
.hero__banner-wrap::before{content:'';position:absolute;inset:0;border:1px solid rgba(255,255,255,.22);border-radius:inherit;pointer-events:none;box-shadow:0 0 0 1px rgba(255,255,255,.1),0 24px 90px rgba(0,0,0,.08)}
.hero__banner-wrap::after{content:'';position:absolute;inset:-6px;border-radius:calc(var(--radius-lg) + 6px);background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 20%,rgba(251,191,36,.6) 45%,rgba(255,255,255,.35) 55%,transparent 80%);filter:blur(12px);opacity:.85;pointer-events:none;background-size:220% 100%;animation:bannerBorderFlow 3.8s linear infinite}
.hero__banner-glow{position:absolute;inset:-28px;z-index:0;background:radial-gradient(ellipse at center,rgba(251,191,36,.55) 0%,transparent 65%);filter:blur(36px);pointer-events:none}
.hero__banner{position:relative;z-index:1;width:100%;height:auto;display:block;max-height:220px}
@keyframes bannerBorderFlow{0%{background-position:0% 50%}100%{background-position:200% 50%}}

.hero__stats{display:flex;flex-wrap:wrap;justify-content:center;gap:0;background:rgba(255,255,255,.65);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.9);border-radius:var(--radius-xl);padding:.7rem 1rem;box-shadow:var(--shadow-md)}
.hero__stat{display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.35rem 1.1rem}
.hero__stat-num{font-family:var(--font-display);font-weight:800;font-size:clamp(1.2rem,2.1vw,1.35rem);color:var(--ink);letter-spacing:-.02em}
.hero__stat-label{font-size:.68rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.hero__stat-divider{width:1px;background:var(--border-dk);align-self:stretch;margin:.2rem 0}
@media(max-width:600px){.hero__stat{padding:.35rem .85rem}.hero__stat-divider:nth-child(6){display:none}}


/* ══════════════════════════════════════════
   MARQUEE
   FIX 1: sits right at the bottom of the first viewport
══════════════════════════════════════════ */
.marquee-strip{
  height: var(--marquee-h);
  background:var(--ink);
  overflow:hidden;
  display: flex; align-items: center;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
  /* Stick it visually to hero bottom */
  position: relative; z-index: 1;
}
.marquee-track{display:flex;align-items:center;gap:1.5rem;width:max-content;animation:marquee 28s linear infinite}
.marquee-strip:hover .marquee-track{animation-play-state:paused}
.marquee-track span{font-size:.75rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5);white-space:nowrap}
.marquee-dot{color:var(--brand-gold)!important;opacity:1!important}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}


/* ── Section commons ── */
.section{padding:clamp(5rem,10vw,8rem) clamp(1rem,4vw,2.5rem)}
.section__head{text-align:center;max-width:700px;margin:0 auto 4rem}
.section__eyebrow{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--brand-red);margin-bottom:.75rem;position:relative}
.section__eyebrow::before,.section__eyebrow::after{content:'';display:inline-block;width:24px;height:1.5px;background:var(--brand-red);vertical-align:middle;margin:0 .5rem}
.section__title{font-family:var(--font-display);font-weight:800;font-size:clamp(2rem,4.5vw,3rem);letter-spacing:-.025em;color:var(--ink);line-height:1.1;margin-bottom:1rem}
.section__desc{color:var(--muted);font-size:1.05rem;line-height:1.7;max-width:600px;margin:0 auto}


/* ── Services cards (homepage coloured cards) ── */
.services{background:var(--surface)}
.services__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:1.25rem;max-width:var(--content-w);margin:0 auto}
.svc-card{position:relative;padding:2rem 1.75rem;border-radius:var(--radius-lg);color:#fff;overflow:hidden;cursor:default;box-shadow:var(--shadow-md);transition:transform .35s var(--ease-spring),box-shadow .35s;will-change:transform}
.svc-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.18) 0%,rgba(255,255,255,.0) 60%);pointer-events:none}
.svc-card:hover{transform:translateY(-6px) scale(1.015);box-shadow:var(--shadow-xl)}
.svc-card__icon-wrap{width:48px;height:48px;margin-bottom:1.25rem;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.18);border-radius:12px}
.svc-card__icon-wrap svg{width:26px;height:26px;color:#fff}
.svc-card h3{font-family:var(--font-display);font-weight:700;font-size:1.1rem;margin-bottom:.5rem;position:relative;z-index:1}
.svc-card p{font-size:.875rem;line-height:1.55;opacity:.92;position:relative;z-index:1}
.svc-card__shine{position:absolute;inset:0;pointer-events:none;background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.08) 50%,transparent 60%);transform:translateX(-100%);transition:transform .5s}
.svc-card:hover .svc-card__shine{transform:translateX(100%)}
.svc-card--red    {background:linear-gradient(145deg,#e53935,#b71c1c)}
.svc-card--orange {background:linear-gradient(145deg,#fb8c00,#e65100)}
.svc-card--yellow {background:linear-gradient(145deg,#f59e0b,#d97706);color:#1a1200}
.svc-card--yellow h3,.svc-card--yellow p{color:#1a1200}
.svc-card--yellow .svc-card__icon-wrap{background:rgba(0,0,0,.12)}
.svc-card--yellow .svc-card__icon-wrap svg{color:#1a1200}
.svc-card--green  {background:linear-gradient(145deg,#16a34a,#14532d)}
.svc-card--blue   {background:linear-gradient(145deg,#1d4ed8,#1e3a8a)}
.svc-card--teal   {background:linear-gradient(145deg,#0d9488,#134e4a)}
.svc-card--violet {background:linear-gradient(145deg,#7c3aed,#4c1d95)}
.svc-card--coral  {background:linear-gradient(145deg,#ef4444,#7f1d1d)}
.svc-card--purple {background:linear-gradient(145deg,#9333ea,#581c87)}
.svc-card--pink   {background:linear-gradient(145deg,#ec4899,#831843)}
.svc-card--indigo {background:linear-gradient(145deg,#4f46e5,#312e81)}
.svc-card--amber  {background:linear-gradient(145deg,#d97706,#78350f)}


/* ── Why Us ── */
.why{background:var(--surface-2);position:relative;overflow:hidden}
.why__bg-art{position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 60% 50% at 80% 20%,rgba(229,57,53,.05) 0%,transparent 70%),radial-gradient(ellipse 50% 40% at 10% 80%,rgba(29,78,216,.05) 0%,transparent 70%)}
.why .section__head{position:relative;z-index:1}
.why__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem;max-width:var(--content-w);margin:0 auto;position:relative;z-index:1}
.why-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem 1.5rem;text-align:center;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease-spring),box-shadow .3s,border-color .3s}
.why-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:rgba(229,57,53,.2)}
.why-card__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}
.why-card__icon{width:36px;height:36px;color:var(--muted-lt);flex-shrink:0}
.why-card__num{font-family:var(--font-display);font-weight:800;font-size:2.25rem;letter-spacing:-.03em;background:linear-gradient(135deg,var(--brand-red),var(--brand-gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.why-card__num--rupee{font-size:2.75rem;-webkit-text-fill-color:transparent}
.why-card__num--large{font-size:clamp(1.3rem,3vw,1.9rem)}
.why-card h3{font-family:var(--font-display);font-weight:700;font-size:1rem;margin-bottom:.5rem;color:var(--ink)}
.why-card p{font-size:.875rem;color:var(--muted);line-height:1.55}


/* ── Gallery ── */
.gallery{background:var(--surface-3)}
.gallery__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-auto-rows:200px;gap:1rem;max-width:var(--content-w);margin:0 auto}
.gallery__item--wide{grid-column:span 2}
.gallery__item--tall{grid-row:span 2}
.gallery__item{position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer;box-shadow:var(--shadow-sm);transition:box-shadow .3s,transform .3s var(--ease-spring);-webkit-tap-highlight-color:transparent}
.gallery__item:hover{box-shadow:var(--shadow-lg);transform:scale(1.02)}
.gallery__item:focus-visible{outline:2px solid var(--brand-red);outline-offset:3px}
.gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform .55s var(--ease-out),filter .55s}
.gallery__item:hover img{transform:scale(1.08);filter:brightness(1.05)}
.gallery__overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,15,.78) 0%,rgba(10,10,15,.0) 55%);display:flex;align-items:flex-end;padding:1rem 1.1rem;opacity:0;transition:opacity .3s}
.gallery__item:hover .gallery__overlay{opacity:1}
.gallery__overlay span{color:#fff;font-weight:600;font-size:.8rem;letter-spacing:.02em;transform:translateY(6px);transition:transform .35s var(--ease-out)}
.gallery__item:hover .gallery__overlay span{transform:translateY(0)}
@media(max-width:640px){.gallery__grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px;gap:.65rem}.gallery__item--wide{grid-column:span 2}.gallery__item--tall{grid-row:span 1}}
@media(max-width:380px){.gallery__grid{grid-template-columns:1fr;grid-auto-rows:200px}.gallery__item--wide{grid-column:span 1}}


/* ── Process ── */
.process{background:var(--ink);position:relative;overflow:hidden;padding:clamp(5rem,10vw,8rem) clamp(1rem,4vw,2.5rem)}
.process__bg{position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 70% 60% at 50% -10%,rgba(251,191,36,.08) 0%,transparent 70%),radial-gradient(ellipse 60% 50% at 80% 110%,rgba(229,57,53,.06) 0%,transparent 70%)}
.process .section__head{position:relative;z-index:1}
.process .section__eyebrow{color:var(--brand-gold)}
.process .section__eyebrow::before,.process .section__eyebrow::after{background:var(--brand-gold)}
.process__steps{max-width:860px;margin:0 auto;position:relative;z-index:1;display:flex;flex-direction:column;gap:0}
.process__step{display:flex;align-items:flex-start;gap:2rem;position:relative;padding-bottom:2.5rem}
.process__step--last{padding-bottom:0}
.process__step-line{position:absolute;left:34px;top:68px;bottom:0;width:2px;background:linear-gradient(to bottom,rgba(251,191,36,.4),rgba(251,191,36,.0))}
.process__circle{width:68px;height:68px;flex-shrink:0;border-radius:50%;background:rgba(255,255,255,.04);border:1.5px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;transition:transform .3s,background .3s,border-color .3s}
.process__circle span{font-family:var(--font-display);font-weight:700;font-size:.95rem;background:linear-gradient(135deg,var(--brand-gold),#f97316);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.process__step:hover .process__circle{background:rgba(251,191,36,.08);border-color:rgba(251,191,36,.35);transform:scale(1.05)}
.process__content{padding-top:.75rem}
.process__content h3{font-family:var(--font-display);font-weight:700;font-size:1.2rem;color:#fff;margin-bottom:.5rem}
.process__content p{font-size:.9rem;color:rgba(255,255,255,.55);line-height:1.6;max-width:480px}
@media(min-width:700px){
  .process__steps{flex-direction:row;gap:0;align-items:flex-start;justify-content:center}
  .process__step{flex-direction:column;align-items:center;text-align:center;padding-bottom:0;padding-right:1.5rem;flex:1}
  .process__step--last{padding-right:0}
  .process__step-line{left:50%;right:-50%;top:34px;bottom:auto;width:auto;height:2px;background:linear-gradient(to right,rgba(251,191,36,.4),rgba(251,191,36,.0))}
  .process__content p{margin:0 auto}
}


/* ── About ── */
.about{background:var(--surface)}
.about__wrap{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;max-width:var(--content-w);margin:0 auto;align-items:start}
.about__text{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.5rem;box-shadow:var(--shadow-sm)}
.about__text p{font-size:.95rem;line-height:1.75;color:var(--muted);margin-bottom:1rem}
.about__text p:last-of-type{margin-bottom:0}
.about__text strong{color:var(--ink);font-weight:600}
.about__address{display:flex;align-items:flex-start;gap:.75rem;margin-top:1.75rem;padding:1.25rem 1.5rem;background:linear-gradient(135deg,var(--brand-gold-lt),#fff);border:1px solid rgba(251,191,36,.3);border-radius:var(--radius);font-size:.9rem;font-weight:500;color:var(--ink-3);line-height:1.6}
.about__address svg{color:var(--brand-red);margin-top:2px}
.about__actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.5rem}
.about__map{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);min-height:380px;background:var(--surface-3)}
.about__map iframe{width:100%;height:380px;border:0;display:block}
@media(max-width:800px){.about__wrap{grid-template-columns:1fr}}


/* ── Contact ── */
.contact{background:var(--surface-2);position:relative;overflow:hidden}
.contact__bg{position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 60% 50% at 50% 100%,rgba(229,57,53,.05) 0%,transparent 70%)}
.contact__cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem;max-width:860px;margin:0 auto 2.5rem;position:relative;z-index:1}
.contact-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;text-align:center;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease-spring),box-shadow .3s,border-color .3s}
.contact-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:rgba(229,57,53,.2)}
.contact-card__icon-wrap{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,#fee2e2,#fff);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}
.contact-card__icon-wrap svg{width:24px;height:24px;color:var(--brand-red)}
.contact-card h3{font-family:var(--font-display);font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-lt);margin-bottom:.5rem}
.contact-card a{font-weight:600;font-size:.975rem;color:var(--ink);word-break:break-word;transition:color .2s}
.contact-card a:hover{color:var(--brand-red)}
.contact__cta{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;position:relative;z-index:1}


/* ── Footer ── */
.footer{background:var(--ink-2);color:rgba(255,255,255,.85);padding:5rem clamp(1rem,4vw,2.5rem) 2rem}
.footer__inner{max-width:var(--content-w);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1.4fr 1.5fr;gap:3rem;align-items:start}
.footer__logo{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}
.footer__logo img{width:38px;height:38px;object-fit:contain;border-radius:8px}
.footer__logo span{font-family:var(--font-display);font-weight:700;font-size:.9rem;letter-spacing:.1em;text-transform:uppercase;background:linear-gradient(90deg,var(--brand-gold),#f97316);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.footer__tagline{font-size:.875rem;color:rgba(255,255,255,.5);line-height:1.65}
.footer__tagline strong{color:rgba(255,255,255,.75);font-weight:600}
.footer__social{display:flex;gap:.65rem;margin-top:1.5rem}
.footer__social-link{width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;transition:background .2s,border-color .2s,transform .2s}
.footer__social-link:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.18);transform:translateY(-2px)}
.footer__social-link svg{width:18px;height:18px;fill:currentColor;color:rgba(255,255,255,.7)}
.footer__col-title{font-family:var(--font-display);font-weight:700;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:1rem}
.footer__links-col ul,.footer__contact-col ul{display:flex;flex-direction:column;gap:.5rem}
.footer__links-col a,.footer__contact-col a{font-size:.875rem;color:rgba(255,255,255,.6);transition:color .2s}
.footer__links-col a:hover,.footer__contact-col a:hover{color:rgba(255,255,255,.95)}
.footer__bottom{max-width:var(--content-w);margin:4rem auto 0;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.07);text-align:center;font-size:.8rem;color:rgba(255,255,255,.3)}
@media(max-width:900px){.footer__inner{grid-template-columns:1fr 1fr;gap:2rem}}
@media(max-width:560px){.footer__inner{grid-template-columns:1fr}}


/* ── Floating buttons ── */
.float-wa{position:fixed;bottom:1.5rem;right:1.5rem;z-index:999;width:56px;height:56px;border-radius:50%;background:linear-gradient(145deg,#25d366,#128c7e);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 28px rgba(37,211,102,.45);transition:transform .25s var(--ease-spring),box-shadow .25s}
.float-wa:hover{transform:scale(1.1);box-shadow:0 16px 40px rgba(37,211,102,.5)}
.float-wa svg{width:30px;height:30px;fill:currentColor}
.back-top{position:fixed;bottom:5.5rem;right:1.5rem;z-index:998;width:44px;height:44px;border-radius:50%;border:none;background:rgba(10,10,15,.85);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .3s,visibility .3s,transform .3s;box-shadow:var(--shadow-md);backdrop-filter:blur(8px)}
.back-top.visible{opacity:1;visibility:visible;transform:translateY(0)}
.back-top:hover{background:var(--brand-red)}
@media(max-width:480px){.back-top{bottom:5rem}}


/* ── Reduced motion ── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .reveal{opacity:1;transform:none}
  html{scroll-behavior:auto}
}