*{margin:0;padding:0;box-sizing:border-box}
/* Local fonts */
@font-face{font-family:'Montserrat';font-weight:700;font-style:normal;font-display:swap;src:url('../fonts/montserrat-latin-700-normal.woff2') format('woff2')}
@font-face{font-family:'Montserrat';font-weight:800;font-style:normal;font-display:swap;src:url('../fonts/montserrat-latin-800-normal.woff2') format('woff2')}
@font-face{font-family:'DM Sans';font-weight:400;font-style:normal;font-display:swap;src:url('../fonts/dm-sans-latin-400-normal.woff2') format('woff2')}
@font-face{font-family:'DM Sans';font-weight:500;font-style:normal;font-display:swap;src:url('../fonts/dm-sans-latin-500-normal.woff2') format('woff2')}
@font-face{font-family:'DM Sans';font-weight:700;font-style:normal;font-display:swap;src:url('../fonts/dm-sans-latin-700-normal.woff2') format('woff2')}
:root{
  --navy:#0a1628;--dark:#0d1a2d;--darker:#081220;
  --blue:#1a6fb5;--cyan:#00c2d1;--orange:#f0842a;--orange-dark:#d4721f;
  --white:#ffffff;--gray:#8a99af;--gray-light:#b8c5d6;
}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--navy);color:var(--white);overflow-x:hidden;-webkit-font-smoothing:antialiased}

/* ══════ MESH PATTERNS ══════ */
/* Square grid mesh */
.mesh-square{position:relative}
.mesh-square::after{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:
    linear-gradient(rgba(0,194,209,.07) 1px,transparent 1px),
    linear-gradient(90deg,rgba(0,194,209,.07) 1px,transparent 1px);
  background-size:55px 55px;
  -webkit-mask-image:radial-gradient(ellipse 90% 80% at 50% 50%,black 30%,transparent 75%);
  mask-image:radial-gradient(ellipse 90% 80% at 50% 50%,black 30%,transparent 75%);
}

/* Diagonal mesh */
.mesh-diagonal{position:relative}
.mesh-diagonal::after{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:
    repeating-linear-gradient(45deg,transparent,transparent 54px,rgba(0,194,209,.06) 54px,rgba(0,194,209,.06) 55px),
    repeating-linear-gradient(-45deg,transparent,transparent 54px,rgba(0,194,209,.06) 54px,rgba(0,194,209,.06) 55px);
  -webkit-mask-image:radial-gradient(ellipse 90% 80% at 50% 50%,black 30%,transparent 75%);
  mask-image:radial-gradient(ellipse 90% 80% at 50% 50%,black 30%,transparent 75%);
}

/* Glow orbs */
.glow{position:absolute;border-radius:50%;filter:blur(90px);pointer-events:none;z-index:0}
.glow-cyan{background:rgba(0,194,209,.055)}
.glow-orange{background:rgba(240,132,42,.04)}

/* Section separator — clean gradient line */
.sep{height:1px;background:linear-gradient(90deg,transparent 5%,rgba(0,194,209,.1) 30%,rgba(240,132,42,.08) 70%,transparent 95%)}

/* ══════ NAV ══════ */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:.2rem 8rem;display:flex;justify-content:space-between;align-items:center;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);background:rgba(10,22,40,.82);border-bottom:1px solid rgba(255,255,255,.04)}
.nav-logo{height:135px;width:auto;aspect-ratio:540/385}
.nav-links{display:flex;gap:2.4rem;list-style:none}
.nav-links a{color:var(--gray);text-decoration:none;font-size:1rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;transition:color .3s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--cyan);transition:width .3s}
.nav-links a:hover{color:var(--white)}
.nav-links a:hover::after{width:100%}
.nav-cta{background:#b45e12;color:var(--white);padding:.75rem 1.8rem;border-radius:50px;text-decoration:none;font-weight:700;font-size:.95rem;text-transform:uppercase;letter-spacing:.06em;transition:all .3s;border:2px solid var(--orange)}
.nav-cta:hover{background:transparent;color:var(--orange)}
.mobile-toggle{display:none;background:none;border:none;color:var(--white);font-size:1.6rem;cursor:pointer}

/* ══════ HERO — square mesh ══════ */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;padding:10rem 3rem 4rem;overflow:hidden;contain:layout style}
.hero::before{content:'';position:absolute;top:-40%;right:-15%;width:900px;height:900px;background:radial-gradient(circle,rgba(0,194,209,.07),transparent 65%);border-radius:50%;will-change:opacity;animation:drift 12s ease-in-out infinite;transform:translateZ(0)}
.hero::after{content:'';position:absolute;bottom:-35%;left:-8%;width:700px;height:700px;background:radial-gradient(circle,rgba(240,132,42,.05),transparent 65%);border-radius:50%;will-change:opacity;animation:drift 15s ease-in-out infinite reverse;transform:translateZ(0)}
@keyframes drift{0%,100%{opacity:.5}50%{opacity:1}}
.hero-inner{display:flex;align-items:center;justify-content:space-between;max-width:1300px;margin:0 auto;width:100%;gap:4rem}
.hero-content{flex:1;max-width:580px;z-index:2}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.45rem 1.1rem;border-radius:50px;background:rgba(0,194,209,.08);border:1px solid rgba(0,194,209,.2);color:var(--cyan);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;margin-bottom:1.8rem;animation:fadeUp .7s ease-out}
.hero-badge .dot{width:7px;height:7px;background:var(--cyan);border-radius:50%;animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}
.hero h1{font-family:'Montserrat',sans-serif;font-weight:800;font-size:clamp(2.2rem,4.5vw,3.5rem);line-height:1.1;margin-bottom:1.3rem;animation:fadeUp .8s ease-out .1s both}
.hero h1 .grad{background:linear-gradient(135deg,var(--cyan),var(--blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{font-size:1.1rem;font-weight:500;color:var(--gray-light);margin-bottom:.8rem;animation:fadeUp .8s ease-out .15s both}
.hero-desc{font-size:.95rem;color:var(--gray);line-height:1.7;margin-bottom:2.2rem;animation:fadeUp .8s ease-out .2s both}
.hero-buttons{display:flex;gap:1rem;flex-wrap:wrap;animation:fadeUp .8s ease-out .3s both}
.btn-main{background:linear-gradient(135deg,var(--orange),var(--orange-dark));color:var(--white);padding:.95rem 2.2rem;border-radius:50px;text-decoration:none;font-weight:700;font-size:.9rem;transition:all .3s;box-shadow:0 8px 32px rgba(240,132,42,.25);display:inline-flex;align-items:center;gap:.5rem;border:none;cursor:pointer}
.btn-main:hover{transform:translateY(-2px);box-shadow:0 14px 40px rgba(240,132,42,.35)}
.btn-ghost{border:2px solid rgba(255,255,255,.12);color:var(--white);padding:.95rem 2.2rem;border-radius:50px;text-decoration:none;font-weight:500;font-size:.9rem;transition:all .3s;display:inline-flex;align-items:center;gap:.5rem}
.btn-ghost:hover{border-color:var(--cyan);color:var(--cyan)}

/* Bento Grid */
.hero-bento{flex:1;max-width:560px;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:200px 200px;gap:.8rem;position:relative;z-index:1;animation:fadeRight 1s ease-out .4s both}
.hero-bento .bento-main{grid-row:1/3;border-radius:20px;overflow:hidden;position:relative}
.hero-bento .bento-main img,.hero-bento .bento-sm img{width:100%;height:100%;object-fit:cover}
.hero-bento .bento-sm{border-radius:16px;overflow:hidden;position:relative}
.bento-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,22,40,.5),transparent 50%)}
.bento-label{position:absolute;bottom:.8rem;left:.8rem;font-size:.7rem;font-weight:600;color:var(--white);background:rgba(0,0,0,.4);backdrop-filter:blur(8px);padding:.3rem .7rem;border-radius:8px}
.hero-float{position:absolute;z-index:10;background:rgba(13,26,45,.85);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:.7rem 1rem;display:flex;align-items:center;gap:.6rem;animation:float 4s ease-in-out infinite;box-shadow:0 8px 32px rgba(0,0,0,.3)}
.hero-float-1{top:10px;right:-15px}
.hero-float-2{bottom:15px;left:-15px;animation-delay:1.5s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.float-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1rem}
.float-icon.cyan{background:rgba(0,194,209,.15)}
.float-icon.orange{background:rgba(240,132,42,.15)}
.float-num{font-family:'Montserrat',sans-serif;font-weight:800;font-size:1.1rem;line-height:1}
.float-label{font-size:.65rem;color:var(--gray);margin-top:.1rem}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeRight{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}

/* ══════ ABOUT — no mesh, dark bg ══════ */
.about{padding:6rem 3rem;background:var(--dark);position:relative;overflow:hidden}
.about-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;position:relative;z-index:1}
.section-tag{display:inline-block;color:var(--cyan);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;margin-bottom:1rem}
.about-text h2{font-family:'Montserrat',sans-serif;font-weight:800;font-size:clamp(1.8rem,3.5vw,2.6rem);line-height:1.15;margin-bottom:1.5rem}
.about-text p{color:var(--gray);font-size:.95rem;line-height:1.75;margin-bottom:1.2rem}
.about-checks{display:grid;grid-template-columns:1fr 1fr;gap:.8rem 1.5rem;margin-top:1.8rem}
.about-check{display:flex;align-items:center;gap:.6rem;font-size:.9rem;font-weight:500;color:var(--gray-light)}
.about-check .icon{width:24px;height:24px;background:rgba(0,194,209,.12);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--cyan);font-size:.7rem;flex-shrink:0}
.about-image{position:relative}
.about-image img{width:100%;border-radius:20px;object-fit:cover;aspect-ratio:4/5;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.about-image::before{content:'';position:absolute;inset:-2px;border-radius:22px;background:linear-gradient(180deg,var(--cyan),transparent 50%,var(--orange));z-index:-1;opacity:.3}

/* ══════ SERVICES — diagonal mesh ══════ */
.services{padding:6rem 3rem;position:relative;overflow:hidden}
.section-header{text-align:center;margin-bottom:3.5rem;position:relative;z-index:1}
.section-header .section-tag{display:inline-block;color:var(--cyan);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;margin-bottom:1rem}
.section-header h2{font-family:'Montserrat',sans-serif;font-weight:800;font-size:clamp(1.8rem,3.5vw,2.6rem);line-height:1.15}
.section-header p{color:var(--gray);font-size:.95rem;line-height:1.6;max-width:600px;margin:.8rem auto 0}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;max-width:1100px;margin:0 auto;position:relative;z-index:1}
.svc{background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.05);border-radius:18px;padding:2rem 1.6rem;transition:all .4s;position:relative;overflow:hidden}
.svc::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--cyan),var(--orange));opacity:0;transition:opacity .4s}
.svc:hover{background:rgba(255,255,255,.05);transform:translateY(-3px);border-color:rgba(0,194,209,.15)}
.svc:hover::before{opacity:1}
.svc-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:14px;background:rgba(0,194,209,.08);margin-bottom:1.2rem;font-size:1.3rem}
.svc h3{font-family:'Montserrat',sans-serif;font-size:1.05rem;margin-bottom:.5rem;font-weight:700}
.svc p{color:var(--gray);font-size:.85rem;line-height:1.55}
.services-note{text-align:center;margin-top:2.5rem;color:var(--gray-light);font-size:1rem;font-weight:500;position:relative;z-index:1}

/* ══════ GALLERY — no mesh, dark bg ══════ */
.gallery{padding:6rem 3rem;background:var(--dark);position:relative;overflow:hidden}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;max-width:1200px;margin:0 auto;position:relative;z-index:1}
.gal{position:relative;overflow:hidden;border-radius:16px;cursor:pointer;aspect-ratio:1}
.gal.w2{grid-column:span 2;aspect-ratio:2/1}
.gal img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.gal:hover img{transform:scale(1.07)}
.gal-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,22,40,.85) 0%,rgba(10,22,40,.15) 50%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:1.2rem;opacity:0;transition:opacity .4s}
.gal:hover .gal-ov{opacity:1}
.gal-ov span{font-size:.85rem;font-weight:600}
.gal-ov small{font-size:.72rem;color:var(--cyan);margin-top:.2rem}
.gallery-bottom{max-width:700px;margin:3rem auto 0;text-align:center;position:relative;z-index:1}
.gallery-bottom h3{font-family:'Montserrat',sans-serif;font-size:1.4rem;margin-bottom:.6rem}
.gallery-bottom p{color:var(--gray);font-size:.92rem;line-height:1.6;margin-bottom:1.5rem}

/* ══════ BEFORE & AFTER — square mesh ══════ */
.ba{padding:6rem 3rem;position:relative;overflow:hidden}
.ba-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;max-width:1100px;margin:0 auto;position:relative;z-index:1}
.ba-card{border-radius:20px;overflow:hidden;background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.05);transition:transform .3s}
.ba-card:hover{transform:translateY(-4px)}
.ba-images{display:grid;grid-template-columns:1fr 1fr;position:relative}
.ba-images img{width:100%;height:200px;object-fit:cover}
.ba-tag{position:absolute;top:.6rem;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;padding:.25rem .6rem;border-radius:6px;z-index:2}
.ba-tag.before{left:.6rem;background:rgba(220,50,50,.8);color:var(--white)}
.ba-tag.after{right:.6rem;background:rgba(0,194,209,.8);color:var(--white)}
.ba-divider{position:absolute;top:0;bottom:0;left:50%;width:3px;background:var(--orange);z-index:2;transform:translateX(-50%)}
.ba-divider::after{content:'VS';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.55rem;font-weight:800;background:var(--orange);color:var(--white);padding:.2rem .4rem;border-radius:6px;letter-spacing:.05em}
.ba-info{padding:1.2rem 1.4rem}
.ba-info h4{font-family:'Montserrat',sans-serif;font-size:.95rem;font-weight:700;margin-bottom:.3rem}
.ba-info p{color:var(--gray);font-size:.8rem;line-height:1.5}

/* ══════ WHY — no mesh, dark bg ══════ */
.why{padding:6rem 3rem;background:var(--dark);position:relative;overflow:hidden}
.why-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;position:relative;z-index:1}
.why-list{display:flex;flex-direction:column;gap:1.2rem}
.why-item{display:flex;align-items:flex-start;gap:1rem;padding:1.3rem 1.5rem;border-radius:16px;background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.04);transition:all .3s}
.why-item:hover{background:rgba(255,255,255,.05);border-color:rgba(0,194,209,.12)}
.why-icon{width:44px;height:44px;background:rgba(0,194,209,.1);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.why-item h4{font-family:'Montserrat',sans-serif;font-size:.95rem;font-weight:700;margin-bottom:.3rem}
.why-item p{color:var(--gray);font-size:.82rem;line-height:1.5}
.why-text h2{font-family:'Montserrat',sans-serif;font-weight:800;font-size:clamp(1.8rem,3.5vw,2.6rem);line-height:1.15;margin-bottom:1rem}
.why-text > p{color:var(--gray);font-size:.95rem;line-height:1.7}

/* ══════ SERVICE AREA — diagonal mesh ══════ */
.area{padding:4rem 3rem;text-align:center;position:relative;overflow:hidden}
.area-inner{max-width:700px;margin:0 auto;position:relative;z-index:1}
.area h2{font-family:'Montserrat',sans-serif;font-weight:800;font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:.8rem}
.area p{color:var(--gray);font-size:.95rem;line-height:1.7}
.area-badge{display:inline-flex;align-items:center;gap:.6rem;margin-top:1.5rem;padding:.6rem 1.4rem;border-radius:50px;background:rgba(0,194,209,.08);border:1px solid rgba(0,194,209,.15);color:var(--cyan);font-size:.85rem;font-weight:600}

/* ══════ CONTACT — no mesh, dark bg ══════ */
.contact{padding:6rem 3rem;background:var(--dark);position:relative;overflow:hidden}
.contact-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;position:relative;z-index:1}
.contact-info h2{font-family:'Montserrat',sans-serif;font-weight:800;font-size:clamp(1.8rem,3.5vw,2.5rem);margin-bottom:.8rem}
.contact-info > p{color:var(--gray);font-size:.95rem;line-height:1.7;margin-bottom:2rem}
.contact-detail{display:flex;align-items:center;gap:1rem;margin-bottom:1.2rem}
.contact-detail-icon{width:44px;height:44px;border-radius:12px;background:rgba(0,194,209,.1);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.contact-detail-text{display:flex;flex-direction:column}
.contact-detail-text strong{font-size:.85rem;font-weight:700;margin-bottom:.1rem}
.contact-detail-text span{color:var(--gray);font-size:.82rem}
.contact-detail-text a{color:var(--cyan);text-decoration:none;font-size:.9rem;font-weight:600;transition:color .3s}
.contact-detail-text a:hover{color:var(--orange)}
.contact-form{background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.06);border-radius:24px;padding:2.5rem;position:relative;overflow:hidden}
.contact-form::before{content:'';position:absolute;top:-80px;right:-80px;width:200px;height:200px;background:radial-gradient(circle,rgba(0,194,209,.06),transparent);border-radius:50%}
.contact-form h3{font-family:'Montserrat',sans-serif;font-size:1.2rem;font-weight:700;margin-bottom:.4rem;position:relative}
.contact-form > p{color:var(--gray);font-size:.85rem;margin-bottom:1.8rem;position:relative}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
.form-group{display:flex;flex-direction:column;gap:.4rem}
.form-group label{font-size:.78rem;font-weight:600;color:var(--gray-light);text-transform:uppercase;letter-spacing:.06em}
.form-group input,.form-group select,.form-group textarea{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:.85rem 1rem;color:var(--white);font-family:'DM Sans',sans-serif;font-size:.9rem;transition:all .3s;outline:none;width:100%}
.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(255,255,255,.25)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--cyan);background:rgba(0,194,209,.04);box-shadow:0 0 0 3px rgba(0,194,209,.08)}
.form-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238a99af' fill='none' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}
.form-group select option{background:var(--dark);color:var(--white)}
.form-group textarea{resize:vertical;min-height:110px}
.form-submit{margin-top:1.2rem}
.form-submit .btn-main{width:100%;justify-content:center;padding:1rem;font-size:.95rem}

/* ══════ FOOTER ══════ */
footer{padding:0;background:var(--darker)}
.footer-top{padding:4rem 3rem 3rem;display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:3rem;max-width:1200px;margin:0 auto}
.footer-brand-col img{height:70px;width:auto;aspect-ratio:540/385;margin-bottom:1.2rem}
.footer-brand-col p{color:var(--gray);font-size:.88rem;line-height:1.7;margin-bottom:1.5rem;max-width:300px}
.footer-social{display:flex;gap:.8rem}
.footer-social a{width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;color:var(--gray);text-decoration:none;transition:all .3s;font-size:.95rem}
.footer-social a:hover{background:rgba(0,194,209,.1);border-color:var(--cyan);color:var(--cyan)}
.footer-col h4{font-family:'Montserrat',sans-serif;font-size:.9rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:1.3rem;color:var(--white);position:relative;padding-bottom:.8rem}
.footer-col h4::after{content:'';position:absolute;bottom:0;left:0;width:30px;height:2px;background:var(--cyan)}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:.7rem}
.footer-col ul li a{color:var(--gray);text-decoration:none;font-size:.85rem;transition:all .3s;display:inline-flex;align-items:center;gap:.4rem}
.footer-col ul li a:hover{color:var(--cyan);transform:translateX(3px)}
.footer-contact-item{display:flex;align-items:flex-start;gap:.8rem;margin-bottom:1rem}
.footer-contact-icon{width:36px;height:36px;border-radius:10px;background:rgba(0,194,209,.08);display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0;margin-top:.1rem}
.footer-contact-text{display:flex;flex-direction:column}
.footer-contact-text strong{font-size:.8rem;font-weight:700;color:var(--white);margin-bottom:.15rem}
.footer-contact-text span,.footer-contact-text a{color:var(--gray);font-size:.82rem;text-decoration:none;transition:color .3s}
.footer-contact-text a:hover{color:var(--cyan)}
.footer-mid{padding:1.5rem 3rem;max-width:1200px;margin:0 auto;border-top:1px solid rgba(255,255,255,.04);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-badges{display:flex;gap:.8rem;flex-wrap:wrap}
.footer-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .9rem;border-radius:8px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);color:var(--gray);font-size:.75rem;font-weight:500}
.footer-badge-icon{font-size:.85rem}
.footer-cta-text{color:var(--gray-light);font-size:.88rem;font-weight:500}
.footer-cta-text a{color:var(--cyan);text-decoration:none;font-weight:700;transition:color .3s}
.footer-cta-text a:hover{color:var(--orange)}
.footer-bottom{padding:1.2rem 3rem;border-top:1px solid rgba(255,255,255,.03);text-align:center}
.footer-bottom p{color:var(--gray);font-size:.72rem;letter-spacing:.03em}

/* ══════ MOBILE ══════ */
@media(max-width:960px){
  nav{padding:.2rem 1.5rem}
  .nav-links,.nav-cta{display:none}
  .mobile-toggle{display:block}
  .hero{padding:9rem 1.5rem 3rem}
  .hero-inner{flex-direction:column;text-align:center;gap:2.5rem}
  .hero-content{max-width:100%}
  .hero-buttons{justify-content:center}
  .hero-bento{max-width:100%;width:100%;grid-template-rows:180px 180px}
  .hero-float-1{right:5px;top:5px}
  .hero-float-2{left:5px;bottom:5px}
  .about-inner{grid-template-columns:1fr;gap:2.5rem}
  .about-image{order:-1;max-width:400px;margin:0 auto}
  .about-checks{grid-template-columns:1fr}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .services,.gallery,.ba,.why,.area,.contact{padding:4rem 1.5rem}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .gal.w2{grid-column:span 2}
  .ba-grid{grid-template-columns:1fr}
  .why-inner{grid-template-columns:1fr}
  .contact-inner{grid-template-columns:1fr;gap:2.5rem}
  .form-row{grid-template-columns:1fr}
  .footer-inner{flex-direction:column;text-align:center;align-items:center}
  .footer-top{grid-template-columns:1fr 1fr;gap:2rem;padding:3rem 1.5rem 2rem}
  .footer-mid{padding:1.2rem 1.5rem;flex-direction:column;text-align:center}
  .footer-bottom{padding:1rem 1.5rem}
}
@media(max-width:560px){
  .services-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .gal.w2{grid-column:span 1;aspect-ratio:1}
  .contact-form{padding:1.8rem 1.2rem}
  .about-checks{grid-template-columns:1fr}
  .hero-bento{grid-template-rows:160px 160px}
}

::-webkit-scrollbar{width:7px}
::-webkit-scrollbar-track{background:var(--navy)}
::-webkit-scrollbar-thumb{background:var(--blue);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--cyan)}
/* ══════ SCROLL REVEAL ══════ */
.reveal{opacity:0;transform:translateY(25px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ══════ NAV SCROLL STATE ══════ */
nav.scrolled{padding-top:.1rem;padding-bottom:.1rem;background:rgba(10,22,40,.95);box-shadow:0 4px 20px rgba(0,0,0,.3)}
nav.scrolled .nav-logo{height:80px;transition:height .3s}

/* ══════ MOBILE MENU OPEN ══════ */
@media(max-width:960px){
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:rgba(10,22,40,.98);flex-direction:column;padding:1.5rem;gap:.5rem;border-top:1px solid rgba(255,255,255,.05)}
  .nav-links.open{display:flex}
  .nav-links li{list-style:none}
  .nav-links a{display:block;padding:.8rem 1rem;border-radius:8px}
  .nav-links a:hover{background:rgba(255,255,255,.05)}
  .nav-cta{display:none}
}
