/* ============================================
   DUOFLEX INVESTMENTS — MAIN STYLESHEET
   ============================================ */
:root {
  --dark:#0a1628; --dark-surface:#0e1e35; --dark-card:#0c1a2e;
  --gold:#d4a843; --gold-light:#e8c36a; --gold-dark:#b08a2e;
  --white:#f5f3ef; --gray:#8a97a8; --text:#c8cdd4; --whatsapp:#25d366;
}
body.light-mode {
  --dark:#f5f3ef; --dark-surface:#e8e4dd; --dark-card:#ece8e1;
  --white:#0a1628; --gray:#4a5568; --text:#2d3748;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--dark);color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased}
::selection{background:var(--gold);color:var(--dark)}
img{max-width:100%;display:block}

/* JUSTIFIED TEXT — no hyphens */
.about-text p, .vm-card p, .value-card p, .service-card p,
.modal-content p, .body-text, .contact-info p,
.safety-points li, .project-info p {
  text-align:justify;
  -webkit-hyphens:none; -moz-hyphens:none; -ms-hyphens:none; hyphens:none;
  word-break:normal; overflow-wrap:normal;
}

/* GRAIN */
.grain{position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:0.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px}

/* NAVBAR */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1.2rem 4%;display:flex;align-items:center;justify-content:space-between;transition:all .4s cubic-bezier(.16,1,.3,1)}
.navbar.scrolled{background:rgba(10,22,40,.95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:.7rem 4%;box-shadow:0 1px 0 rgba(212,168,67,.15)}
.nav-logo{display:flex;align-items:center;gap:.6rem;text-decoration:none}
.nav-logo img{height:34px}
.nav-logo-text{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;letter-spacing:2px;color:var(--white)}
.nav-logo-text span{color:var(--gold)}
.nav-links{display:flex;gap:2rem;list-style:none}
.nav-links a{color:var(--gray);text-decoration:none;font-size:.8rem;font-weight:500;letter-spacing:1.2px;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(--gold);transition:width .3s}
.nav-links a:hover{color:var(--white)}
.nav-links a:hover::after{width:100%}
.nav-right{display:flex;align-items:center;gap:1rem}
.nav-wa{width:38px;height:38px;border:1px solid rgba(37,211,102,.3);display:flex;align-items:center;justify-content:center;color:var(--whatsapp);border-radius:50%;text-decoration:none;transition:all .3s}
.nav-wa:hover{background:rgba(37,211,102,.1);border-color:var(--whatsapp)}
.nav-cta{background:var(--gold);color:var(--dark);border:none;padding:.6rem 1.6rem;font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:.75rem;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;text-decoration:none;transition:all .3s}
.nav-cta:hover{background:var(--gold-light);transform:translateY(-1px)}
.mobile-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px}
.mobile-toggle span{display:block;width:24px;height:2px;background:var(--white);margin:5px 0;transition:all .3s}

/* HERO */
.hero{min-height:100vh;position:relative;display:flex;align-items:flex-end;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;filter:brightness(.3) contrast(1.1)}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,22,40,.4) 0%,rgba(10,22,40,.05) 40%,rgba(10,22,40,.85) 78%,var(--dark) 100%)}
.hero-overlay-stripe{position:absolute;top:0;right:0;width:5px;height:100%;background:var(--gold);z-index:2;opacity:.5}
.hero-content{position:relative;z-index:3;padding:0 6% 8vh;max-width:900px;animation:heroFadeUp 1.2s cubic-bezier(.16,1,.3,1) .3s both}
@keyframes heroFadeUp{from{opacity:0;transform:translateY(60px)}to{opacity:1;transform:translateY(0)}}
.hero-tag{font-size:.72rem;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem;display:flex;align-items:center;gap:1rem}
.hero-tag::before{content:'';width:40px;height:2px;background:var(--gold)}
.hero-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.8rem,7vw,6.2rem);line-height:.95;color:var(--white);margin-bottom:1.2rem;letter-spacing:2px}
.hero-title span{color:var(--gold)}
.hero-sub{font-size:1.05rem;line-height:1.7;max-width:600px;color:var(--gray);margin-bottom:2.5rem;font-weight:300;text-align:justify;hyphens:none}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap}
.btn-primary{background:var(--gold);color:var(--dark);border:none;padding:.9rem 2.2rem;font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:.78rem;letter-spacing:2px;text-transform:uppercase;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:.7rem;transition:all .35s cubic-bezier(.16,1,.3,1)}
.btn-primary:hover{background:var(--gold-light);transform:translateY(-2px);box-shadow:0 10px 30px rgba(212,168,67,.25)}
.btn-primary svg{transition:transform .3s}
.btn-primary:hover svg{transform:translateX(4px)}
.btn-outline{background:transparent;color:var(--white);border:1px solid rgba(255,255,255,.25);padding:.9rem 2.2rem;font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:.78rem;letter-spacing:2px;text-transform:uppercase;cursor:pointer;text-decoration:none;transition:all .35s}
.btn-outline:hover{border-color:var(--gold);color:var(--gold)}

/* STATS */
.stats-bar{background:var(--dark-surface);border-top:1px solid rgba(212,168,67,.15);border-bottom:1px solid rgba(212,168,67,.15);padding:2.8rem 6%;display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
.stat-item{text-align:center}
.stat-num{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.2rem,4vw,3.5rem);color:var(--gold);line-height:1}
.stat-label{font-size:.72rem;text-transform:uppercase;letter-spacing:2px;color:var(--gray);margin-top:.4rem;font-weight:500}

/* SECTIONS */
.section{padding:6rem 6%}
.section-tag{font-size:.7rem;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:.8rem;display:flex;align-items:center;gap:1rem}
.section-tag::before{content:'';width:30px;height:2px;background:var(--gold)}
.section-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(2rem,4.5vw,3.5rem);color:var(--white);line-height:1.05;margin-bottom:1.2rem;letter-spacing:1px}
.section-title span{color:var(--gold)}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center;margin-top:2.5rem}
.about-img-wrap{position:relative;overflow:hidden}
.about-img-wrap img{width:100%;height:480px;object-fit:cover;filter:brightness(.9)}
.about-img-wrap::after{content:'';position:absolute;bottom:0;left:0;width:5px;height:60%;background:var(--gold)}
.about-text p{font-size:.95rem;line-height:1.85;color:var(--text);margin-bottom:1.3rem;font-weight:300}
.about-text p:first-of-type::first-letter{font-family:'Bebas Neue',sans-serif;font-size:3.2rem;float:left;line-height:1;margin-right:.4rem;color:var(--gold)}
.vm-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-top:3.5rem}
.vm-card{padding:3rem;border:1px solid rgba(212,168,67,.1);position:relative;overflow:hidden;transition:all .4s}
.vm-card:hover{border-color:rgba(212,168,67,.3);background:rgba(212,168,67,.03)}
.vm-card::before{content:'';position:absolute;top:0;left:0;width:4px;height:0;background:var(--gold);transition:height .5s cubic-bezier(.16,1,.3,1)}
.vm-card:hover::before{height:100%}
.vm-card h3{font-family:'Bebas Neue',sans-serif;font-size:1.7rem;color:var(--gold);margin-bottom:.8rem;letter-spacing:2px}
.vm-card p{font-size:.9rem;line-height:1.8;font-weight:300}

/* VALUES */
.values{background:var(--dark-surface)}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2.5rem}
.value-card{padding:2.3rem;background:rgba(10,22,40,.6);border:1px solid rgba(212,168,67,.08);transition:all .4s;position:relative}
.value-card:hover{border-color:rgba(212,168,67,.25);transform:translateY(-4px);box-shadow:0 20px 40px rgba(0,0,0,.3)}
.value-icon{width:46px;height:46px;background:rgba(212,168,67,.1);display:flex;align-items:center;justify-content:center;margin-bottom:1.2rem}
.value-icon svg{width:22px;height:22px;color:var(--gold)}
.value-card h3{font-family:'Bebas Neue',sans-serif;font-size:1.4rem;color:var(--white);margin-bottom:.6rem;letter-spacing:2px}
.value-card p{font-size:.85rem;line-height:1.75;font-weight:300;color:var(--gray)}

/* SERVICES */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2.5rem}
.service-card{position:relative;overflow:hidden;height:340px;cursor:pointer}
.service-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.16,1,.3,1),filter .6s;filter:brightness(.45) saturate(.8)}
.service-card:hover img{transform:scale(1.08);filter:brightness(.3) saturate(1)}
.service-card-content{position:absolute;bottom:0;left:0;right:0;padding:2rem;background:linear-gradient(transparent,rgba(10,22,40,.95));z-index:2}
.service-card-tag{display:inline-block;background:var(--gold);color:var(--dark);padding:.25rem .7rem;font-size:.6rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:.6rem}
.service-card h3{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;color:var(--white);letter-spacing:1px;margin-bottom:.4rem}
.service-card p{font-size:.8rem;line-height:1.5;color:var(--gray);font-weight:300}
.card-click-hint{position:absolute;top:1rem;right:1rem;z-index:3;background:rgba(212,168,67,.9);color:var(--dark);padding:.3rem .8rem;font-size:.65rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;opacity:0;transform:translateY(-8px);transition:all .3s;display:flex;align-items:center;gap:.4rem}
.service-card:hover .card-click-hint,.project-card:hover .card-click-hint{opacity:1;transform:translateY(0)}

/* PROJECTS */
.projects{background:var(--dark-surface)}
.projects-scroll{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2.5rem}
.project-card{position:relative;overflow:hidden;height:300px;border:1px solid rgba(212,168,67,.08);transition:all .4s;cursor:pointer}
.project-card:hover{border-color:rgba(212,168,67,.3)}
.project-card img{width:100%;height:100%;object-fit:cover;filter:brightness(.4);transition:all .5s}
.project-card:hover img{filter:brightness(.25);transform:scale(1.05)}
.project-info{position:absolute;bottom:0;left:0;right:0;padding:1.8rem;z-index:2}
.project-year{font-size:.62rem;color:var(--gold);font-weight:700;letter-spacing:3px;text-transform:uppercase;margin-bottom:.3rem}
.project-info h4{font-family:'Bebas Neue',sans-serif;font-size:1.3rem;color:var(--white);letter-spacing:1px}
.project-info p{font-size:.78rem;color:var(--gray);margin-top:.3rem;font-weight:300}

/* VIEW MORE BUTTON */
.expandable-section{display:none;margin-top:0}
.expandable-section.expanded{display:grid}
.view-more-wrap{text-align:center;margin-top:2rem}
.btn-view-more{background:transparent;border:1px solid rgba(212,168,67,.3);color:var(--gold);padding:.85rem 2.5rem;font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:.78rem;letter-spacing:2px;text-transform:uppercase;cursor:pointer;display:inline-flex;align-items:center;gap:.7rem;transition:all .35s}
.btn-view-more:hover{background:rgba(212,168,67,.08);border-color:var(--gold);transform:translateY(-2px)}
.btn-view-more.collapsed .vm-arrow{transform:rotate(180deg)}
.vm-arrow{transition:transform .35s}

/* EQUIPMENT */
.equip-layout{display:grid;grid-template-columns:1fr 1.2fr;gap:3.5rem;align-items:center;margin-top:2.5rem}
.equip-img{position:relative}
.equip-img img{width:100%;object-fit:cover}
.equip-img::before{content:'';position:absolute;top:-12px;left:-12px;width:70px;height:70px;border-top:3px solid var(--gold);border-left:3px solid var(--gold);z-index:2}
.equip-list{list-style:none}
.equip-list li{padding:.8rem 0;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:.8rem;font-size:.9rem;color:var(--text)}
.equip-list li::before{content:'';width:7px;height:7px;background:var(--gold);flex-shrink:0}
.equip-capacity{margin-top:1.5rem;padding:1.3rem 1.8rem;background:rgba(212,168,67,.08);border-left:3px solid var(--gold)}
.equip-capacity strong{font-family:'Bebas Neue',sans-serif;font-size:2rem;color:var(--gold);display:block}
.equip-capacity span{font-size:.82rem;color:var(--gray)}
.body-text{font-size:.95rem;line-height:1.8;color:var(--text);font-weight:300}

/* SAFETY */
.safety{background:var(--dark-surface)}
.safety-layout{display:grid;grid-template-columns:1.2fr 1fr;gap:3.5rem;align-items:center;margin-top:2.5rem}
.safety-img img{width:100%;object-fit:cover}
.safety-points{list-style:none}
.safety-points li{padding:.8rem 0;border-bottom:1px solid rgba(255,255,255,.05);font-size:.85rem;line-height:1.7;font-weight:300;display:flex;gap:.8rem;align-items:flex-start}
.safety-check{flex-shrink:0;width:20px;height:20px;background:rgba(212,168,67,.15);display:flex;align-items:center;justify-content:center;margin-top:2px}
.safety-check svg{width:11px;height:11px;color:var(--gold)}

/* CONTACT */
.contact{border-top:1px solid rgba(212,168,67,.15)}
.contact-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:3.5rem;margin-top:2.5rem}
.contact-info h3{font-family:'Bebas Neue',sans-serif;font-size:2.2rem;color:var(--white);margin-bottom:1.2rem;letter-spacing:1px}
.contact-info p{font-size:.9rem;line-height:1.8;color:var(--gray);margin-bottom:1.5rem;font-weight:300}
.contact-detail{display:flex;align-items:center;gap:.8rem;padding:.7rem 0;font-size:.85rem;color:var(--text)}
.contact-detail svg{color:var(--gold);flex-shrink:0}
.contact-socials{display:flex;gap:.8rem;margin-top:1.5rem}
.contact-socials a{width:40px;height:40px;border:1px solid rgba(212,168,67,.2);display:flex;align-items:center;justify-content:center;color:var(--gray);text-decoration:none;transition:all .3s;font-size:.75rem;font-weight:600}
.contact-socials a:hover{border-color:var(--gold);color:var(--gold);background:rgba(212,168,67,.05)}
.contact-form-wrap{background:rgba(212,168,67,.04);border:1px solid rgba(212,168,67,.12);padding:2.5rem}
.form-heading{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;color:var(--gold);margin-bottom:1.2rem;letter-spacing:2px}
.form-group{margin-bottom:.9rem}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.8rem 1rem;background:rgba(10,22,40,.8);border:1px solid rgba(255,255,255,.1);color:var(--white);font-family:'Plus Jakarta Sans',sans-serif;font-size:.85rem;outline:none;transition:border-color .3s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--gold)}
.form-group select{appearance:none;cursor:pointer}
.form-group select option{background:var(--dark)}
.form-group textarea{resize:vertical;min-height:80px}
.form-actions{display:flex;gap:.8rem;margin-top:.5rem}
.btn-whatsapp{background:var(--whatsapp);color:#fff;border:none;padding:.9rem 1.5rem;font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:.78rem;letter-spacing:1px;text-transform:uppercase;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:.6rem;transition:all .3s}
.btn-whatsapp:hover{background:#20bd5a;transform:translateY(-2px)}

/* FLOATING WHATSAPP */
.whatsapp-float{position:fixed;bottom:2rem;right:2rem;z-index:998;width:56px;height:56px;border-radius:50%;background:var(--whatsapp);color:#fff;display:flex;align-items:center;justify-content:center;text-decoration:none;box-shadow:0 4px 20px rgba(37,211,102,.4);transition:all .3s;animation:waPulse 2s infinite}
.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 6px 30px rgba(37,211,102,.5)}
@keyframes waPulse{0%,100%{box-shadow:0 4px 20px rgba(37,211,102,.4)}50%{box-shadow:0 4px 30px rgba(37,211,102,.6),0 0 0 10px rgba(37,211,102,.1)}}

/* FOOTER */
.footer{padding:1.8rem 6%;border-top:1px solid rgba(255,255,255,.05);display:flex;justify-content:space-between;align-items:center;font-size:.72rem;color:var(--gray)}

/* SCROLL ANIMATIONS */
.reveal{opacity:0;transform:translateY(35px);transition:all .8s cubic-bezier(.16,1,.3,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.rd1{transition-delay:.12s}.rd2{transition-delay:.24s}.rd3{transition-delay:.36s}

/* MODAL */
.modal-overlay{position:fixed;inset:0;z-index:2000;background:rgba(5,12,25,.85);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all .35s}
.modal-overlay.active{opacity:1;visibility:visible}
.modal-container{position:relative;width:92%;max-width:860px;max-height:88vh;overflow-y:auto;background:var(--dark-surface);border:1px solid rgba(212,168,67,.15);box-shadow:0 40px 80px rgba(0,0,0,.5);transform:scale(.92) translateY(30px);transition:transform .4s cubic-bezier(.16,1,.3,1)}
.modal-overlay.active .modal-container{transform:scale(1) translateY(0)}
.modal-container::-webkit-scrollbar{width:6px}
.modal-container::-webkit-scrollbar-track{background:var(--dark)}
.modal-container::-webkit-scrollbar-thumb{background:var(--gold-dark);border-radius:3px}
.modal-close{position:sticky;top:1rem;float:right;z-index:20;margin:1rem 1rem 0 0;width:42px;height:42px;background:rgba(10,22,40,.7);border:1px solid rgba(212,168,67,.5);color:var(--gold);font-size:1.8rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border-radius:0}
.modal-close:hover{background:var(--gold);color:var(--dark)}
.modal-body{padding:0}
.modal-hero{position:relative;height:300px;overflow:hidden;margin-top:-58px}
.modal-hero img{width:100%;height:100%;object-fit:cover;filter:brightness(.4)}
.modal-hero-overlay{position:absolute;bottom:0;left:0;right:0;padding:2.5rem;background:linear-gradient(transparent,rgba(14,30,53,.98))}
.modal-hero-tag{display:inline-block;background:var(--gold);color:var(--dark);padding:.25rem .8rem;font-size:.62rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:.6rem}
.modal-hero h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(1.8rem,3vw,2.6rem);color:var(--white);letter-spacing:1px;line-height:1.05}
.modal-content{padding:2.5rem}
.modal-content p{font-size:.92rem;line-height:1.85;color:var(--text);margin-bottom:1.2rem;font-weight:300}
.modal-content h3{font-family:'Bebas Neue',sans-serif;font-size:1.4rem;color:var(--gold);letter-spacing:2px;margin:2rem 0 .8rem;padding-bottom:.5rem;border-bottom:1px solid rgba(212,168,67,.15)}
.modal-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.8rem;margin:1.5rem 0}
.modal-gallery img{width:100%;height:180px;object-fit:cover;border:1px solid rgba(212,168,67,.1);transition:all .3s}
.modal-gallery img:hover{border-color:var(--gold);transform:scale(1.02)}
.modal-specs{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin:1rem 0}
.modal-spec{padding:1rem 1.2rem;background:rgba(212,168,67,.05);border-left:3px solid var(--gold)}
.modal-spec strong{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--gold);margin-bottom:.3rem}
.modal-spec span{font-size:.88rem;color:var(--text)}
.modal-cta-row{display:flex;gap:.8rem;margin-top:2rem;flex-wrap:wrap}

/* THEME TOGGLE */
.theme-toggle{width:38px;height:38px;border:1px solid rgba(212,168,67,.3);background:transparent;display:flex;align-items:center;justify-content:center;color:var(--gold);border-radius:50%;cursor:pointer;transition:all .3s}
.theme-toggle:hover{background:rgba(212,168,67,.1);border-color:var(--gold)}
.theme-icon-moon{display:none}
body.light-mode .theme-icon-sun{display:none}
body.light-mode .theme-icon-moon{display:block}
body.light-mode .navbar.scrolled{background:rgba(245,243,239,.95)}
body.light-mode .hero-bg img{filter:brightness(.45) contrast(1.1)}
body.light-mode .hero-bg::after{background:linear-gradient(180deg,rgba(245,243,239,.4) 0%,rgba(245,243,239,.05) 40%,rgba(245,243,239,.85) 78%,var(--dark) 100%)}
body.light-mode .nav-links a{color:var(--gray)}
body.light-mode .nav-links a:hover{color:var(--white)}
body.light-mode .mobile-toggle span{background:var(--white)}
body.light-mode .grain{opacity:0.015}
body.light-mode .service-card img{filter:brightness(.6) saturate(.9)}
body.light-mode .service-card:hover img{filter:brightness(.4) saturate(1)}
body.light-mode .project-card img{filter:brightness(.55)}
body.light-mode .project-card:hover img{filter:brightness(.35)}
body.light-mode .modal-overlay{background:rgba(245,243,239,.85)}
body.light-mode .form-group input,body.light-mode .form-group select,body.light-mode .form-group textarea{background:rgba(245,243,239,.8);border:1px solid rgba(0,0,0,.15);color:var(--white)}
body.light-mode .form-group select option{background:var(--dark-surface)}
body.light-mode ::selection{background:var(--gold);color:#fff}

/* RESPONSIVE */
@media(max-width:1024px){.about-grid,.equip-layout,.safety-layout,.contact-grid{grid-template-columns:1fr}.services-grid{grid-template-columns:repeat(2,1fr)}.projects-scroll{grid-template-columns:repeat(2,1fr)}.values-grid,.vm-grid{grid-template-columns:1fr}.stats-bar{grid-template-columns:repeat(2,1fr)}.modal-specs{grid-template-columns:1fr}}
@media(max-width:768px){.nav-links{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(10,22,40,.98);flex-direction:column;align-items:center;justify-content:center;gap:2rem;z-index:999}.nav-links.show{display:flex}.nav-links a{font-size:1.2rem}.nav-right .nav-cta{display:none}.mobile-toggle{display:block;z-index:1001}.hero-content{padding:0 5% 5vh}.section{padding:3.5rem 5%}.stats-bar{padding:2rem 5%}.services-grid,.projects-scroll{grid-template-columns:1fr}.form-actions{flex-direction:column}.modal-container{width:96%;max-height:92vh}.modal-hero{height:220px}.footer{flex-direction:column;gap:.8rem;text-align:center}}
