/* ============================================================
   AGT INFRAGROUPS — Premium Glassmorphism Stylesheet
   WHITE & GOLD — LIGHT LUXURY THEME
   ============================================================ */
:root{
  --bg0:#ffffff;
  --bg1:#FAF7F0;          /* warm cream */
  --bg2:#F3EEE2;          /* elevated cream */

  --gold:#B8912E;         /* deep gold — readable on white */
  --gold-rich:#C9A227;
  --gold-bright:#D9B452;
  --gold-soft:#EBD9A6;
  --ink:#12161D;          /* charcoal ink */
  --blue:#0A93C2;         /* secondary accents */
  --green:#0E8F5E;

  --glass:rgba(255,255,255,.6);
  --glass-strong:rgba(255,255,255,.78);
  --glass-brd:rgba(184,145,46,.22);   /* gold-tinted edge */
  --glass-shadow:0 22px 55px rgba(80,60,15,.12), inset 0 1px 0 rgba(255,255,255,.75);

  --txt:#14181F;
  --muted:#6e6a5e;        /* warm gray */
  --blur:15px;
  --rad:22px;
  --max:1240px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--bg0);
  color:var(--txt);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
body::before{ /* airy gold ambient field */
  content:"";position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(900px 620px at 12% 6%, rgba(184,145,46,.12), transparent 60%),
    radial-gradient(820px 600px at 90% 16%, rgba(217,180,82,.13), transparent 60%),
    radial-gradient(900px 760px at 50% 102%, rgba(184,145,46,.07), transparent 60%),
    linear-gradient(180deg,#ffffff,#faf7f0 45%,#ffffff);
}
h1,h2,h3,h4{font-family:'Sora',sans-serif;line-height:1.1;font-weight:700;letter-spacing:-.02em;color:#0e1219}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.muted{color:var(--muted)}
.center{text-align:center;display:flex;justify-content:center;gap:14px;flex-wrap:wrap}
section.center{flex-direction:column;align-items:center}

/* ---------- glass primitive ---------- */
.glass{
  background:var(--glass);
  backdrop-filter:blur(var(--blur));
  -webkit-backdrop-filter:blur(var(--blur));
  border:1px solid var(--glass-brd);
  border-radius:var(--rad);
  box-shadow:var(--glass-shadow);
}

/* ---------- gradient text ---------- */
.grad-blue{background:linear-gradient(90deg,#0784ad,var(--blue));-webkit-background-clip:text;background-clip:text;color:transparent}
.grad-green{background:linear-gradient(90deg,#0a7a4f,var(--green));-webkit-background-clip:text;background-clip:text;color:transparent}
.grad-water{background:linear-gradient(90deg,#0a93c2,#0db39a);-webkit-background-clip:text;background-clip:text;color:transparent}
.grad-gold{background:linear-gradient(90deg,#A87C0A,var(--gold-bright));-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.95rem 1.6rem;border-radius:999px;font-weight:700;font-family:'Sora',sans-serif;
  cursor:pointer;border:1px solid transparent;transition:transform .25s, box-shadow .25s, background .25s;
  font-size:.98rem;
}
.btn-primary{background:linear-gradient(120deg,var(--gold),var(--gold-bright));color:#fff;box-shadow:0 12px 30px rgba(184,145,46,.32)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 18px 42px rgba(201,162,39,.42)}
.btn-ghost{background:rgba(255,255,255,.7);border-color:var(--glass-brd);color:var(--ink);backdrop-filter:blur(8px)}
.btn-ghost:hover{transform:translateY(-3px);border-color:var(--gold);box-shadow:0 12px 28px rgba(184,145,46,.2)}
.btn-block{width:100%;justify-content:center;margin-top:.4rem}

.eyebrow{display:inline-block;font-family:'Sora';font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  font-size:.72rem;color:var(--gold);margin-bottom:.8rem}

/* ---------- layout ---------- */
.section{max-width:var(--max);margin:0 auto;padding:6.5rem 1.4rem}
.section-head{text-align:center;max-width:760px;margin:0 auto 3rem}
.section-head h2{font-size:clamp(1.9rem,4.4vw,3rem)}

/* ============================================================
   LOGO ENTRY ANIMATION — white & gold
   ============================================================ */
.loader{position:fixed;inset:0;z-index:9999;
  background:radial-gradient(circle at 50% 42%,#ffffff,#f7f1e3 60%,#efe6d2);
  display:flex;align-items:center;justify-content:center;transition:opacity .8s, visibility .8s;overflow:hidden}
.loader.done{opacity:0;visibility:hidden}
.loader-aura{position:absolute;width:min(680px,92vw);aspect-ratio:1;border-radius:50%;
  background:conic-gradient(from 0deg,rgba(184,145,46,0),rgba(217,180,82,.4),rgba(184,145,46,.3),rgba(235,217,166,.35),rgba(184,145,46,0));
  filter:blur(46px);opacity:.65;animation:auraspin 8s linear infinite}
@keyframes auraspin{to{transform:rotate(360deg)}}
.loader-scene{position:relative;width:min(520px,86vw);text-align:center;z-index:2}
.logo-stage{position:relative;width:200px;height:200px;margin:0 auto 1.6rem}
.ring{position:absolute;inset:0;margin:auto;border-radius:50%;border:1px solid rgba(184,145,46,.5);opacity:0}
.ring-1{width:140px;height:140px;animation:ringPulse 2.6s .2s ease-out infinite}
.ring-2{width:140px;height:140px;animation:ringPulse 2.6s 1s ease-out infinite}
.ring-3{width:140px;height:140px;border-color:rgba(217,180,82,.6);animation:ringPulse 2.6s 1.8s ease-out infinite}
@keyframes ringPulse{0%{opacity:.8;transform:scale(.65)}100%{opacity:0;transform:scale(1.5)}}
.orbit{position:absolute;inset:0;margin:auto;width:178px;height:178px;border-radius:50%;animation:orbit 4.5s linear infinite}
.orbit i{position:absolute;top:-4px;left:50%;width:9px;height:9px;border-radius:50%;background:var(--gold);
  box-shadow:0 0 14px 3px rgba(184,145,46,.8);transform:translateX(-50%)}
@keyframes orbit{to{transform:rotate(360deg)}}
.logo-badge{position:absolute;inset:0;margin:auto;width:130px;height:130px;border-radius:50%;overflow:hidden;background:#fff;
  display:flex;align-items:center;justify-content:center;
  border:2px solid rgba(184,145,46,.9);box-shadow:0 0 0 6px rgba(184,145,46,.10),0 14px 50px rgba(184,145,46,.4);
  transform:scale(.2) rotate(-25deg);opacity:0;animation:badgeIn 1.1s .25s cubic-bezier(.2,.9,.25,1.2) forwards}
.logo-badge img{width:86%;height:auto;object-fit:contain}
@keyframes badgeIn{0%{opacity:0;transform:scale(.2) rotate(-25deg)}60%{opacity:1;transform:scale(1.08) rotate(4deg)}100%{opacity:1;transform:scale(1) rotate(0)}}
.logo-sheen{position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(110deg,transparent,rgba(255,255,255,.85),transparent);
  transform:skewX(-18deg);animation:sheen 2.4s 1.2s ease-in-out infinite}
@keyframes sheen{0%{left:-120%}55%,100%{left:160%}}
.loader-logo{opacity:0;animation:logoIn 1s 1.2s forwards}
@keyframes logoIn{to{opacity:1}}
.loader-word{display:block;font-family:'Sora';font-weight:800;letter-spacing:.32em;font-size:1.5rem;
  background:linear-gradient(120deg,#A87C0A,var(--gold-bright),#8a6a12);-webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 3px 14px rgba(184,145,46,.3))}
.loader-tag{display:block;color:var(--muted);font-size:.84rem;margin-top:.6rem;letter-spacing:.06em}
.loader-bar{position:relative;margin:1.6rem auto 0;width:200px;height:3px;background:rgba(184,145,46,.18);border-radius:3px;overflow:hidden}
.loader-bar span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--gold),var(--gold-bright));animation:bar 3s ease forwards}
@keyframes bar{to{width:100%}}

/* ============================================================
   GLOBAL FX
   ============================================================ */
#cursor-light{position:fixed;width:480px;height:480px;border-radius:50%;pointer-events:none;z-index:1;
  transform:translate(-50%,-50%);left:50%;top:30%;
  background:radial-gradient(circle,rgba(184,145,46,.10),transparent 62%);transition:left .15s ease, top .15s ease}
#particles{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.particle{position:absolute;bottom:-10px;width:6px;height:6px;border-radius:50%;background:rgba(184,145,46,.5);
  box-shadow:0 0 8px rgba(184,145,46,.45);animation:floatUp linear infinite}
@keyframes floatUp{to{transform:translateY(-110vh) translateX(40px);opacity:0}}
#scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:9998;
  background:linear-gradient(90deg,var(--gold),var(--gold-bright),#A87C0A)}

/* ============================================================
   NAVBAR
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:900;display:flex;align-items:center;justify-content:space-between;
  padding:1rem 1.6rem;transition:background .3s, padding .3s, box-shadow .3s}
.nav.scrolled{background:rgba(255,255,255,.8);backdrop-filter:blur(16px);box-shadow:0 8px 30px rgba(80,60,15,.10);padding:.6rem 1.6rem;border-bottom:1px solid var(--glass-brd)}
.brand{display:flex;align-items:center;gap:.6rem;font-family:'Sora';font-weight:700}
.brand img{height:40px;width:auto;object-fit:contain;display:block}
.brand-text{font-size:1.1rem;color:#0e1219}
.brand-text em{font-style:normal;color:var(--gold)}
.nav-links{display:flex;align-items:center;gap:1.5rem}
.nav-links a{font-size:.94rem;font-weight:600;color:#2a2c30;position:relative;transition:color .2s}
.nav-links a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:linear-gradient(90deg,var(--gold),var(--gold-bright));transition:width .25s}
.nav-links a:not(.nav-cta):hover{color:#000}
.nav-links a:not(.nav-cta):hover::after{width:100%}
.nav-cta{padding:.55rem 1.1rem;border-radius:999px;background:linear-gradient(120deg,var(--gold),var(--gold-bright));color:#fff !important;font-weight:700;box-shadow:0 8px 20px rgba(184,145,46,.28)}
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;padding:7px;background:none;border:0;cursor:pointer;border-radius:8px;transition:background .2s}
.nav-toggle:hover{background:rgba(184,145,46,.1)}
.nav-toggle span{display:block;width:22px;height:2px;background:#0e1219;border-radius:2px;transition:transform .3s,opacity .3s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
/* sliding image background */
.hero-slideshow{position:absolute;inset:0;overflow:hidden}
.hero-track{display:flex;height:100%;width:100%;transition:transform 1s cubic-bezier(.65,.02,.25,1)}
.hero-slide{position:relative;flex:0 0 100%;height:100%;overflow:hidden}
.hero-slide-bg{position:absolute;inset:0;background-size:cover;background-position:center;
  transform:scale(1.14);transition:transform 6s ease}
.hero-slide.active .hero-slide-bg{transform:scale(1)}
.hero-slide-label{position:absolute;bottom:7%;left:0;right:0;z-index:2;text-align:center;
  font-family:'Sora';letter-spacing:.22em;text-transform:uppercase;font-size:.74rem;font-weight:700;color:#5a513a;
  opacity:0;transition:opacity .8s .4s}
.hero-slide.active .hero-slide-label{opacity:.95}
.hero-overlay{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(circle at 50% 46%,rgba(255,255,255,.04),rgba(255,255,255,.08))}
/* hero dots */
.hero-dots{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:4;display:flex;gap:.55rem}
.hero-dot{width:11px;height:11px;border-radius:50%;border:1px solid var(--gold);background:transparent;cursor:pointer;transition:.3s;padding:0}
.hero-dot.active{background:var(--gold);box-shadow:0 0 12px rgba(184,145,46,.7);width:30px;border-radius:6px}
.hero-inner{position:relative;z-index:3;max-width:980px;padding:0 1.2rem}
.hero-inner .eyebrow{color:#B8912E;font-size:.85rem;letter-spacing:.28em;text-shadow:0 0 24px rgba(184,145,46,.6);}
.hero-title{font-size:clamp(2.8rem,7vw,5.4rem);font-weight:800;
  background:linear-gradient(135deg,#7a5500 0%,#B8912E 30%,#E8C84A 55%,#fff 70%,#D9A932 85%,#9a6d00 100%);
  background-size:200% 200%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 4px 24px rgba(184,145,46,.35));
  animation:heroTitleShimmer 5s ease-in-out infinite alternate;}
@keyframes heroTitleShimmer{from{background-position:0% 50%;}to{background-position:100% 50%;}}
.hero-sub{margin:1.2rem auto 0;max-width:680px;font-size:clamp(1rem,2.2vw,1.25rem);font-family:'Sora',sans-serif;
  font-weight:700;letter-spacing:.28em;text-transform:uppercase;
  color:#B8912E;
  text-shadow:0 2px 18px rgba(184,145,46,.5),0 0 40px rgba(184,145,46,.2);}
.hero-actions{display:flex;gap:1rem;justify-content:center;margin-top:2.2rem;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:3;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:.5rem}
.hero-scroll span{width:22px;height:36px;border:2px solid rgba(184,145,46,.4);border-radius:12px;position:relative}
.hero-scroll span::after{content:"";position:absolute;top:6px;left:50%;transform:translateX(-50%);width:4px;height:8px;border-radius:2px;background:var(--gold);animation:scrolldot 1.6s infinite}
@keyframes scrolldot{0%{opacity:0;top:6px}50%{opacity:1}100%{opacity:0;top:18px}}

/* ---------- stats band ---------- */
.stats-band{max-width:var(--max);margin:0 auto;padding:1rem 1.4rem 0;display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.stat{padding:1.8rem 1rem;text-align:center}
.stat-num{font-family:'Sora';font-weight:800;font-size:clamp(2rem,4vw,2.8rem);
  background:linear-gradient(120deg,var(--gold),#A87C0A);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat-label{color:var(--muted);font-size:.9rem;margin-top:.3rem}

/* ============================================================
   MARQUEE STRIP (21st.dev-style infinite scroll)
   ============================================================ */
.marquee-section{max-width:var(--max);margin:2.5rem auto 0;padding:0 1.4rem}
.marquee{position:relative;overflow:hidden;padding:1.1rem 0;border-top:1px solid var(--glass-brd);border-bottom:1px solid var(--glass-brd);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee-track{display:flex;align-items:center;gap:1.6rem;width:max-content;animation:marquee 38s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{font-family:'Sora';font-weight:700;font-size:clamp(1rem,2.4vw,1.5rem);white-space:nowrap;color:#3c3a32}
.marquee-dot{color:var(--gold);font-size:.7rem;opacity:.85}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ============================================================
   DASHBOARD SLIDER (horizontal track)
   ============================================================ */
.slider{position:relative;border-radius:26px;overflow:hidden;min-height:520px;
  border:1px solid var(--glass-brd);box-shadow:0 30px 70px rgba(80,60,15,.16)}
.slides-track{display:flex;height:520px;width:100%;
  transition:transform .85s cubic-bezier(.65,.02,.25,1)}
.slide{position:relative;flex:0 0 100%;height:100%;overflow:hidden;display:flex;align-items:center}
.slide-bg{position:absolute;inset:0;background-size:cover;background-position:center;
  transform:scale(1.12);transition:transform 1.1s cubic-bezier(.2,.7,.2,1)}
.slide.active .slide-bg{transform:scale(1)}
.slide-overlay{position:absolute;inset:0;background:linear-gradient(100deg,rgba(255,255,255,.72) 0%,rgba(255,255,255,.52) 38%,rgba(255,255,255,.04) 100%)}
.slide-content{position:relative;z-index:2;max-width:600px;padding:2.5rem clamp(1.6rem,5vw,4rem)}
.slide-content>*{opacity:0;transform:translateX(-38px);transition:opacity .7s, transform .7s}
.slide.active .slide-content>*{opacity:1;transform:none}
.slide.active .slide-content .eyebrow{transition-delay:.25s}
.slide.active .slide-content .slide-title{transition-delay:.38s}
.slide.active .slide-content .slide-text{transition-delay:.5s}
.slide.active .slide-content .btn{transition-delay:.62s}
.slide.active .slide-content .slide-actions{transition-delay:.62s}
.slide-title{font-size:clamp(1.8rem,4.5vw,3.1rem);font-weight:800;margin:.4rem 0 .8rem;color:#0e1219}
.slide-text{color:#3c3a32;font-size:1.05rem;max-width:480px;margin-bottom:1.6rem}

/* --- Slide actions row (btn + play button) --- */
.slide-actions{display:flex;align-items:center;gap:.9rem;flex-wrap:wrap}

/* --- Play button inside slide content --- */
.slide-play-btn{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.65rem 1.3rem;border-radius:999px;border:2px solid rgba(255,0,0,.55);
  background:rgba(255,0,0,.08);color:#cc0000;
  font-family:'Sora',sans-serif;font-weight:700;font-size:.88rem;
  cursor:pointer;transition:all .25s;backdrop-filter:blur(6px);
}
.slide-play-btn:hover{background:#ff0000;border-color:#ff0000;color:#fff;
  box-shadow:0 8px 24px rgba(255,0,0,.35);transform:translateY(-2px);}
.slide-play-icon{
  width:28px;height:28px;border-radius:50%;
  background:#ff0000;display:flex;align-items:center;justify-content:center;
  color:#fff;flex-shrink:0;transition:background .25s;
}
.slide-play-btn:hover .slide-play-icon{background:#fff;}
.slide-play-btn:hover .slide-play-icon svg{color:#ff0000;}

/* --- YouTube badge (corner pulse) --- */
.slide-yt-badge{
  position:absolute;top:1.2rem;right:1.4rem;z-index:6;
  width:56px;height:56px;border-radius:50%;
  background:#ff0000;color:#fff;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  box-shadow:0 6px 24px rgba(255,0,0,.5);
  transition:transform .25s,box-shadow .25s;
  animation:ytPulse 2.4s ease-in-out infinite;
}
.slide-yt-badge:hover{transform:scale(1.12);box-shadow:0 10px 32px rgba(255,0,0,.65);animation:none;}
@keyframes ytPulse{
  0%,100%{box-shadow:0 6px 24px rgba(255,0,0,.5),0 0 0 0 rgba(255,0,0,.4);}
  50%{box-shadow:0 6px 24px rgba(255,0,0,.5),0 0 0 10px rgba(255,0,0,0);}
}

/* --- YouTube Modal --- */
.yt-modal{
  position:fixed;inset:0;z-index:99998;
  display:flex;align-items:center;justify-content:center;
  pointer-events:none;opacity:0;transition:opacity .3s;
}
.yt-modal.yt-open{pointer-events:all;opacity:1;}
.yt-modal-backdrop{
  position:absolute;inset:0;background:rgba(0,0,0,.88);
  backdrop-filter:blur(6px);cursor:pointer;
}
.yt-modal-box{
  position:relative;z-index:2;width:min(900px,92vw);
  background:#000;border-radius:16px;overflow:hidden;
  box-shadow:0 40px 100px rgba(0,0,0,.8),0 0 0 1px rgba(255,255,255,.08);
  transform:scale(.92);transition:transform .3s;
}
.yt-modal.yt-open .yt-modal-box{transform:scale(1);}
.yt-iframe-wrap{position:relative;padding-bottom:56.25%;height:0;}
.yt-iframe-wrap iframe{position:absolute;inset:0;width:100%;height:100%;}
.yt-modal-close{
  position:absolute;top:.7rem;right:.7rem;z-index:10;
  width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.2);
  background:rgba(0,0,0,.6);color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s;
}
.yt-modal-close:hover{background:rgba(220,50,50,.7);}
.slider-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:52px;height:52px;border-radius:50%;
  background:rgba(255,255,255,.7);border:1px solid var(--glass-brd);color:var(--gold);font-size:1.8rem;line-height:1;cursor:pointer;
  backdrop-filter:blur(8px);transition:background .25s, transform .25s;box-shadow:0 8px 22px rgba(80,60,15,.12)}
.slider-arrow:hover{background:linear-gradient(120deg,var(--gold),var(--gold-bright));color:#fff;transform:translateY(-50%) scale(1.08)}
.slider-arrow.prev{left:18px}
.slider-arrow.next{right:18px}
.slider-dots{position:absolute;bottom:22px;right:clamp(1.6rem,5vw,4rem);z-index:5;display:flex;gap:.6rem}
.dot{width:11px;height:11px;border-radius:50%;border:1px solid var(--gold);background:transparent;cursor:pointer;transition:.3s;padding:0}
.dot.active{background:var(--gold);box-shadow:0 0 12px rgba(184,145,46,.7);width:30px;border-radius:6px}
.slider-progress{position:absolute;left:0;bottom:0;height:3px;width:100%;background:rgba(80,60,15,.10);z-index:5}
.slider-progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--gold),var(--gold-bright))}

/* ---------- the three pillars ---------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:1.6rem}
.pillar{overflow:hidden;transition:transform .4s, box-shadow .4s;display:flex;flex-direction:column}
.pillar:hover{transform:translateY(-10px);box-shadow:0 30px 60px rgba(80,60,15,.2)}
.pillar-img{position:relative;height:200px;background-size:cover;background-position:center;transition:transform .5s}
.pillar:hover .pillar-img{transform:scale(1.06)}
.pillar-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(255,255,255,.18))}
.pillar-no{position:absolute;top:.8rem;left:1rem;z-index:2;font-family:'Sora';font-weight:800;font-size:1.4rem;
  color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.5)}
.pillar-body{padding:1.5rem}
.pillar-body h3{font-size:1.25rem;margin-bottom:.5rem}
.pillar-body p{font-size:.92rem;color:var(--muted);margin-bottom:1rem}
.pillar-link{font-family:'Sora';font-weight:700;font-size:.92rem}

/* ---------- masonry / portfolio ---------- */
.masonry{columns:3;column-gap:1.1rem}
.masonry-item{break-inside:avoid;margin-bottom:1.1rem;border-radius:18px;overflow:hidden;position:relative;
  min-height:230px;background-size:cover;background-position:center;cursor:pointer;
  box-shadow:0 16px 40px rgba(80,60,15,.16);transition:transform .4s}
.masonry-item:nth-child(3n){min-height:300px}
.masonry-item:nth-child(4n){min-height:200px}
.masonry-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 42%,rgba(255,255,255,.94));transition:opacity .3s}
.masonry-item:hover{transform:scale(1.02)}
.masonry-item figcaption{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.5rem}
.masonry-item figcaption strong{font-family:'Sora';font-size:1.05rem;color:#0e1219}
.tag{align-self:flex-start;text-transform:uppercase;font-size:.64rem;letter-spacing:.12em;padding:.25rem .6rem;border-radius:999px;font-weight:700}
.tag-sports{background:rgba(14,143,94,.14);color:#0a7a4f;border:1px solid rgba(14,143,94,.4)}
.tag-pools{background:rgba(10,147,194,.14);color:#0784ad;border:1px solid rgba(10,147,194,.4)}
.tag-buildings{background:rgba(184,145,46,.16);color:#9a7209;border:1px solid rgba(184,145,46,.45)}
.center{margin-top:2.4rem}

/* ---------- cost calculator ---------- */
.calc{display:grid;grid-template-columns:1.2fr 1fr;gap:2rem;padding:2.4rem;align-items:center}
.calc-controls{display:flex;flex-direction:column;gap:1.2rem}
.calc-range{-webkit-appearance:none;width:100%;height:6px;border-radius:6px;background:rgba(80,60,15,.14);outline:none}
.calc-range::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:linear-gradient(120deg,var(--gold),var(--gold-bright));cursor:pointer;box-shadow:0 4px 14px rgba(184,145,46,.5)}
.calc-range::-moz-range-thumb{width:22px;height:22px;border:0;border-radius:50%;background:var(--gold);cursor:pointer}
.calc-result{text-align:center;padding:1.6rem;border-left:1px solid var(--glass-brd)}
.calc-amount{font-family:'Sora';font-weight:800;font-size:clamp(1.8rem,4vw,2.6rem);margin:.4rem 0 1.2rem;
  background:linear-gradient(120deg,#A87C0A,var(--gold-bright));-webkit-background-clip:text;background-clip:text;color:transparent}

/* ============================================================
   INSTANT ESTIMATION CALCULATOR (luxury black + gold)
   ============================================================ */
.estimator{position:relative;border-radius:26px;overflow:hidden;padding:2.2rem clamp(1.2rem,3vw,2.6rem) 2.6rem;
  background:linear-gradient(160deg,#0c0d10,#16140d 55%,#0a0b0e);
  border:1px solid rgba(224,184,75,.3);box-shadow:0 34px 80px rgba(0,0,0,.45);color:#f3efe6}
.estimator::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(700px 380px at 12% -10%,rgba(224,184,75,.16),transparent 60%),
             radial-gradient(620px 420px at 100% 110%,rgba(224,184,75,.12),transparent 60%)}
.estimator>*{position:relative;z-index:1}
.est-steps{display:flex;align-items:center;justify-content:center;gap:.6rem;margin-bottom:1.8rem;flex-wrap:wrap}
.est-step{display:inline-flex;align-items:center;gap:.5rem;font-family:'Sora';font-weight:600;font-size:.82rem;color:#8b8576}
.est-step i{width:26px;height:26px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
  font-style:normal;font-size:.8rem;background:rgba(255,255,255,.06);border:1px solid rgba(224,184,75,.3);color:#cdbf94}
.est-step.active{color:#f4d77a}
.est-step.active i{background:linear-gradient(120deg,#E0B84B,#F4D77A);color:#1a1407;border-color:transparent;box-shadow:0 0 16px rgba(224,184,75,.5)}
.est-line{width:34px;height:2px;background:rgba(224,184,75,.25)}

.est-stage.est-anim{animation:estIn .45s cubic-bezier(.2,.7,.2,1)}
@keyframes estIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.est-head{display:flex;align-items:center;gap:1rem;margin-bottom:1.4rem;flex-wrap:wrap}
.est-head h3{font-size:clamp(1.1rem,2.6vw,1.5rem);color:#fff;margin-right:auto}
.est-rate{font-family:'Sora';font-weight:700;color:#1a1407;background:linear-gradient(120deg,#E0B84B,#F4D77A);padding:.3rem .9rem;border-radius:999px;font-size:.84rem}
.est-back{background:rgba(255,255,255,.05);border:1px solid rgba(224,184,75,.3);color:#cdbf94;border-radius:999px;
  padding:.4rem .9rem;cursor:pointer;font-family:'Sora';font-weight:600;font-size:.82rem;transition:.2s}
.est-back:hover{background:rgba(224,184,75,.16);color:#fff}

.est-grid{display:grid;gap:1rem}
.est-grid-2{grid-template-columns:repeat(2,1fr)}
.est-grid-3{grid-template-columns:repeat(3,1fr)}
.est-grid-4{grid-template-columns:repeat(4,1fr)}
.est-card{display:flex;flex-direction:column;align-items:flex-start;gap:.4rem;text-align:left;cursor:pointer;
  padding:1.3rem;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid rgba(224,184,75,.2);
  color:#f3efe6;transition:transform .25s, border-color .25s, box-shadow .25s, background .25s}
.est-card:hover{transform:translateY(-5px);border-color:#E0B84B;background:rgba(224,184,75,.1);box-shadow:0 16px 36px rgba(224,184,75,.18)}
.est-card-ico{font-size:1.8rem;filter:drop-shadow(0 4px 10px rgba(224,184,75,.4))}
.est-card-t{font-family:'Sora';font-weight:700;font-size:1rem}
.est-card-s{font-size:.78rem;color:#9d9783}

.est-dims{display:flex;align-items:flex-end;gap:1rem;flex-wrap:wrap;margin-bottom:.6rem}
.est-dims-col{flex-direction:column;align-items:stretch}
.est-x{font-size:1.6rem;color:#E0B84B;padding-bottom:.5rem;font-family:'Sora'}
.est-field{display:flex;flex-direction:column;gap:.4rem;flex:1;min-width:140px}
.est-field>span{font-size:.82rem;color:#b6b09c;font-weight:500}
.est-input{width:100%;padding:.85rem 1rem;border-radius:12px;background:rgba(255,255,255,.06);
  border:1px solid rgba(224,184,75,.28);color:#fff;font-family:inherit;font-size:1rem;transition:border .2s, box-shadow .2s}
.est-input::placeholder{color:#8b8576}
.est-input:focus{outline:none;border-color:#F4D77A;box-shadow:0 0 0 3px rgba(224,184,75,.18)}
.est-min{font-size:.78rem;color:#9d9783;margin:.4rem 0}
.est-msg{color:#ffb4a0;font-size:.85rem;min-height:1.1rem;margin:.2rem 0}

.est-block{margin:1.1rem 0}
.est-block-l{display:block;font-family:'Sora';font-weight:600;font-size:.85rem;color:#cdbf94;margin-bottom:.6rem}
.est-radios{display:flex;flex-wrap:wrap;gap:.6rem}
.est-radio{display:inline-flex;align-items:center;gap:.45rem;padding:.5rem .9rem;border-radius:999px;cursor:pointer;
  background:rgba(255,255,255,.04);border:1px solid rgba(224,184,75,.25);font-size:.85rem;color:#e8e2d4;transition:.2s}
.est-radio:has(input:checked){background:linear-gradient(120deg,rgba(224,184,75,.9),rgba(244,215,122,.9));color:#1a1407;border-color:transparent}
.est-radio input{accent-color:#1a1407}

.est-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;font-family:'Sora';font-weight:700;
  padding:.95rem 1.6rem;border-radius:999px;border:1px solid transparent;font-size:.95rem;transition:transform .2s, box-shadow .2s, background .2s;margin-top:.6rem}
.est-btn-gold{background:linear-gradient(120deg,#E0B84B,#F4D77A);color:#1a1407;box-shadow:0 12px 30px rgba(224,184,75,.35)}
.est-btn-gold:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(244,215,122,.45)}
.est-btn-line{background:rgba(255,255,255,.05);border-color:rgba(224,184,75,.4);color:#f4d77a}
.est-btn-line:hover{background:rgba(224,184,75,.14)}
.est-btn-wa{background:rgba(37,211,102,.92);color:#06210f}
.est-btn-wa:hover{transform:translateY(-3px)}
.est-btn[disabled]{opacity:.6;cursor:default;transform:none}

/* result card */
.est-result{position:relative;max-width:640px;margin:0 auto;text-align:center;
  background:rgba(255,255,255,.03);border:1px solid rgba(224,184,75,.28);border-radius:20px;padding:2.2rem clamp(1.2rem,3vw,2.4rem)}
.est-result-glow{position:absolute;top:-40%;left:50%;transform:translateX(-50%);width:380px;height:380px;border-radius:50%;
  background:radial-gradient(circle,rgba(224,184,75,.25),transparent 60%);pointer-events:none}
.est-result-k{position:relative;font-family:'Sora';letter-spacing:.18em;text-transform:uppercase;font-size:.74rem;color:#cdbf94}
.est-amount{position:relative;font-family:'Sora';font-weight:800;font-size:clamp(2.2rem,6vw,3.4rem);margin:.5rem 0 1.4rem;
  background:linear-gradient(120deg,#E0B84B,#F4D77A,#fff5d6);-webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 4px 22px rgba(224,184,75,.4))}
.est-summary{text-align:left;border-top:1px solid rgba(224,184,75,.2);border-bottom:1px solid rgba(224,184,75,.2);padding:.4rem 0;margin-bottom:1.2rem}
.est-row{display:flex;justify-content:space-between;padding:.6rem .2rem;border-bottom:1px dashed rgba(224,184,75,.12);font-size:.92rem}
.est-row:last-child{border-bottom:0}
.est-row span{color:#a9a390}
.est-row strong{color:#fff}
.est-row-total{background:rgba(184,145,46,.08);border-radius:8px;padding:.8rem .6rem!important;margin-top:.3rem;border-bottom:0!important}
.est-row-total span{color:#D9B452!important;font-weight:600}
.est-total-val{color:#D9B452!important;font-size:1.1rem}
.est-note{font-size:.82rem;color:#b6b09c;margin-bottom:1rem}
.est-actions{display:flex;gap:.7rem;justify-content:center;flex-wrap:wrap}
.est-disc{font-size:.72rem;color:#8b8576;margin-top:1.2rem;line-height:1.5}
.est-restart{margin-top:1rem;background:none;border:0;color:#cdbf94;cursor:pointer;font-size:.84rem;text-decoration:underline}
.est-lead-title{color:#fff;font-size:1.2rem;margin:.6rem 0 1.2rem}
.est-leadgrid{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin-bottom:.4rem}
.est-check{width:72px;height:72px;border-radius:50%;margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;
  font-size:2rem;color:#1a1407;background:linear-gradient(120deg,#E0B84B,#F4D77A);box-shadow:0 0 36px rgba(224,184,75,.5)}

@media(max-width:760px){
  .est-grid-3,.est-grid-4{grid-template-columns:repeat(2,1fr)}
  .est-leadgrid{grid-template-columns:1fr}
}
@media(max-width:440px){
  .est-grid-2,.est-grid-3,.est-grid-4{grid-template-columns:1fr}
}

/* ---------- testimonials ---------- */
.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.testimonial{padding:2rem;display:flex;flex-direction:column;gap:1rem;transition:transform .4s;background:var(--glass-strong)}
.testimonial:hover{transform:translateY(-8px) rotateX(4deg)}
.stars{color:var(--gold);letter-spacing:.15em}
.testimonial blockquote{font-size:1rem;color:#2a2c30}
.testimonial figcaption{display:flex;flex-direction:column}

/* ---------- forms ---------- */
.form-split{display:grid;grid-template-columns:1fr 1fr;gap:2.4rem;align-items:center;max-width:var(--max);margin:0 auto}
.form-copy h2{font-size:clamp(1.8rem,4vw,2.6rem);margin:.4rem 0 1rem}
.ticks{list-style:none;margin-top:1.2rem;display:flex;flex-direction:column;gap:.7rem}
.ticks li{position:relative;padding-left:1.8rem;color:#3c3a32}
.ticks li::before{content:"✓";position:absolute;left:0;color:var(--gold);font-weight:700}
.form-card{padding:2.2rem;background:#ffffff;border:1px solid rgba(184,145,46,.3);
  border-top:3px solid var(--gold);box-shadow:0 26px 60px rgba(80,60,15,.18)}
.form-title{font-size:1.3rem;margin-bottom:1.2rem;color:#0e1219}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field{display:flex;flex-direction:column;gap:.4rem}
.field-full{grid-column:1/-1}
.field-label{font-size:.82rem;color:var(--muted);font-weight:600}
.glass-input{width:100%;padding:.8rem .9rem;border-radius:12px;background:#fbf9f4;
  border:1px solid rgba(120,100,50,.32);color:var(--txt);font-family:inherit;font-size:.95rem;transition:border .2s, box-shadow .2s}
.glass-input::placeholder{color:#a59f8e}
.glass-input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(184,145,46,.16)}
select.glass-input{appearance:none;cursor:pointer}
select.glass-input option{background:#ffffff;color:#0e1219}
textarea.glass-input{resize:vertical;min-height:90px}
.field-error{color:#c8324a;font-size:.78rem}
.form-errors{color:#c8324a;margin-bottom:.8rem;font-size:.85rem}
.form-note{font-size:.76rem;color:var(--muted);margin-top:.8rem;text-align:center}

/* ============================================================
   PAGE HEROES (sub-pages)
   ============================================================ */
.page-hero{position:relative;min-height:78vh;display:flex;align-items:center;overflow:hidden;
  background-image:var(--bg);background-size:cover;background-position:center;background-attachment:fixed}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(120deg,rgba(255,255,255,.68),rgba(255,255,255,.22))}
.page-hero-inner{position:relative;z-index:3;max-width:780px;padding:7rem 1.6rem 3rem;margin-left:max(1.6rem,calc((100vw - var(--max))/2))}
.page-hero-inner h1{font-size:clamp(2.2rem,6vw,4rem);font-weight:800;color:#0e1219}
.page-hero-inner p{margin-top:1rem;font-size:1.1rem;color:#3c3a32;max-width:560px}
.floodlights{position:absolute;inset:0;z-index:1;overflow:hidden}
.floodlights span{position:absolute;top:-20%;width:30%;height:140%;background:linear-gradient(180deg,rgba(14,143,94,.12),transparent 70%);filter:blur(20px);transform:rotate(8deg)}
.floodlights span:nth-child(1){left:5%}
.floodlights span:nth-child(2){left:32%;background:linear-gradient(180deg,rgba(184,145,46,.14),transparent 70%)}
.floodlights span:nth-child(3){left:60%;background:linear-gradient(180deg,rgba(14,143,94,.12),transparent 70%)}
.floodlights span:nth-child(4){left:82%}
.water-shimmer{position:absolute;inset:0;z-index:1;background:
  repeating-linear-gradient(110deg,rgba(10,147,194,.06) 0 12px,transparent 12px 28px);
  animation:shimmer 8s linear infinite}
@keyframes shimmer{to{background-position:300px 0}}
.blueprint-grid{position:absolute;inset:0;z-index:1;opacity:.4;
  background-image:linear-gradient(rgba(184,145,46,.28) 1px,transparent 1px),linear-gradient(90deg,rgba(184,145,46,.28) 1px,transparent 1px);
  background-size:42px 42px;animation:bpmove 14s linear infinite}
@keyframes bpmove{to{background-position:42px 42px}}

/* ---------- service cards ---------- */
.card-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.3rem}
.svc-card{overflow:hidden;transition:transform .4s, box-shadow .4s;background:var(--glass-strong)}
.svc-card:hover{transform:translateY(-10px)}
.svc-img{height:180px;background-size:cover;background-position:center;transition:transform .5s}
.svc-card:hover .svc-img{transform:scale(1.08)}
.svc-body{padding:1.3rem}
.svc-body h3{font-size:1.15rem;margin-bottom:.4rem}
.svc-body p{font-size:.9rem;color:var(--muted)}
.extra-services{margin-top:1.6rem;padding:1.4rem 1.6rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.extra-services>span{font-family:'Sora';font-weight:700;color:#2a2c30}
.chips{list-style:none;display:flex;flex-wrap:wrap;gap:.4rem;margin:0}
.chips li{font-size:.72rem;padding:.3rem .7rem;border-radius:999px;background:rgba(184,145,46,.08);border:1px solid var(--glass-brd);color:#5a513a}

/* ---------- values / timeline ---------- */
.value-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1.1rem}
.value{padding:1.6rem;text-align:center;transition:transform .4s}
.value:hover{transform:translateY(-8px)}
.value-ico{font-size:1.4rem;color:var(--gold)}
.value h3{font-size:1.05rem;margin:.6rem 0 .4rem}
.value p{font-size:.85rem;color:var(--muted)}
.timeline{list-style:none;max-width:880px;margin:0 auto;position:relative;padding-left:1rem}
.timeline::before{content:"";position:absolute;left:34px;top:10px;bottom:10px;width:2px;background:linear-gradient(180deg,var(--gold),var(--gold-bright),#A87C0A)}
.timeline li{position:relative;padding:0 0 2.2rem 5rem;min-height:60px}
.t-step{position:absolute;left:8px;top:-4px;width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:'Sora';font-weight:800;background:var(--glass-strong);border:1px solid var(--glass-brd);color:var(--gold);backdrop-filter:blur(10px)}
.timeline h3{font-size:1.15rem}
.timeline p{color:var(--muted)}

/* ---------- filter bar + lightbox ---------- */
.filter-bar{display:flex;gap:.7rem;justify-content:center;margin-bottom:2.4rem;flex-wrap:wrap}
.filter{padding:.6rem 1.3rem;border-radius:999px;background:rgba(255,255,255,.7);border:1px solid var(--glass-brd);
  color:#3c3a32;cursor:pointer;font-family:'Sora';font-weight:600;transition:.25s}
.filter.active,.filter:hover{background:linear-gradient(120deg,var(--gold),var(--gold-bright));color:#fff;border-color:transparent}
.masonry-item.hide{display:none}
.lightbox{position:fixed;inset:0;z-index:9990;background:rgba(247,241,227,.9);backdrop-filter:blur(10px);
  display:none;align-items:center;justify-content:center;padding:2rem}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:80vh;border-radius:14px;box-shadow:0 30px 80px rgba(80,60,15,.35)}
.lightbox figcaption{text-align:center;margin-top:1rem;font-family:'Sora';font-size:1.1rem;color:#0e1219}
.lightbox-close{position:absolute;top:1.4rem;right:1.8rem;font-size:2.2rem;background:none;border:0;color:#0e1219;cursor:pointer}

/* ---------- contact ---------- */
.contact-rows{display:flex;flex-direction:column;gap:.8rem;margin:1.2rem 0}
.contact-row{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.3rem;transition:transform .25s}
.contact-row:hover{transform:translateX(6px)}
.contact-row span{color:var(--muted);font-size:.85rem}
.contact-row strong{color:#0e1219}
.map-embed{overflow:hidden;height:240px;margin-top:1rem}
.map-embed iframe{width:100%;height:100%;border:0;filter:grayscale(.15) sepia(.12) contrast(1.02)}

/* ---------- cta band / thanks ---------- */
.cta-band{padding:3rem 2rem;text-align:center;max-width:760px;margin:0 auto}
.cta-band h2{font-size:clamp(1.6rem,4vw,2.4rem);margin-bottom:.6rem}
.thanks-screen{min-height:90vh;display:flex;align-items:center;justify-content:center;padding:6rem 1.4rem}
.thanks-card{padding:3.4rem 2.6rem;text-align:center;max-width:560px;background:var(--glass-strong)}
.thanks-check{width:84px;height:84px;border-radius:50%;margin:0 auto 1.4rem;display:flex;align-items:center;justify-content:center;
  font-size:2.4rem;color:#fff;background:linear-gradient(120deg,var(--gold),var(--gold-bright));box-shadow:0 14px 40px rgba(184,145,46,.4)}
.thanks-card h1{font-size:2.4rem;margin-bottom:.6rem}

/* ---------- toast messages ---------- */
.toast-wrap{position:fixed;top:80px;left:50%;transform:translateX(-50%);z-index:950;display:flex;flex-direction:column;gap:.6rem;width:min(520px,92vw)}
.toast{padding:.9rem 1.2rem;border-radius:12px;backdrop-filter:blur(12px);border:1px solid var(--glass-brd);font-size:.9rem;animation:toastIn .4s;box-shadow:0 12px 30px rgba(80,60,15,.12)}
.toast.success{background:rgba(14,143,94,.12);border-color:rgba(14,143,94,.4);color:#0a6a44}
.toast.error{background:rgba(200,50,74,.12);border-color:rgba(200,50,74,.4);color:#a82740}
@keyframes toastIn{from{opacity:0;transform:translateY(-12px)}to{opacity:1}}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{position:relative;overflow:hidden;margin-top:4rem;backdrop-filter:blur(10px);
  background:linear-gradient(180deg,rgba(250,247,240,.6),rgba(247,241,227,.92))}
/* animated gold shimmer line along the top edge */
.footer-shine{position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),var(--gold-bright),var(--gold),transparent);
  background-size:50% 100%;animation:footerShine 4.5s linear infinite}
@keyframes footerShine{0%{background-position:-120% 0}100%{background-position:220% 0}}
/* giant parallax watermark */
.footer-watermark{position:absolute;left:50%;bottom:-3.2rem;transform:translateX(-50%);z-index:0;
  font-family:'Sora';font-weight:800;font-size:clamp(8rem,26vw,20rem);letter-spacing:-.03em;line-height:1;
  color:transparent;-webkit-text-stroke:2px rgba(184,145,46,.14);pointer-events:none;
  animation:wmFloat 9s ease-in-out infinite}
@keyframes wmFloat{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-14px)}}
/* back-to-top */
.footer-top{position:absolute;top:1.4rem;right:1.6rem;z-index:3;width:46px;height:46px;border-radius:50%;cursor:pointer;
  border:1px solid var(--glass-brd);background:rgba(255,255,255,.7);color:var(--gold);font-size:1.3rem;
  box-shadow:0 8px 22px rgba(80,60,15,.12);transition:transform .25s, box-shadow .25s, background .25s}
.footer-top:hover{transform:translateY(-4px);background:linear-gradient(120deg,var(--gold),var(--gold-bright));color:#fff;box-shadow:0 14px 30px rgba(184,145,46,.4)}
.footer-grid{position:relative;z-index:1;max-width:var(--max);margin:0 auto;padding:3.4rem 1.6rem;display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:2rem}
.brand-footer img{height:36px;width:auto;transition:transform .4s}
.brand-footer:hover img{transform:rotate(-4deg) scale(1.06)}
.footer-tag{color:var(--gold);font-family:'Sora';font-weight:700;margin:.8rem 0 .4rem}
.footer h4{font-size:.95rem;margin-bottom:1rem;color:#0e1219;position:relative;display:inline-block}
.footer h4::after{content:"";position:absolute;left:0;bottom:-5px;height:2px;width:24px;border-radius:2px;
  background:linear-gradient(90deg,var(--gold),var(--gold-bright));transition:width .35s}
.footer-col:hover h4::after{width:100%}
.footer-grid a{display:block;color:var(--muted);margin-bottom:.5rem;font-size:.9rem;transition:color .2s, transform .2s;width:fit-content}
.footer-grid a:hover{color:var(--gold);transform:translateX(5px)}
.footer-social{display:flex;gap:.6rem;margin-top:.6rem;flex-wrap:wrap}
.footer-social a{width:40px;height:40px;display:flex !important;align-items:center;justify-content:center;border-radius:12px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);margin:0 !important;color:rgba(255,255,255,.75);
  transition:transform .25s, background .25s, color .25s, box-shadow .25s}
.footer-social a:hover{transform:translateY(-4px);color:#fff;}
.footer-social-wa:hover{background:#25d366;box-shadow:0 8px 20px rgba(37,211,102,.4);}
.footer-social-ig:hover{background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#bc1888);box-shadow:0 8px 20px rgba(220,39,67,.4);}
.footer-social-yt:hover{background:#ff0000;box-shadow:0 8px 20px rgba(255,0,0,.4);}
.footer-social-fb:hover{background:#1877f2;box-shadow:0 8px 20px rgba(24,119,242,.4);}
.footer-bottom{position:relative;z-index:1;border-top:1px solid var(--glass-brd);max-width:var(--max);margin:0 auto;padding:1.2rem 1.6rem;
  display:flex;justify-content:space-between;font-size:.82rem;color:var(--muted);flex-wrap:wrap;gap:.5rem}

/* ============================================================
   FLOATING ACTION MENU
   ============================================================ */
.fab{position:fixed;right:1.4rem;bottom:1.4rem;z-index:920;display:flex;flex-direction:column;align-items:flex-end;gap:.7rem}
.fab-items{display:flex;flex-direction:column;gap:.6rem;opacity:0;pointer-events:none;transform:translateY(14px) scale(.95);transition:.3s}
.fab.open .fab-items{opacity:1;pointer-events:auto;transform:none}
.fab-item{padding:.65rem 1.1rem;border-radius:999px;font-size:.82rem;font-weight:600;color:#fff;backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.4);box-shadow:0 10px 24px rgba(80,60,15,.2);transition:transform .2s}
.fab-item:hover{transform:translateX(-4px)}
.fab-item.wa{background:rgba(37,211,102,.95)}
.fab-item.call{background:linear-gradient(120deg,var(--gold),var(--gold-bright))}
.fab-item.ig{background:linear-gradient(120deg,#f09433,#e6683c,#dc2743,#bc1888)}
.fab-item.yt{background:rgba(255,0,0,.9)}
.fab-main{width:60px;height:60px;border-radius:50%;border:0;cursor:pointer;color:#fff;font-size:1.8rem;
  background:linear-gradient(120deg,var(--gold),var(--gold-bright));box-shadow:0 12px 30px rgba(184,145,46,.45);transition:transform .3s}
.fab.open .fab-main{transform:rotate(135deg)}
.fab-main::after{content:"";position:absolute;inset:-6px;border-radius:50%;border:2px solid rgba(184,145,46,.5);animation:pulse 2s infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.5);opacity:0}}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   MISSING BUTTON VARIANTS
   ============================================================ */
.btn-gold{background:linear-gradient(120deg,var(--gold),var(--gold-bright));color:#fff;box-shadow:0 12px 30px rgba(184,145,46,.32)}
.btn-gold:hover{transform:translateY(-3px);box-shadow:0 18px 42px rgba(201,162,39,.42)}
.btn-line{background:transparent;border-color:var(--gold);color:var(--gold)}
.btn-line:hover{background:rgba(184,145,46,.08);transform:translateY(-2px)}

/* ============================================================
   MOBILE NAV BACKDROP
   ============================================================ */
.nav-backdrop{
  display:none;position:fixed;inset:0;z-index:899;
  background:rgba(0,0,0,.45);backdrop-filter:blur(2px);
}
.nav-backdrop.open{display:block;}

/* ============================================================
   RESPONSIVE — 1200px (large tablet)
   ============================================================ */
@media(max-width:1200px){
  .footer-grid{grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:1.4rem}
}

/* ============================================================
   RESPONSIVE — 1024px (tablet landscape)
   ============================================================ */
@media(max-width:1024px){
  .testimonials,.card-grid{grid-template-columns:repeat(2,1fr)}
  .value-grid{grid-template-columns:repeat(3,1fr)}
  .masonry{columns:2}
  .stats-band{grid-template-columns:repeat(2,1fr)}
  .pillars{grid-template-columns:repeat(2,1fr)}
  .pillars .pillar:last-child{grid-column:1/-1;max-width:480px;justify-self:center}
  .drw-grid{grid-template-columns:repeat(3,1fr)}
}

/* ============================================================
   RESPONSIVE — 820px (tablet portrait / large phone)
   ============================================================ */
@media(max-width:820px){
  /* --- Nav --- */
  .nav{padding:.8rem 1.2rem}
  .nav-links{
    position:fixed;top:0;right:0;height:100dvh;width:min(300px,82vw);
    flex-direction:column;justify-content:center;align-items:flex-start;
    background:rgba(255,255,255,.98);backdrop-filter:blur(20px);
    transform:translateX(110%);transition:transform .35s cubic-bezier(.4,0,.2,1);
    gap:1.4rem;padding:2.4rem 2rem;
    box-shadow:-20px 0 60px rgba(80,60,15,.18);z-index:900;
  }
  .nav-links.open{transform:none}
  .nav-links a{font-size:1.05rem}
  .nav-cta{margin-top:.6rem;text-align:center;width:100%;justify-content:center}
  .nav-toggle{display:flex;z-index:901}
  /* --- Layout --- */
  .calc,.form-split{grid-template-columns:1fr}
  .calc-result{border-left:0;border-top:1px solid var(--glass-brd);padding-top:1.4rem}
  .form-grid{grid-template-columns:1fr}
  /* --- Page heroes --- */
  .page-hero{min-height:60vh;background-attachment:scroll}
  .page-hero-inner{margin-left:0;padding:6rem 1.4rem 2.4rem}
  .page-hero-inner h1{font-size:clamp(1.9rem,6vw,3rem)}
  /* --- Slider --- */
  .slider{min-height:400px}
  .slides-track{height:400px}
  .slide-content{padding:2rem 1.6rem}
  /* --- Pillars --- */
  .pillars{grid-template-columns:1fr;gap:1rem}
  .pillars .pillar:last-child{grid-column:auto;max-width:100%;justify-self:auto}
  /* --- Cards --- */
  .card-grid{grid-template-columns:repeat(2,1fr)}
  /* --- Value --- */
  .value-grid{grid-template-columns:repeat(2,1fr)}
  /* --- Masonry --- */
  .masonry{columns:2}
  /* --- Footer --- */
  .footer-grid{grid-template-columns:1fr 1fr;gap:1.6rem;padding:2.4rem 1.4rem}
  /* --- Hero dots --- */
  .hero-dots{bottom:52px}
  /* --- Drawings --- */
  .drw-grid{grid-template-columns:repeat(2,1fr)}
  .drw-section-info{flex-direction:column;align-items:flex-start}
}

/* ============================================================
   RESPONSIVE — 640px (medium mobile)
   ============================================================ */
@media(max-width:640px){
  /* --- Sections --- */
  .section{padding:4rem 1rem}
  .section-head{margin-bottom:2rem}
  /* --- Stats --- */
  .stats-band{grid-template-columns:repeat(2,1fr);gap:.8rem;padding:.8rem 1rem 0}
  .stat{padding:1.2rem .8rem}
  /* --- Hero --- */
  .hero-actions{gap:.7rem}
  .hero-actions .btn{padding:.8rem 1.2rem;font-size:.9rem}
  .hero-scroll{display:none}
  /* --- Slider --- */
  .slider{min-height:340px;border-radius:16px}
  .slides-track{height:340px}
  .slider-arrow{width:36px;height:36px;font-size:1.2rem}
  .slider-arrow.prev{left:8px}
  .slider-arrow.next{right:8px}
  /* --- Pillars --- */
  .pillar-img{height:160px}
  /* --- Forms --- */
  .form-card{padding:1.4rem}
  .form-copy h2{font-size:1.6rem}
  /* --- Testimonials --- */
  .testimonials{grid-template-columns:1fr}
  /* --- Cards --- */
  .card-grid{grid-template-columns:1fr}
  /* --- Value --- */
  .value-grid{grid-template-columns:repeat(2,1fr)}
  /* --- Masonry --- */
  .masonry{columns:1}
  /* --- Footer --- */
  .footer-grid{grid-template-columns:1fr;gap:1.4rem}
  .footer-top{top:1rem;right:1rem;width:38px;height:38px;font-size:1rem}
  .footer-watermark{font-size:clamp(5rem,22vw,12rem)}
  /* --- CTA Band --- */
  .cta-band{padding:2rem 1.2rem}
  /* --- Timeline --- */
  .timeline{padding-left:.4rem}
  .timeline li{padding:0 0 1.8rem 4.2rem}
  .t-step{width:44px;height:44px;font-size:.85rem;left:4px}
  /* --- Thank you --- */
  .thanks-card{padding:2.2rem 1.4rem}
  /* --- Drawings --- */
  .drw-grid{grid-template-columns:repeat(2,1fr);gap:.6rem}
  .drw-hero{padding:90px 1rem 40px}
  .drw-downloads{grid-template-columns:1fr}
  .drw-tabs{padding:1.6rem 1rem 0}
  /* --- Estimator --- */
  .est-grid-2,.est-grid-3,.est-grid-4{grid-template-columns:repeat(2,1fr)}
  .est-leadgrid{grid-template-columns:1fr}
  .est-actions{flex-direction:column;align-items:stretch}
  .est-actions .est-btn{width:100%}
}

/* ============================================================
   RESPONSIVE — 480px (small mobile)
   ============================================================ */
@media(max-width:480px){
  /* --- Nav --- */
  .brand-text{font-size:.95rem}
  .brand img{height:34px}
  /* --- Hero --- */
  .hero-inner{padding:0 1rem}
  /* --- Slider --- */
  .slider{min-height:280px}
  .slides-track{height:280px}
  .slide-title{font-size:1.4rem}
  .slide-text{font-size:.88rem}
  .slide-content{padding:1.4rem 1.2rem}
  /* --- Stats --- */
  .stat-num{font-size:1.8rem}
  /* --- Sections --- */
  .section{padding:3.2rem .9rem}
  /* --- Buttons --- */
  .btn{padding:.8rem 1.2rem;font-size:.88rem}
  /* --- Forms --- */
  .form-card{padding:1.2rem}
  /* --- Page hero --- */
  .page-hero{min-height:50vh}
  .page-hero-inner{padding:5.5rem 1rem 2rem}
  /* --- Masonry --- */
  .masonry-item{min-height:160px}
  /* --- Footer --- */
  .footer-grid{padding:2rem 1rem}
  /* --- Est --- */
  .est-grid-2,.est-grid-3,.est-grid-4{grid-template-columns:1fr}
  /* --- Drawings --- */
  .drw-grid{grid-template-columns:1fr}
  .lb-strip{display:none}
  /* --- Loader --- */
  .loader-word{font-size:1.1rem;letter-spacing:.2em}
  .logo-stage{width:160px;height:160px}
  .logo-badge{width:106px;height:106px}
}

/* ============================================================
   RESPONSIVE — 380px (very small phones)
   ============================================================ */
@media(max-width:380px){
  .stats-band{grid-template-columns:repeat(2,1fr)}
  .stat{padding:.9rem .5rem}
  .hero-title{font-size:2.2rem}
  .nav{padding:.6rem .9rem}
  .brand-text{display:none}
  .section{padding:2.8rem .8rem}
  .btn{padding:.7rem 1rem;font-size:.82rem}
  .footer-grid{padding:1.6rem .9rem}
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media(prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important}
  .reveal{opacity:1;transform:none}
  .slide.active{opacity:1}
}
