@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;700;800&family=DM+Sans:wght@300;400;500;600&family=Space+Grotesk:wght@300;500;700&display=swap');

:root {
  --c-bg: #06071A;
  --c-bg2: #0D0E2A;
  --c-primary: #1A1B4B;
  --c-secondary: #3A47AF;
  --c-accent: #00D2FF;
  --c-teal: #4EBABA;
  --c-white: #FFFFFF;
  --c-text: rgba(255,255,255,0.9);
  --c-muted: rgba(255,255,255,0.5);
  --c-border: rgba(255,255,255,0.07);
  --c-light: #F0F2FF;
  --c-light-text: #080920;
  --font-display: 'Syne', sans-serif;
  --font-body: 'DM Sans', sans-serif;
  --font-mono: 'Space Grotesk', sans-serif;
  --ease: cubic-bezier(0.16,1,0.3,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{overflow-x:hidden;scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--c-bg);color:var(--c-text);line-height:1.65;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* ─── CURSOR ─── */
#cursor-dot,#cursor-ring{position:fixed;pointer-events:none;z-index:9999;border-radius:50%;transform:translate(-50%,-50%)}
#cursor-dot{width:6px;height:6px;background:var(--c-accent);transition:transform .1s}
#cursor-ring{width:34px;height:34px;border:1.5px solid rgba(0,210,255,0.5);transition:width .35s var(--ease),height .35s var(--ease),opacity .35s}
body.cursor-grow #cursor-ring{width:56px;height:56px;opacity:.4}

/* ─── TYPOGRAPHY ─── */
h1,h2,h3,h4,h5{font-family:var(--font-display);font-weight:800;line-height:1.05;overflow-wrap:break-word;word-wrap:break-word}
.display{font-size:clamp(4rem,9vw,9.5rem);letter-spacing:-0.03em;text-transform:uppercase;line-height:.93;overflow-wrap:break-word;word-wrap:break-word}
.section-label{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--c-accent);font-weight:500}
.section-title{font-size:clamp(2.2rem,5vw,4rem);line-height:1.05}
.lead{font-size:clamp(1rem,1.8vw,1.25rem);color:var(--c-muted);line-height:1.7}

/* ─── LAYOUT ─── */
.container{width:100%;max-width:1280px;margin:0 auto;padding:0 clamp(20px,5vw,72px)}
.sec{padding:clamp(5rem,10vw,9rem) 0}
.sec-light{background:var(--c-light);color:var(--c-light-text)}
.sec-light h1,.sec-light h2,.sec-light h3,.sec-light h4,.sec-light h5{color:var(--c-light-text)}
.sec-light .section-label{color:var(--c-secondary)}
.sec-light .lead{color:rgba(8,9,32,0.6)}
.sec-mid{background:var(--c-bg2)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}

/* ─── HEADER ─── */
.site-header{position:fixed;top:0;left:0;width:100%;z-index:500;padding:clamp(14px,4vw,45px) 0;transition:padding .4s var(--ease),background .4s var(--ease)}
.site-header.scrolled{padding:10px 0;background:rgba(6,7,26,.95);backdrop-filter:blur(18px);border-bottom:1px solid var(--c-border)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.logo img{height:clamp(44px, 8vw, 155px);width:auto;transition:all .4s var(--ease);filter:drop-shadow(0 0 10px rgba(0,210,255,0.2))}
.site-header.scrolled .logo img{height:clamp(38px, 6vw, 105px)}
.nav-links{display:flex;align-items:center;gap:32px}
.nav-link{font-family:var(--font-mono);font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--c-muted);transition:color .2s;position:relative;padding-bottom:2px}
.nav-link::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--c-accent);transition:width .3s var(--ease)}
.nav-link:hover,.nav-link.active{color:var(--c-white)}
.nav-link:hover::after,.nav-link.active::after{width:100%}

/* hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;padding:4px;z-index:501}
.hamburger span{display:block;width:22px;height:2px;background:var(--c-white);transition:all .3s var(--ease);transform-origin:center}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mobile-nav{display:none;position:fixed;inset:0;background:rgba(6,7,26,.98);backdrop-filter:blur(24px);z-index:400;flex-direction:column;align-items:center;justify-content:center;gap:2.5rem}
.mobile-nav.open{display:flex}
.mobile-nav .nav-link{font-size:1.75rem;letter-spacing:.05em;color:var(--c-white)}
.mobile-nav .btn-cta{margin-top:1rem;font-size:1rem}

/* ─── BUTTONS ─── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;font-family:var(--font-mono);font-size:.85rem;font-weight:600;letter-spacing:.05em;border-radius:100px;transition:all .3s var(--ease);border:1.5px solid transparent;white-space:nowrap}
.btn-cta{background:var(--c-accent);color:var(--c-primary);border-color:var(--c-accent)}
.btn-cta:hover{box-shadow:0 0 32px rgba(0,210,255,.55);transform:translateY(-2px) scale(1.03)}
.btn-outline{border-color:rgba(255,255,255,.25);color:var(--c-white)}
.btn-outline:hover{border-color:var(--c-accent);color:var(--c-accent)}
.btn-dark-outline{border-color:rgba(8,9,32,.3);color:var(--c-light-text)}
.btn-dark-outline:hover{border-color:var(--c-secondary);color:var(--c-secondary)}

/* ─── HERO ─── */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;padding-top:90px;padding-bottom:clamp(3rem,7vw,6rem);position:relative;overflow:hidden}
.hero-orb{position:absolute;border-radius:50%;pointer-events:none;filter:blur(90px)}
.orb1{width:clamp(400px,50vw,750px);height:clamp(400px,50vw,750px);background:radial-gradient(circle,rgba(0,210,255,.12) 0%,transparent 70%);top:-20%;right:-15%;animation:orb 10s ease-in-out infinite alternate}
.orb2{width:clamp(250px,30vw,500px);height:clamp(250px,30vw,500px);background:radial-gradient(circle,rgba(58,71,175,.2) 0%,transparent 70%);bottom:5%;left:-10%;animation:orb 14s ease-in-out infinite alternate-reverse}
@keyframes orb{to{transform:translate(30px,20px) scale(1.08)}}
.hero-tag{margin-bottom:1.5rem}
.hero-display{margin-bottom:1.5rem}
.hero-display .line{overflow:hidden;display:block}
.hero-display .word{display:inline-block}
.hero-content-flex{display:flex;align-items:center;justify-content:space-between;gap:4rem;margin-bottom:2.5rem}
.hero-image{flex:1;max-width:550px;position:relative}
.hero-image img{width:100%;height:auto;border-radius:24px;box-shadow:0 20px 40px rgba(0,0,0,0.4);border:1px solid rgba(255,255,255,0.1)}
.hero-image::after{content:'';position:absolute;inset:0;border-radius:24px;background:linear-gradient(45deg, var(--c-accent), transparent);opacity:0.1;pointer-events:none}
.hero-image::after{content:'';position:absolute;inset:0;border-radius:24px;background:linear-gradient(45deg, var(--c-accent), transparent);opacity:0.1;pointer-events:none}
.hero-scroll{display:flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--c-muted)}
.scroll-bar{width:40px;height:1px;background:var(--c-muted);position:relative;overflow:hidden}
.scroll-bar::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:var(--c-accent);animation:scrollbar 2s ease infinite}
@keyframes scrollbar{to{left:100%}}
.hero-actions{display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap}

/* ─── STATS ─── */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--c-border);border-radius:16px;overflow:hidden}
.stat-item{padding:clamp(1.25rem,3vw,3.5rem) clamp(1rem,2vw,2.5rem);border-right:1px solid var(--c-border);position:relative}
.stat-item:last-child{border-right:none}
.stat-num{font-family:var(--font-display);font-size:clamp(1.6rem,4vw,4.5rem);font-weight:800;color:var(--c-white);line-height:1;margin-bottom:.4rem;white-space:nowrap}
.stat-num span{color:var(--c-accent)}
.stat-label{font-family:var(--font-mono);font-size:clamp(.6rem,.9vw,.78rem);letter-spacing:.08em;text-transform:uppercase;color:var(--c-muted);line-height:1.3}

/* ─── SERVICE ITEMS ─── */
.service-list-items{display:flex;flex-direction:column}
.service-list-item{display:flex;align-items:center;gap:2rem;padding:2rem 0;border-bottom:1px solid var(--c-border);cursor:pointer;transition:all .3s var(--ease);position:relative;overflow:hidden}
.service-list-item:first-child{border-top:1px solid var(--c-border)}
.service-list-item::before{content:'';position:absolute;top:0;left:0;width:0;height:100%;background:rgba(0,210,255,.04);transition:width .4s var(--ease);z-index:0}
.service-list-item:hover::before{width:100%}
.service-list-item>*{position:relative;z-index:1}
.service-num{font-family:var(--font-mono);font-size:.8rem;letter-spacing:.1em;color:var(--c-muted);min-width:40px}
.service-name{font-family:var(--font-display);font-size:clamp(1.3rem,2.5vw,2rem);font-weight:700;flex:1;transition:color .3s}
.service-list-item:hover .service-name{color:var(--c-accent)}
.service-tag{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--c-muted);border:1px solid var(--c-border);padding:5px 12px;border-radius:100px;transition:all .3s}
.service-list-item:hover .service-tag{border-color:var(--c-accent);color:var(--c-accent)}
.service-arrow{color:var(--c-muted);transition:transform .3s var(--ease),color .3s}
.service-list-item:hover .service-arrow{transform:translateX(6px);color:var(--c-accent)}

/* ─── WHY US (Feature Cards) ─── */
.feature-card{padding:2rem;border:1px solid var(--c-border);border-radius:var(--r-lg,16px);transition:all .35s var(--ease);background:var(--c-bg2)}
.feature-card:hover{border-color:rgba(0,210,255,.25);transform:translateY(-6px);background:rgba(0,210,255,.04)}
.feature-icon{width:52px;height:52px;border-radius:12px;background:rgba(0,210,255,.08);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;color:var(--c-accent)}
.feature-title{font-size:1.2rem;margin-bottom:.75rem;color:var(--c-white) !important}
.feature-text{font-size:.9rem;color:var(--c-muted);line-height:1.7}

/* ─── PROCESS ─── */
.process-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:0;position:relative}
.process-steps::before{content:'';position:absolute;top:28px;left:10%;right:10%;height:1px;background:var(--c-border);z-index:0}
.process-step{display:flex;flex-direction:column;align-items:center;text-align:center;padding:0 1rem;position:relative;z-index:1}
.step-num{width:56px;height:56px;border-radius:50%;background:var(--c-bg);border:1px solid var(--c-border);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:.85rem;font-weight:700;color:var(--c-accent);margin-bottom:1.25rem;transition:all .3s var(--ease)}
.process-step:hover .step-num{background:var(--c-accent);color:var(--c-primary);border-color:var(--c-accent);box-shadow:0 0 20px rgba(0,210,255,.4)}
.step-title{font-family:var(--font-display);font-size:.95rem;font-weight:700;margin-bottom:.5rem;color:var(--c-white)}
.step-text{font-size:.8rem;color:var(--c-muted);line-height:1.6}

/* ─── CTA BANNER ─── */
.cta-band{background:linear-gradient(120deg,var(--c-secondary),var(--c-primary) 50%,var(--c-bg) 100%);position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;top:-50%;right:-5%;width:60%;height:200%;background:radial-gradient(circle,rgba(0,210,255,.15) 0%,transparent 60%);pointer-events:none}
.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;padding:clamp(3rem,7vw,5rem) 0}

/* ─── SERVICES PAGE ─── */
.service-detail{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(3rem,6vw,6rem);align-items:center;padding:clamp(4rem,8vw,7rem) 0;border-bottom:1px solid var(--c-border)}
.service-detail:last-child{border-bottom:none}
.service-detail.reverse{direction:rtl}.service-detail.reverse>*{direction:ltr}
.svc-visual{border-radius:20px;overflow:hidden;aspect-ratio:4/3;background:var(--c-bg2);display:flex;align-items:center;justify-content:center;border:1px solid var(--c-border);position:relative}
.svc-visual-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--c-muted);font-family:var(--font-mono);font-size:.8rem;letter-spacing:.1em}
.svc-number{font-family:var(--font-display);font-size:clamp(5rem,10vw,9rem);font-weight:800;color:rgba(0,210,255,.06);line-height:1;margin-bottom:-.5rem}
.svc-checklist{display:flex;flex-direction:column;gap:.85rem;margin:1.5rem 0}
.svc-check{display:flex;align-items:flex-start;gap:.75rem;font-size:.9rem;color:var(--c-muted)}
.svc-check svg{color:var(--c-accent);flex-shrink:0;margin-top:3px}
.price-pill{display:inline-flex;align-items:center;gap:.5rem;padding:8px 18px;background:rgba(0,210,255,.08);border:1px solid rgba(0,210,255,.2);border-radius:100px;color:var(--c-accent);font-family:var(--font-mono);font-size:.85rem;font-weight:600;margin-bottom:1.5rem}

/* ─── SHOWROOM / SLIDER ─── */
.ba-wrap{max-width:860px;margin:0 auto;position:relative}
.ba-container{width:100%;aspect-ratio:16/9;border-radius:20px;overflow:hidden;position:relative;user-select:none;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.ba-panel{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:1.5rem;color:rgba(255,255,255,.3)}
.ba-before{background:linear-gradient(135deg,#2a1a0a,#5a3a1a)}
.ba-after{background:linear-gradient(135deg,var(--c-secondary),var(--c-teal));clip-path:inset(0 50% 0 0)}
.ba-handle{position:absolute;top:0;left:50%;transform:translateX(-50%);height:100%;width:3px;background:var(--c-white);z-index:10;cursor:ew-resize}
.ba-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;background:var(--c-white);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,0,0,.3)}
.ba-label{position:absolute;top:16px;padding:5px 14px;border-radius:100px;background:rgba(0,0,0,.55);backdrop-filter:blur(8px);color:var(--c-white);font-family:var(--font-mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;pointer-events:none;z-index:11}
.ba-label-before{right:16px}.ba-label-after{left:16px}

/* ─── GALLERY GRID ─── */
.gallery-masonry{columns:3;gap:1.25rem}
.gallery-item{break-inside:avoid;margin-bottom:1.25rem;border-radius:14px;overflow:hidden;position:relative;background:var(--c-bg2);border:1px solid var(--c-border)}
.gallery-placeholder{aspect-ratio:1;display:flex;align-items:center;justify-content:center;color:var(--c-muted);font-family:var(--font-mono);font-size:.75rem;letter-spacing:.1em}
.gallery-item:nth-child(even) .gallery-placeholder{aspect-ratio:4/5}
.gallery-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(6,7,26,.9),transparent 50%);opacity:0;transition:opacity .3s;display:flex;align-items:flex-end;padding:1.25rem}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-caption{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.1em;color:var(--c-white);text-transform:uppercase}

/* ─── CONTACT ─── */
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(3rem,5vw,5rem);align-items:start}
.contact-info-item{display:flex;align-items:center;gap:1.25rem;padding:1.5rem;border:1px solid var(--c-border);border-radius:14px;margin-bottom:1rem;transition:all .3s var(--ease)}
.contact-info-item:hover{border-color:rgba(0,210,255,.2);background:rgba(0,210,255,.03)}
.ci-icon{width:46px;height:46px;flex-shrink:0;border-radius:10px;background:rgba(0,210,255,.08);display:flex;align-items:center;justify-content:center;color:var(--c-accent)}
.ci-label{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--c-muted);margin-bottom:4px}
.ci-value{font-size:.95rem;color:var(--c-text);font-weight:500}
.form-card{background:var(--c-bg2);border:1px solid var(--c-border);border-radius:20px;padding:clamp(2rem,4vw,3rem)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.form-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem}
.form-label{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--c-muted)}
.form-control{background:rgba(255,255,255,.04);border:1px solid var(--c-border);border-radius:10px;padding:13px 16px;color:var(--c-white);font-family:var(--font-body);font-size:.95rem;transition:all .25s var(--ease);width:100%}
.form-control::placeholder{color:rgba(255,255,255,.25)}
.form-control:focus{outline:none;border-color:rgba(0,210,255,.4);background:rgba(0,210,255,.03);box-shadow:0 0 0 3px rgba(0,210,255,.08)}
select.form-control option{background:var(--c-bg);color:var(--c-white)}
textarea.form-control{resize:vertical;min-height:110px}
.form-success{display:none;padding:14px;border-radius:10px;background:rgba(78,186,186,.1);border:1px solid rgba(78,186,186,.25);color:var(--c-teal);font-family:var(--font-mono);font-size:.85rem;text-align:center;margin-top:1rem}
.form-success.show{display:block}

/* ─── PAGE HERO (inner pages) ─── */
.page-hero{padding:clamp(8rem,14vw,12rem) 0 clamp(3rem,6vw,5rem);position:relative;overflow:hidden}
.page-hero .hero-orb{top:-30%;right:-10%}

/* ─── FOOTER ─── */
.site-footer{background:var(--c-primary);padding:clamp(4rem,8vw,6rem) 0 2rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:clamp(2rem, 5vw, 4rem);margin-bottom:4rem}
.footer-logo{height:clamp(90px, 15vw, 160px);width:auto;margin-bottom:2.5rem;filter:drop-shadow(0 0 25px rgba(255,255,255,0.15));transition:transform .3s var(--ease)}
.footer-logo:hover{transform:scale(1.02)}
.footer-desc{font-size:.9rem;color:rgba(255,255,255,.55);line-height:1.7;margin-bottom:1.5rem}
.footer-heading{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:1.25rem;font-weight:500}
.footer-links li{margin-bottom:.65rem}
.footer-links a{color:rgba(255,255,255,.6);font-size:.9rem;transition:color .2s}
.footer-links a:hover{color:var(--c-accent)}
.footer-contact-item{display:flex;align-items:center;gap:.65rem;color:rgba(255,255,255,.6);font-size:.875rem;margin-bottom:.75rem}
.social-row{display:flex;gap:.75rem;margin-top:1rem}
.social-btn{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);transition:all .25s}
.social-btn:hover{border-color:var(--c-accent);color:var(--c-accent);transform:translateY(-2px)}
.footer-bottom{padding-top:2rem;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.footer-copy{color:rgba(255,255,255,.35);font-size:.8rem}

/* ─── WA FLOAT ─── */
.wa-float{position:fixed;bottom:28px;right:28px;width:56px;height:56px;background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;z-index:300;box-shadow:0 8px 24px rgba(0,0,0,.3);transition:transform .3s var(--ease),box-shadow .3s}
.wa-float:hover{transform:scale(1.1);box-shadow:0 0 30px rgba(37,211,102,.5)}

/* ─── ANIMATIONS ─── */
.reveal{opacity:1;transform:translateY(0);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-d1{transition-delay:.1s}.reveal-d2{transition-delay:.2s}.reveal-d3{transition-delay:.3s}.reveal-d4{transition-delay:.4s}
.reveal-left{opacity:1;transform:translateX(0);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal-left.in{opacity:1;transform:translateX(0)}
.reveal-right{opacity:1;transform:translateX(0);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal-right.in{opacity:1;transform:translateX(0)}

/* ─── RESPONSIVE ─── */
@media(max-width:1024px){
  .grid4{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat-item{border-bottom:1px solid var(--c-border)}
  .process-steps{grid-template-columns:repeat(3,1fr);gap:2rem}
  .process-steps::before{display:none}
  .service-detail{grid-template-columns:1fr}
  .service-detail.reverse{direction:ltr}
}
@media(max-width:768px){
  .hamburger{display:flex}
  .nav-links{display:none}
  /* Logo mobile: compact so header fits in one row */
  .logo img{height:75px !important}
  .site-header.scrolled .logo img{height:65px !important}
  .site-header{padding:5px 0 !important}
  .site-header.scrolled{padding:2px 0 !important}
  /* Stats: 2 columns on tablet */
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat-item{border-bottom:1px solid var(--c-border);border-right:none}
  .stat-item:nth-child(odd){border-right:1px solid var(--c-border)}
  .grid2,.grid3,.contact-grid{grid-template-columns:1fr}
  .hero{min-height:auto;padding-top:110px;justify-content:flex-start}
  .hero-content-flex{flex-direction:row;align-items:center;gap:1rem;margin-bottom:1.5rem}
  .hero-display{margin-bottom:0}
  .hero-image{flex:1;max-width:40%;order:0}
  .hero-image img{border-radius:12px;box-shadow:0 10px 20px rgba(0,0,0,0.3)}
  .hero-tag{margin-top:0.5rem}
  .hero-scroll{margin-top:2.5rem !important}
  .form-row{grid-template-columns:1fr}
  .gallery-masonry{columns:2}
  .cta-inner{flex-direction:column;text-align:center}
  .footer-grid{grid-template-columns:1fr}
  /* Footer logo: big on mobile since it's stacked */
  .footer-logo{height:clamp(80px,25vw,130px) !important}
  /* Prevent horizontal overflow */
  .display{font-size:clamp(3rem,12vw,9.5rem)}
  section,.hero{overflow-x:hidden}
}
@media(max-width:480px){
  /* Stats: still 2 columns, but numbers smaller */
  .stats-grid{grid-template-columns:1fr 1fr}
  .stat-num{font-size:clamp(1.4rem,8vw,2rem)}
  .stat-label{font-size:.6rem;letter-spacing:.05em}
  .process-steps{grid-template-columns:1fr}
  .gallery-masonry{columns:1}
  /* Hero display title */
  .display{font-size:clamp(2rem,11vw,9.5rem);letter-spacing:-0.02em}
  .section-title{font-size:clamp(1.3rem,7vw,2.5rem);letter-spacing:-0.01em;word-break:break-word}
  /* Buttons side by side */
  .hero-actions{flex-wrap:wrap;gap:.75rem}
  .btn{padding:10px 18px;font-size:.75rem}
}

/* Divider shape */
.wave-divider{display:block;width:100%;overflow:hidden;line-height:0}
.wave-divider svg{display:block;width:100%;height:auto}

/* JS-driven reveal — hidden only after JS initializes */
.js-ready .reveal{opacity:0;transform:translateY(40px)}
.js-ready .reveal.in{opacity:1;transform:translateY(0)}
.js-ready .reveal-left{opacity:0;transform:translateX(-40px)}
.js-ready .reveal-left.in{opacity:1;transform:translateX(0)}
.js-ready .reveal-right{opacity:0;transform:translateX(40px)}
.js-ready .reveal-right.in{opacity:1;transform:translateX(0)}
