@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@400;600;700;800;900&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;1,400&display=swap');

:root {
  --bg-main:      #0B1520;
  --bg-secondary: #111E2B;
  --bg-card:      #162435;
  --bg-accent:    #F0F4F8;
  --text-light:   #EFF4FA;
  --text-gray:    #8FA8C0;
  --text-muted:   #5C7A92;
  --cta:          #F05A00;
  --cta-dark:     #C94C00;
  --cta-glow:     rgba(240,90,0,0.22);
  --safety-yellow: #FFD000;
  --safety-yellow-dim: rgba(255,208,0,0.12);
  --green-accent: #00C97A;
  --border-dim:   rgba(255,255,255,0.07);
  --border-cta:   rgba(240,90,0,0.28);
  --border-light: rgba(255,255,255,0.12);
  --shadow-hard:  0 16px 50px rgba(0,0,0,0.45);
  --shadow-soft:  0 4px 24px rgba(0,0,0,0.18);
  --shadow-cta:   0 8px 28px rgba(240,90,0,0.35);
  --radius:       6px;
  --radius-lg:    12px;
  --font-heading: 'Barlow Condensed', sans-serif;
  --font-body:    'DM Sans', sans-serif;
  --nav-h:        70px;
  --transition:   all 0.28s cubic-bezier(0.4,0,0.2,1);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);background:var(--bg-accent);color:#1E2D3D;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
ul{list-style:none}
h1,h2,h3,h4,h5{font-family:var(--font-heading);font-weight:800;letter-spacing:.5px;line-height:1.1;text-transform:uppercase}

.container{max-width:1280px;margin:0 auto;padding:0 clamp(1rem,4vw,3rem)}
.section{padding:clamp(4rem,8vw,6rem) 0}
.section-accent{background:#F0F4F8}
.section-darker{background:var(--bg-main)}
.section-dark{background:var(--bg-secondary)}
.centered{text-align:center}
.two-column{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}

.section-label{display:flex;align-items:center;gap:.7rem;font-size:.72rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--cta);margin-bottom:.9rem}
.section-label::before{content:'';width:28px;height:2px;background:var(--cta);flex-shrink:0}
.section-title{font-size:clamp(1.9rem,3.5vw,2.9rem);color:#1A2A3A;margin-bottom:1rem}
.section-sub{color:#4A5568;font-size:clamp(.9rem,1.8vw,1.05rem);max-width:580px;line-height:1.75}

/* NAVBAR */
header{position:fixed;width:100%;top:0;z-index:1000;background:rgba(11,21,32,.97);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1.5px solid rgba(240,90,0,.4);transition:var(--transition),box-shadow .3s}
header.scrolled{box-shadow:0 4px 30px rgba(0,0,0,.5);border-bottom-color:rgba(240,90,0,.6)}
nav.navbar{display:flex;justify-content:space-between;align-items:center;padding:0 clamp(1rem,3vw,3rem);height:var(--nav-h);max-width:1440px;margin:0 auto}
.logo img{height:44px;object-fit:contain}
.nav-links{display:flex;gap:0;align-items:center}
.nav-links li a{color:var(--text-gray);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:1.3px;padding:.5rem 1rem;position:relative;transition:color .2s;white-space:nowrap}
.nav-links li a::after{content:'';position:absolute;width:0;height:2px;background:var(--cta);bottom:-2px;left:50%;transform:translateX(-50%);transition:width .25s ease}
.nav-links li a:hover,.nav-links li a.active{color:#fff}
.nav-links li a:hover::after,.nav-links li a.active::after{width:60%}
.nav-cta-link a{background:var(--cta)!important;color:#fff!important;padding:.45rem 1.2rem!important;border-radius:3px;letter-spacing:1px;transition:background .2s,box-shadow .2s!important;box-shadow:0 4px 14px rgba(240,90,0,.3)}
.nav-cta-link a:hover{background:var(--cta-dark)!important;box-shadow:var(--shadow-cta)!important}
.nav-cta-link a::after{display:none!important}

.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;z-index:1100;border-radius:4px;transition:background .2s}
.hamburger:hover{background:rgba(255,255,255,.07)}
.hamburger span{display:block;height:2px;width:24px;background:var(--text-light);border-radius:2px;transition:all .3s ease}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.sidebar{position:fixed;top:0;right:-100%;width:min(85vw,320px);height:100vh;background:var(--bg-main);border-left:2px solid var(--cta);box-shadow:-10px 0 40px rgba(0,0,0,.6);display:flex;flex-direction:column;padding-top:calc(var(--nav-h) + .5rem);transition:right .38s cubic-bezier(.4,0,.2,1);z-index:1050}
.sidebar.active{right:0}
.sidebar ul li a{color:var(--text-gray);display:flex;align-items:center;gap:.7rem;padding:1rem 1.8rem;font-family:var(--font-heading);font-size:1.1rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid var(--border-dim);transition:var(--transition)}
.sidebar ul li a:hover,.sidebar ul li a.active{background:rgba(240,90,0,.1);color:var(--cta);padding-left:2.2rem;border-left:3px solid var(--cta)}
.sidebar-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:1040;opacity:0;pointer-events:none;transition:opacity .3s;backdrop-filter:blur(2px)}
.sidebar-overlay.active{opacity:1;pointer-events:all}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:.55rem;padding:.75rem 2rem;font-family:var(--font-heading);font-size:.95rem;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;cursor:pointer;border:none;border-radius:var(--radius);transition:var(--transition);position:relative;overflow:hidden;white-space:nowrap}
.btn::before{content:'';position:absolute;inset:0;background:rgba(255,255,255,.08);transform:translateX(-101%);transition:transform .35s ease}
.btn:hover::before{transform:translateX(0)}
.btn-primary{background:var(--cta);color:#fff;box-shadow:0 4px 16px rgba(240,90,0,.28)}
.btn-primary:hover{background:var(--cta-dark);box-shadow:var(--shadow-cta);transform:translateY(-1px)}
.btn-outline{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.3)}
.btn-outline:hover{border-color:var(--cta);color:var(--cta);background:rgba(240,90,0,.07);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--cta);border:1.5px solid var(--cta)}
.btn-ghost:hover{background:var(--cta);color:#fff;box-shadow:var(--shadow-cta)}
.btn-sm{padding:.5rem 1.2rem;font-size:.82rem}
.btn-lg{padding:.9rem 2.5rem;font-size:1.05rem}

/* HERO */
.video-hero{position:relative;height:100vh;min-height:600px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;background:var(--bg-main)}
.hero-bg-video{position:absolute;top:50%;left:50%;min-width:100%;min-height:100%;width:auto;height:auto;transform:translateX(-50%) translateY(-50%);object-fit:cover;opacity:.42;z-index:0}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(11,21,32,.95) 0%,rgba(11,21,32,.7) 55%,rgba(240,90,0,.06) 100%);z-index:1}
.hero-overlay::after{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:60px 60px;pointer-events:none}
.hero-content{position:relative;z-index:2;max-width:860px;padding:0 1.5rem;animation:fadeInUp .9s ease both}
@keyframes fadeInUp{from{opacity:0;transform:translateY(36px)}to{opacity:1;transform:translateY(0)}}
.hero-eyebrow{font-size:.73rem;font-weight:600;letter-spacing:3.5px;text-transform:uppercase;color:var(--cta);margin-bottom:1.2rem;display:flex;align-items:center;justify-content:center;gap:.8rem}
.hero-eyebrow::before,.hero-eyebrow::after{content:'';width:36px;height:1.5px;background:var(--cta)}
.hero-title{font-size:clamp(3rem,8vw,6rem);color:#fff;font-weight:900;margin-bottom:1.2rem;text-shadow:0 4px 24px rgba(0,0,0,.45);line-height:.95}
.hero-title span{color:var(--safety-yellow)}
.hero-sub{color:var(--text-gray);font-size:clamp(.95rem,2vw,1.2rem);font-weight:400;margin:0 auto 2.8rem;max-width:540px;line-height:1.75}
.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.hero-badges{display:flex;justify-content:center;gap:2rem;margin-top:3rem;flex-wrap:wrap}
.hero-badge{display:flex;align-items:center;gap:.5rem;color:rgba(255,255,255,.55);font-size:.78rem;letter-spacing:.5px}
.hero-badge i{color:var(--safety-yellow);font-size:1rem}
.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);z-index:2;color:var(--text-muted);font-size:.7rem;letter-spacing:2.5px;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:.5rem;animation:scrollBounce 2.5s infinite}
.hero-scroll i{font-size:1.1rem;color:var(--cta)}
@keyframes scrollBounce{0%,100%{transform:translateX(-50%) translateY(0);opacity:.8}50%{transform:translateX(-50%) translateY(10px);opacity:1}}

/* TICKER */
.ticker-strip{background:var(--cta);overflow:hidden;padding:.65rem 0;position:relative;z-index:2}
.ticker-inner{display:flex;gap:0;white-space:nowrap;animation:ticker 28s linear infinite}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ticker-item{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-heading);font-size:.82rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.92);padding:0 2rem}
.ticker-item::after{content:'▪';margin-left:2rem;opacity:.5}

/* STATS */
.stats-section{background:var(--bg-secondary);padding:3.5rem 0;position:relative}
.stats-section::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(240,90,0,.04),transparent)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px}
.stat-item{text-align:center;padding:2.5rem 1.5rem;background:var(--bg-card);position:relative;transition:var(--transition);border-top:3px solid transparent}
.stat-item:hover{background:rgba(22,36,53,1);border-top-color:var(--cta)}
.stat-item i{font-size:1.8rem;color:var(--cta);margin-bottom:.8rem;display:block;opacity:.85}
.counter-wrap{display:flex;align-items:flex-end;justify-content:center;gap:.1rem}
.stat-item h3{font-family:var(--font-heading);font-size:clamp(2.2rem,4vw,3rem);font-weight:900;color:#fff;line-height:1}
.counter-wrap span{font-family:var(--font-heading);font-size:1.8rem;font-weight:900;color:var(--cta);line-height:1.3}
.stat-item p{color:var(--text-gray);font-size:.78rem;text-transform:uppercase;letter-spacing:1.5px;margin-top:.5rem}

/* SERVICE CARDS */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5px}
.service-card{background:var(--bg-card);padding:2.2rem 2rem;border-top:3px solid transparent;transition:var(--transition);position:relative;overflow:hidden}
.service-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,rgba(240,90,0,.06) 0%,transparent 60%);opacity:0;transition:opacity .3s}
.service-card:hover{border-top-color:var(--cta)}
.service-card:hover::before{opacity:1}
.service-card i{font-size:2.2rem;color:var(--cta);margin-bottom:1rem;display:block;transition:transform .3s}
.service-card:hover i{transform:scale(1.12)}
.service-card h3{font-size:1.15rem;color:#fff;margin-bottom:.7rem}
.service-card p{color:var(--text-gray);font-size:.87rem;line-height:1.7}
.service-card .card-link{display:inline-flex;align-items:center;gap:.4rem;color:var(--cta);font-size:.78rem;font-weight:700;letter-spacing:.5px;margin-top:1rem;opacity:0;transform:translateX(-4px);transition:var(--transition)}
.service-card:hover .card-link{opacity:1;transform:translateX(0)}

/* SERVICE DETAIL CARDS */
.service-detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5px}
.service-detail-card{background:var(--bg-card);transition:var(--transition);border-top:3px solid transparent;overflow:hidden}
.service-detail-card:hover{border-top-color:var(--cta)}
.service-detail-card-header{background:rgba(255,255,255,.025);padding:1.8rem 2rem 1.5rem;position:relative;border-bottom:1px solid var(--border-dim)}
.service-detail-card-header i{font-size:2.2rem;color:var(--cta);margin-bottom:.8rem;display:block}
.service-detail-card-header h3{font-size:1.1rem;color:#fff;line-height:1.2}
.service-num{position:absolute;top:1.5rem;right:1.5rem;font-family:var(--font-heading);font-size:3rem;font-weight:900;color:rgba(255,255,255,.04);line-height:1}
.service-detail-card-body{padding:1.5rem 2rem 2rem}
.service-detail-card-body p{color:var(--text-gray);font-size:.88rem;line-height:1.7;margin-bottom:1.2rem}
.service-features{display:flex;flex-direction:column;gap:.4rem}
.service-features li{color:var(--text-gray);font-size:.83rem;display:flex;align-items:center;gap:.5rem}
.service-features li i{color:var(--green-accent);flex-shrink:0}

/* HIGHLIGHTS */
.highlights-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5px}
.highlight-card{background:var(--bg-card);padding:2rem 1.8rem;text-align:center;border-bottom:3px solid transparent;transition:var(--transition)}
.highlight-card:hover{border-bottom-color:var(--cta);background:var(--bg-secondary)}
.highlight-card i{font-size:2rem;color:var(--cta);margin-bottom:1rem;display:block}
.highlight-card h4{font-size:1rem;color:#fff;margin-bottom:.6rem}
.highlight-card p{color:var(--text-gray);font-size:.84rem;line-height:1.65}

/* BLOG */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5px}
.blog-card{background:var(--bg-card);overflow:hidden;transition:var(--transition);border-top:3px solid transparent}
.blog-card:hover{border-top-color:var(--cta);transform:translateY(-3px);box-shadow:var(--shadow-hard)}
.blog-card-img{height:160px;background:linear-gradient(135deg,rgba(240,90,0,.15),rgba(11,21,32,.8));display:flex;align-items:center;justify-content:center;font-size:3rem;color:var(--cta);position:relative;overflow:hidden}
.blog-card-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.45}
.blog-card-body{padding:1.5rem}
.tag{display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--cta);background:rgba(240,90,0,.1);border:1px solid rgba(240,90,0,.2);padding:.2rem .65rem;border-radius:2px;margin-bottom:.8rem}
.blog-card-body h3{font-size:1.05rem;color:#fff;margin-bottom:.6rem;line-height:1.3}
.blog-card-body p{color:var(--text-gray);font-size:.84rem;line-height:1.65;margin-bottom:.8rem}
.blog-card-meta{display:flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.75rem}
.blog-card-meta i{color:var(--cta)}
.read-more{display:inline-flex;align-items:center;gap:.4rem;color:var(--cta);font-size:.78rem;font-weight:700;letter-spacing:.5px;margin-top:.4rem;transition:gap .2s}
.read-more:hover{gap:.7rem}

/* FILTER BAR */
.filter-bar{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:2.5rem;justify-content:center}
.filter-btn{font-family:var(--font-heading);font-size:.8rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:.45rem 1.2rem;border:1.5px solid var(--border-dim);background:transparent;color:var(--text-gray);cursor:pointer;border-radius:var(--radius);transition:var(--transition)}
.filter-btn:hover,.filter-btn.active{background:var(--cta);border-color:var(--cta);color:#fff}

/* PAGE HEADER */
.page-header{background:var(--bg-main);padding:calc(var(--nav-h) + 3.5rem) 0 3.5rem;text-align:center;position:relative;overflow:hidden}
.page-header::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(240,90,0,.07) 0%,transparent 50%),linear-gradient(315deg,rgba(255,208,0,.04) 0%,transparent 50%)}
.page-header::after{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:50px 50px}
.page-header .container{position:relative;z-index:1}
.page-header h1{font-size:clamp(2.2rem,5vw,3.8rem);color:#fff;margin-bottom:.8rem}
.page-header .subtitle{color:var(--text-gray);font-size:.95rem;font-style:italic;margin-bottom:1rem}
.page-header .breadcrumb{color:var(--text-muted);font-size:.78rem;letter-spacing:.5px}
.page-header .breadcrumb a{color:var(--cta)}

/* CTA SECTION */
.cta-section{background:linear-gradient(135deg,var(--cta) 0%,var(--cta-dark) 100%);padding:clamp(4rem,7vw,5.5rem) 0;text-align:center;position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(0,0,0,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.06) 1px,transparent 1px);background-size:50px 50px}
.cta-section .container{position:relative;z-index:1}
.cta-section h2{font-size:clamp(2rem,4vw,3.2rem);color:#fff;margin-bottom:1rem}
.cta-section p{color:rgba(255,255,255,.82);font-size:clamp(.9rem,1.8vw,1.1rem);margin-bottom:2.5rem;max-width:540px;margin-left:auto;margin-right:auto}
.cta-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.cta-section .btn-outline{border-color:rgba(255,255,255,.5);color:#fff}
.cta-section .btn-outline:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.8);color:#fff}

/* PROCESS STEPS */
.process-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:0;position:relative}
.process-steps::before{content:'';position:absolute;top:2.2rem;left:4%;width:92%;height:2px;background:linear-gradient(90deg,var(--cta),var(--safety-yellow));z-index:0}
.process-step{text-align:center;padding:0 1rem;position:relative;z-index:1}
.step-num{width:44px;height:44px;background:var(--cta);color:#fff;font-family:var(--font-heading);font-size:1rem;font-weight:900;display:flex;align-items:center;justify-content:center;border-radius:50%;margin:0 auto 1.2rem;box-shadow:0 0 0 4px var(--bg-accent),0 0 0 6px rgba(240,90,0,.2)}
.process-step h4{font-size:.9rem;color:#1A2A3A;margin-bottom:.5rem}
.process-step p{color:#5A7A8A;font-size:.8rem;line-height:1.6}

/* CONTACT */
.contact-layout{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,5vw,4rem)}
.contact-info{display:flex;flex-direction:column;gap:.9rem}
.contact-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem 1.2rem;background:var(--bg-card);border-left:3px solid transparent;border-radius:var(--radius);transition:var(--transition)}
.contact-item:hover{border-left-color:var(--cta)}
.contact-item .icon{width:38px;height:38px;background:rgba(240,90,0,.12);color:var(--cta);display:flex;align-items:center;justify-content:center;border-radius:var(--radius);font-size:.95rem;flex-shrink:0}
.contact-item h4{font-size:.75rem;letter-spacing:1px;color:var(--text-muted);text-transform:uppercase;margin-bottom:.2rem}
.contact-item a,.contact-item p{color:var(--text-light);font-size:.88rem;line-height:1.4}
.contact-item a:hover{color:var(--cta)}
.contact-form-wrap{background:var(--bg-card);padding:clamp(1.5rem,3vw,2.5rem);border-top:3px solid var(--cta);border-radius:0 0 var(--radius) var(--radius)}
.contact-form-wrap h3{font-size:1.6rem;color:#fff;margin-bottom:.4rem}
.contact-form-wrap > p{color:var(--text-gray);font-size:.87rem;margin-bottom:1.8rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-group{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}
.form-group label{font-size:.75rem;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:var(--text-gray)}
.form-group input,.form-group select,.form-group textarea{background:rgba(255,255,255,.04);border:1.5px solid var(--border-dim);color:var(--text-light);padding:.75rem 1rem;font-family:var(--font-body);font-size:.9rem;border-radius:var(--radius);transition:border-color .2s,background .2s;outline:none;-webkit-appearance:none;appearance:none}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--cta);background:rgba(240,90,0,.04)}
.form-group select option{background:var(--bg-secondary);color:var(--text-light)}
.form-group textarea{height:110px;resize:vertical}
.submit-btn{width:100%;justify-content:center;font-size:1rem;padding:.9rem}
.form-success{display:none;margin-top:1rem;padding:1rem 1.2rem;background:rgba(0,201,122,.1);border:1px solid rgba(0,201,122,.3);color:var(--green-accent);border-radius:var(--radius);font-size:.88rem;text-align:center}
.map-embed{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border-dim)}
.map-embed iframe{width:100%;height:220px;display:block;filter:grayscale(80%) invert(92%) hue-rotate(180deg)}

/* PRODUCTS */
.search-section{background:var(--bg-secondary);padding:2.5rem 0;border-bottom:1px solid var(--border-dim)}
.search-box{display:flex;align-items:center;gap:.8rem;max-width:540px;margin:0 auto;background:var(--bg-card);border:1.5px solid var(--border-dim);border-radius:40px;padding:.65rem 1.4rem;transition:border-color .2s}
.search-box:focus-within{border-color:var(--cta)}
.search-box i{color:var(--text-muted);flex-shrink:0}
.search-box input{flex:1;background:transparent;border:none;color:var(--text-light);font-family:var(--font-body);font-size:.9rem;outline:none}
.search-box input::placeholder{color:var(--text-muted)}
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5px}
.reveal-card{position:relative;height:220px;background:var(--bg-card);overflow:hidden;cursor:pointer}
.reveal-front{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.8rem;background:var(--bg-card);transition:opacity .35s ease,transform .35s ease;z-index:1}
.reveal-front i{font-size:2.5rem;color:var(--cta)}
.reveal-front h3{font-size:1.1rem;color:#fff}
.reveal-back{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity .35s ease}
.reveal-overlay{position:absolute;inset:0;background:rgba(11,21,32,.82)}
.reveal-content{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:1.5rem;text-align:center}
.reveal-content p{color:rgba(255,255,255,.8);font-size:.86rem;line-height:1.6}
.category-btn{display:inline-block;padding:.45rem 1.2rem;background:var(--cta);color:#fff;font-family:var(--font-heading);font-size:.8rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;border-radius:var(--radius);transition:background .2s}
.category-btn:hover{background:var(--cta-dark)}
.reveal-card:hover .reveal-front{opacity:0;transform:scale(1.05)}
.reveal-card:hover .reveal-back{opacity:1}
.category-block{background:var(--bg-card);margin-bottom:2px;border-left:4px solid transparent;transition:border-color .2s}
.category-block:hover{border-left-color:var(--cta)}
.category-block-header{padding:1.2rem 1.8rem;display:flex;align-items:center;gap:.8rem;cursor:pointer;user-select:none;background:rgba(255,255,255,.02);border-bottom:1px solid var(--border-dim)}
.category-block-header i{color:var(--cta);font-size:1.2rem}
.category-block-header h3{font-size:1.05rem;color:#fff;flex:1}
.category-block-header .item-count{font-size:.73rem;color:var(--text-muted);background:rgba(255,255,255,.06);padding:.15rem .5rem;border-radius:10px}
.product-list{padding:1rem 1.8rem 1.5rem;display:grid;grid-template-columns:repeat(2,1fr);gap:.4rem}
.product-list li{display:flex;align-items:center;gap:.55rem;color:var(--text-gray);font-size:.85rem;padding:.35rem 0;border-bottom:1px solid rgba(255,255,255,.03);transition:color .2s}
.product-list li::before{content:'→';color:var(--cta);font-size:.75rem;flex-shrink:0;opacity:.7}
.product-list li:hover{color:var(--text-light)}

/* TESTIMONIALS */
.testimonials-section{background:var(--bg-secondary);padding:clamp(4rem,7vw,6rem) 0;overflow:hidden}
.testimonials-slider{position:relative;overflow:hidden}
.testimonials-track{display:flex;gap:1.5rem;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.testimonial-card{flex:0 0 calc(33.333% - 1rem);background:var(--bg-card);padding:2rem;border-radius:var(--radius-lg);border:1px solid var(--border-dim);border-top:3px solid var(--cta)}
.testimonial-quote{font-size:3rem;color:var(--cta);opacity:.25;line-height:1;font-family:Georgia,serif;margin-bottom:.5rem}
.testimonial-text{color:var(--text-gray);font-size:.9rem;line-height:1.75;margin-bottom:1.5rem;font-style:italic}
.testimonial-author{display:flex;align-items:center;gap:.9rem}
.testimonial-avatar{width:44px;height:44px;background:linear-gradient(135deg,var(--cta),var(--cta-dark));border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--font-heading);font-size:1.1rem;font-weight:900;flex-shrink:0}
.testimonial-author-info h5{font-size:.9rem;color:#fff}
.testimonial-author-info p{color:var(--text-muted);font-size:.75rem}
.testimonial-stars{display:flex;gap:.2rem;margin-bottom:.8rem}
.testimonial-stars i{color:var(--safety-yellow);font-size:.8rem}
.slider-controls{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:2rem}
.slider-btn{width:40px;height:40px;background:var(--bg-card);border:1px solid var(--border-dim);color:var(--text-gray);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:var(--transition);font-size:.9rem}
.slider-btn:hover{background:var(--cta);border-color:var(--cta);color:#fff}
.slider-dots{display:flex;gap:.5rem}
.slider-dot{width:8px;height:8px;background:var(--border-dim);border-radius:50%;cursor:pointer;transition:var(--transition);border:none;padding:0}
.slider-dot.active{background:var(--cta);width:24px;border-radius:4px}

/* FAQ */
.faq-section{background:var(--bg-accent);padding:clamp(4rem,7vw,6rem) 0}
.faq-list{max-width:820px;margin:0 auto}
.faq-item{border-bottom:1px solid rgba(0,0,0,.1);overflow:hidden}
.faq-question{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1.3rem 0;cursor:pointer;user-select:none}
.faq-question h4{font-size:1rem;color:#1A2A3A;font-weight:700;line-height:1.3;text-transform:none;letter-spacing:0}
.faq-icon{width:32px;height:32px;background:rgba(240,90,0,.1);color:var(--cta);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:var(--transition);font-size:.85rem}
.faq-item.open .faq-icon{background:var(--cta);color:#fff;transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .38s ease}
.faq-answer p{color:#4A6070;font-size:.9rem;line-height:1.75;padding-bottom:1.3rem}
.faq-item.open .faq-answer{max-height:300px}

/* GALLERY */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}
.gallery-item{position:relative;aspect-ratio:4/3;overflow:hidden;cursor:pointer;background:var(--bg-card)}
.gallery-item-inner{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3.5rem;color:var(--cta);background:linear-gradient(135deg,var(--bg-card),var(--bg-secondary));transition:transform .45s ease}
.gallery-item:hover .gallery-item-inner{transform:scale(1.08)}
.gallery-overlay{position:absolute;inset:0;background:rgba(11,21,32,0);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;transition:background .35s ease;padding:1.5rem;text-align:center}
.gallery-item:hover .gallery-overlay{background:rgba(11,21,32,.78)}
.gallery-overlay-content{opacity:0;transform:translateY(12px);transition:opacity .3s ease,transform .3s ease}
.gallery-item:hover .gallery-overlay-content{opacity:1;transform:translateY(0)}
.gallery-overlay-content h4{color:#fff;font-size:.95rem;margin-bottom:.3rem}
.gallery-overlay-content p{color:var(--text-gray);font-size:.78rem}
.gallery-overlay-content .zoom-icon{color:var(--cta);font-size:1.3rem;margin-top:.5rem}
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:9999;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;backdrop-filter:blur(4px)}
.lightbox.active{opacity:1;pointer-events:all}
.lightbox-inner{max-width:700px;width:90%;text-align:center;position:relative}
.lightbox-icon{font-size:8rem;color:var(--cta);margin-bottom:1.5rem;opacity:.7}
.lightbox-content h3{color:#fff;font-size:1.5rem;margin-bottom:.5rem}
.lightbox-content p{color:var(--text-gray);font-size:.9rem}
.lightbox-close{position:absolute;top:-3rem;right:0;color:var(--text-gray);font-size:1.5rem;cursor:pointer;background:none;border:none;transition:color .2s;padding:.5rem}
.lightbox-close:hover{color:#fff}
.lightbox-nav-btn{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);color:#fff;font-size:1.1rem;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.lightbox-nav-btn:hover{background:var(--cta);border-color:var(--cta)}
.lightbox-prev{left:-3.5rem}
.lightbox-next{right:-3.5rem}

/* ABOUT PAGE */
.company-visual{background:var(--bg-card);padding:2.5rem 2rem;text-align:center;border:1px solid var(--border-dim);border-top:4px solid var(--cta);border-radius:var(--radius)}
.company-visual i{font-size:4rem;color:var(--cta);margin-bottom:1rem;display:block}
.company-visual p{color:var(--text-gray);font-size:.85rem}
.vm-cards{display:grid;grid-template-columns:1fr 1fr;gap:1.5px}
.vm-card{padding:2.5rem 2rem;position:relative;overflow:hidden}
.vision-card{background:var(--bg-card);border-top:4px solid var(--cta)}
.mission-card{background:var(--bg-secondary);border-top:4px solid var(--safety-yellow)}
.vm-card i{font-size:2rem;margin-bottom:1rem;display:block}
.vision-card i{color:var(--cta)}
.mission-card i{color:var(--safety-yellow)}
.vm-card h3{font-size:1.3rem;color:#fff;margin-bottom:.8rem}
.vm-card p{color:var(--text-gray);font-size:.88rem;line-height:1.75}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5px}
.team-card{background:var(--bg-card);text-align:center;padding:2rem 1.5rem;border-bottom:3px solid transparent;transition:var(--transition)}
.team-card:hover{border-bottom-color:var(--cta)}
.team-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--cta) 0%,var(--cta-dark) 100%);margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:2rem;font-weight:900;color:#fff;box-shadow:0 6px 20px rgba(240,90,0,.3)}
.team-card h4{font-size:1rem;color:#fff;margin-bottom:.3rem}
.team-card .role{color:var(--cta);font-size:.73rem;letter-spacing:1px;text-transform:uppercase;font-weight:600;margin-bottom:.7rem}
.team-card p{color:var(--text-gray);font-size:.82rem;line-height:1.6}
.timeline{position:relative;max-width:720px;margin:0 auto;padding-left:2.5rem}
.timeline::before{content:'';position:absolute;left:.8rem;top:0;bottom:0;width:2px;background:linear-gradient(180deg,var(--cta),var(--safety-yellow),var(--green-accent))}
.timeline-item{position:relative;padding:0 0 2.5rem 2rem}
.timeline-item::before{content:'';position:absolute;left:-.45rem;top:.35rem;width:12px;height:12px;background:var(--cta);border-radius:50%;box-shadow:0 0 0 3px rgba(240,90,0,.2)}
.timeline-year{font-family:var(--font-heading);font-size:.8rem;font-weight:900;letter-spacing:2px;color:var(--cta);text-transform:uppercase;margin-bottom:.3rem}
.timeline-item h4{font-size:1rem;color:#fff;margin-bottom:.4rem}
.timeline-item p{color:var(--text-gray);font-size:.84rem;line-height:1.65}

/* WA WIDGET */
.wa-widget-container{position:fixed;bottom:2rem;right:1.5rem;z-index:999;display:flex;flex-direction:column;align-items:flex-end;gap:.8rem}
.wa-float-btn{width:56px;height:56px;background:#25D366;border:none;border-radius:50%;color:#fff;font-size:1.55rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 24px rgba(37,211,102,.45);transition:transform .3s ease,box-shadow .3s;position:relative}
.wa-float-btn:hover{transform:scale(1.08);box-shadow:0 8px 30px rgba(37,211,102,.55)}
.wa-pulse{position:absolute;width:100%;height:100%;border-radius:50%;background:#25D366;animation:waPulse 2.5s ease-out infinite;z-index:-1}
@keyframes waPulse{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.8);opacity:0}}
.wa-options{display:none;flex-direction:column;background:var(--bg-secondary);border:1px solid var(--border-dim);border-radius:var(--radius-lg);overflow:hidden;min-width:230px;box-shadow:var(--shadow-hard)}
.wa-options.show{display:flex}
.wa-header{background:#25D366;color:#fff;padding:.8rem 1.1rem;font-size:.82rem;font-weight:600;display:flex;justify-content:space-between;align-items:center}
.wa-option{display:block;padding:.75rem 1.1rem;color:var(--text-gray);font-size:.84rem;border-bottom:1px solid var(--border-dim);transition:background .2s}
.wa-option:last-child{border-bottom:none}
.wa-option:hover{background:rgba(255,255,255,.04);color:var(--text-light)}

/* SCROLL TOP */
.scroll-top{position:fixed;bottom:5.5rem;right:1.5rem;width:40px;height:40px;background:var(--cta);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:998;opacity:0;pointer-events:none;transform:translateY(10px);transition:opacity .3s,transform .3s,box-shadow .3s;box-shadow:0 4px 14px rgba(240,90,0,.3)}
.scroll-top.visible{opacity:1;pointer-events:all;transform:translateY(0)}
.scroll-top:hover{box-shadow:var(--shadow-cta);transform:translateY(-2px)!important}

/* MOBILE CTA BAR */
.mobile-cta-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:997;background:var(--bg-main);border-top:1px solid var(--border-dim);padding:.6rem 1rem;gap:.6rem;box-shadow:0 -4px 20px rgba(0,0,0,.35)}
.mobile-cta-bar a{flex:1;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.7rem;border-radius:var(--radius);font-family:var(--font-heading);font-size:.82rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase}
.mobile-cta-bar .cta-call{background:var(--cta);color:#fff}
.mobile-cta-bar .cta-wa{background:#25D366;color:#fff}

/* FOOTER */
.site-footer{background:var(--bg-main);border-top:3px solid rgba(240,90,0,.25)}
.footer-main{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:3rem;padding:clamp(3rem,6vw,5rem) clamp(1rem,4vw,3rem);max-width:1280px;margin:0 auto}
.footer-brand img{height:44px;margin-bottom:1rem}
.footer-brand p{color:var(--text-gray);font-size:.84rem;line-height:1.7;max-width:280px}
.footer-socials{display:flex;gap:.6rem;margin-top:1.2rem}
.footer-socials a{width:36px;height:36px;background:rgba(255,255,255,.06);color:var(--text-gray);display:flex;align-items:center;justify-content:center;border-radius:var(--radius);font-size:.9rem;transition:var(--transition);border:1px solid var(--border-dim)}
.footer-socials a:hover{background:var(--cta);color:#fff;border-color:var(--cta);transform:translateY(-2px)}
.footer-col h4{font-size:.78rem;letter-spacing:2px;text-transform:uppercase;color:var(--text-light);margin-bottom:1.2rem;padding-bottom:.7rem;border-bottom:1px solid var(--border-dim)}
.footer-col ul li{margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}
.footer-col ul li a,.footer-col ul li p,.footer-col ul li span{color:var(--text-gray);font-size:.83rem;transition:color .2s}
.footer-col ul li a:hover{color:var(--cta)}
.footer-col ul li i{color:var(--cta);font-size:.8rem;flex-shrink:0}
.divider{height:1px;background:var(--border-dim);max-width:1280px;margin:0 auto}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:1.2rem clamp(1rem,4vw,3rem);max-width:1280px;margin:0 auto;flex-wrap:wrap;gap:.5rem}
.footer-bottom span{color:var(--text-muted);font-size:.77rem}
.footer-bottom a{color:var(--cta)}

/* RESPONSIVE */
@media(max-width:1100px){
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .service-detail-grid{grid-template-columns:repeat(2,1fr)}
  .highlights-grid{grid-template-columns:repeat(2,1fr)}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .footer-main{grid-template-columns:1fr 1fr;gap:2rem}
  .process-steps{grid-template-columns:1fr}
  .process-steps::before{display:none}
  .testimonial-card{flex:0 0 calc(50% - .75rem)}
}
@media(max-width:768px){
  :root{--nav-h:62px}
  .nav-links{display:none}
  .hamburger{display:flex}
  .two-column{grid-template-columns:1fr}
  .vm-cards{grid-template-columns:1fr}
  .contact-layout{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:1px}
  .services-grid{grid-template-columns:1fr}
  .service-detail-grid{grid-template-columns:1fr}
  .highlights-grid{grid-template-columns:1fr 1fr}
  .blog-grid{grid-template-columns:1fr}
  .product-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .team-grid{grid-template-columns:1fr 1fr}
  .footer-main{grid-template-columns:1fr;gap:2rem}
  .footer-brand p{max-width:100%}
  .testimonial-card{flex:0 0 100%}
  .mobile-cta-bar{display:flex}
  body{padding-bottom:68px}
  .wa-widget-container{bottom:5.5rem;right:1rem}
  .scroll-top{bottom:8rem;right:1rem}
  .lightbox-prev{left:-1rem}
  .lightbox-next{right:-1rem}
  .page-header{padding:calc(var(--nav-h) + 2.5rem) 0 2.5rem}
}
@media(max-width:480px){
  .highlights-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .product-grid{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .hero-title{font-size:clamp(2.5rem,12vw,3.5rem)}
  .btn{padding:.7rem 1.5rem;font-size:.88rem}
  .cta-buttons{flex-direction:column;align-items:center}
  .footer-main{grid-template-columns:1fr}
  .product-list{grid-template-columns:1fr}
}

.page-top-offset{padding-top:var(--nav-h)}
.cert-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .9rem;border:1px solid var(--border-dim);border-radius:30px;color:var(--text-gray);font-size:.75rem;background:rgba(255,255,255,.03)}
.cert-badge i{color:var(--safety-yellow)}

  PRODUCTS PAGE: HOVER REVEAL CARDS (FIXED)
   ========================================= */
   
 body {
  overflow-x: hidden;
}
 
.hover-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(260px, 100%), 1fr));
  gap: 2rem;
  margin-top: 3rem;
}

.reveal-card {
  position: relative;
  height: 260px;
  background: var(--bg-secondary);
  overflow: hidden;
  box-shadow: var(--shadow);
  cursor: pointer;
  border-radius: 12px; /* Fallback */
  clip-path: polygon(20px 0, 100% 0, 100% calc(100% - 20px), calc(100% - 20px) 100%, 0 100%, 0 20px);
}

/* Front Face */
.reveal-front {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--bg-secondary);
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  transition: transform 0.4s ease, opacity 0.4s ease;
  z-index: 2;
}

.reveal-front i {
  font-size: 3.5rem;
  color: var(--cta);
  margin-bottom: 1rem;
}

.reveal-front h3 {
  font-size: 1.5rem;
  font-weight: 700;
  color: #fff;
  font-family: var(--font-heading);
  text-transform: uppercase;
  margin: 0;
}

/* Back Face (Image + Content) */
.reveal-back {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  transform: translateY(100%);
  transition: transform 0.4s ease;
  z-index: 1;
}

.reveal-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(19, 30, 39, 0.9); /* Dark overlay */
  z-index: 1;
}

.reveal-content {
  position: relative;
  z-index: 2;
  padding: 1.5rem;
  color: #fff;
}

.reveal-content p {
  font-size: 1.1rem;
  margin-bottom: 1.5rem;
}

.category-btn {
  background: var(--cta);
  color: #fff;
  padding: 0.7rem 1.8rem;
  border-radius: 30px;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 0.9rem;
  letter-spacing: 1px;
  display: inline-block;
  text-decoration: none;
  transition: background 0.3s ease, transform 0.2s ease;
}

.category-btn:hover {
  background: var(--safety-yellow);
  color: var(--bg-main);
  transform: scale(1.05);
}

/* Hover Actions for Reveal Card */
.reveal-card:hover .reveal-front {
  transform: translateY(-100%);
  opacity: 0;
}

.reveal-card:hover .reveal-back {
  transform: translateY(0);
}
/* Hover Reveal Grid */

.reveal-front i {
  font-size: 3.5rem;
  color: var(--cta);
  margin-bottom: 1rem;
}

.reveal-front h3 {
  font-size: 1.5rem;
  font-weight: 700;
  font-family: var(--font-heading);
}

/* Back Face (Image + Content) */
.reveal-back {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  transform: translateY(100%);
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 1;
}

.reveal-overlay {
  position: absolute;
  inset: 0;
  background: rgba(19, 30, 39, 0.85); /* Dark overlay */
  z-index: 1;
}

.reveal-content {
  position: relative;
  z-index: 2;
  padding: 1.5rem;
  color: #fff;
}

.reveal-content p {
  font-size: 1.1rem;
  margin-bottom: 1.5rem;
}

.category-btn {
  background: var(--cta);
  color: #fff;
  padding: 0.7rem 1.8rem;
  border-radius: 30px;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 0.9rem;
  letter-spacing: 1px;
  transition: background 0.3s ease, transform 0.2s ease;
}

.category-btn:hover {
  background: var(--safety-yellow);
  color: var(--bg-main);
  transform: scale(1.05);
}

/* Hover Actions for Reveal Card */
.reveal-card:hover .reveal-front {
  transform: translateY(-100%);
  opacity: 0;
}

.reveal-card:hover .reveal-back {
  transform: translateY(0);
}

/* Inventory List Styling */
.inventory-category {
  background: #fff;
  padding: 2.5rem;
  border-radius: 12px;
  margin-bottom: 2rem;
  box-shadow: var(--shadow-light);
  border-left: 5px solid var(--cta);
}

.inventory-category h3 {
  color: var(--bg-main);
  margin-bottom: 1.5rem;
  font-size: 1.6rem;
  display: flex;
  align-items: center;
  gap: 15px;
}

.inventory-category h3 i {
  color: var(--cta);
}

.product-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 1rem;
  list-style: none;
}

.product-list li {
  background: var(--bg-accent);
  padding: 1rem 1.5rem;
  border-radius: 6px;
  color: #444;
  font-weight: 500;
  transition: all 0.2s ease;
  border-left: 3px solid transparent;

  /* Fix for text overflow */
  display: flex;            /* Keeps icon and text aligned */
  align-items: flex-start;  /* Aligns icon to the top of multi-line text */
  white-space: normal;      /* Allows text to wrap to the next line */
  word-wrap: break-word;    /* Breaks long words if necessary */
  overflow-wrap: break-word;
  height: auto;             /* Ensures the box expands with the text */
  line-height: 1.4;         /* Improves readability for multi-line text */
}


.product-list li:hover {
  background: var(--bg-secondary);
  color: #fff;
  border-left-color: var(--safety-yellow);
  transform: translateX(5px);
}

/* =========================================
   FOOTER SECTION
   ========================================= */
.site-footer {
  background: #0d141b; /* Extra dark for footer */
  color: var(--text-gray);
  padding: 4rem 2rem 1.5rem;
  border-top: 4px solid var(--cta);
}

.footer-main {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 3rem;
  max-width: 1200px;
  margin: 0 auto 2rem;
}

.footer-col {
  flex: 1;
  min-width: 250px;
}

.footer-col h4 {
  color: #fff;
  font-size: 1.3rem;
  margin-bottom: 1.5rem;
  position: relative;
  padding-bottom: 10px;
}

.footer-col h4::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 50px;
  height: 3px;
  background: var(--safety-yellow);
}

.footer-col ul {
  list-style: none;
}

.footer-col ul li {
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: 10px;
}

.footer-col a {
  color: var(--text-gray);
  transition: color 0.3s ease;
}

.footer-col a:hover {
  color: var(--safety-yellow);
}

.footer-socials {
  display: flex;
  gap: 1.5rem;
  margin-top: 1rem;
}

.footer-socials a {
  font-size: 1.8rem;
  color: var(--text-gray);
  background: rgba(255,255,255,0.05);
  width: 45px;
  height: 45px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 50%;
  transition: all 0.3s ease;
}

.footer-socials a:hover {
  background: var(--cta);
  color: #fff;
  transform: translateY(-5px);
}

.footer-credits {
  text-align: center;
  padding-top: 2rem;
  border-top: 1px solid rgba(255,255,255,0.1);
  font-size: 0.9rem;
  color: #888;
}

/* =========================================
   RESPONSIVE TWEAKS FOR ALL PAGES
   ========================================= */
@media (max-width: 768px) {
  .hero-title { font-size: 2.8rem; }
  .hero-sub { font-size: 1.2rem; }
  .section { padding: 3rem 1.5rem; }
  .counter-wrap { font-size: 3rem; }
  .stat-item i { font-size: 2.5rem; }
  .two-column, .vm-cards, .founder-content {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
}
/* =========================================
   ABOUT PAGE SPECIFIC STYLES (PREMIUM THEME)
   ========================================= */

/* Company Overview */
.company-overview { background: #fff; color: var(--bg-main); }
.two-column { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: center; }
.content-left h2 { font-size: 2.2rem; margin-bottom: 1.2rem; color: var(--bg-main); }
.content-left p { font-size: 1.1rem; color: #555; margin-bottom: 1rem; }
.company-visual { background: var(--bg-accent); padding: 3rem; border-radius: 12px; text-align: center; border-bottom: 4px solid var(--cta); }
.company-visual i { font-size: 5rem; color: var(--cta); margin-bottom: 1rem; }
.company-visual p { font-weight: 600; font-family: var(--font-heading); color: var(--bg-main); }

/* Vision & Mission */
.vision-mission { background: var(--bg-secondary); color: #fff; }
.vm-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 2rem; }
.vm-card { background: rgba(255,255,255,0.05); padding: 3rem 2rem; border-radius: 12px; text-align: center; border-top: 4px solid transparent; transition: all 0.3s; }
.vm-card:hover { border-top-color: var(--safety-yellow); background: rgba(255,255,255,0.08); transform: translateY(-5px); }
.vm-card i { font-size: 3rem; color: var(--safety-yellow); margin-bottom: 1.2rem; }
.vm-card h3 { color: #fff; margin-bottom: 1rem; font-size: 1.6rem; }
.vm-card p { color: var(--text-gray); font-size: 1.05rem; }

/* Core Values */
.core-values { background: var(--bg-accent); text-align: center; }
.core-values h2 { margin-bottom: 3rem; color: var(--bg-main); font-size: 2.5rem; }
.values-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 2rem; }
.value-card { background: #fff; padding: 2.5rem 1.5rem; border-radius: 12px; box-shadow: var(--shadow-light); transition: transform 0.3s; }
.value-card:hover { transform: translateY(-8px); box-shadow: var(--shadow); }
.value-card i { font-size: 2.5rem; color: var(--cta); margin-bottom: 1rem; }
.value-card h4 { font-size: 1.2rem; margin-bottom: 0.5rem; color: var(--bg-main); }
.value-card p { color: #666; font-size: 0.95rem; }

/* Founder Section */
.founder-section { background: var(--bg-main); color: #fff; }
.founder-content { display: grid; grid-template-columns: 1fr 2fr; gap: 3rem; align-items: center; background: var(--bg-secondary); padding: 3rem; border-radius: 12px; border-left: 5px solid var(--safety-yellow); }
.founder-image i { font-size: 6rem; color: var(--safety-yellow); }
.founder-text h3 { font-size: 2rem; margin-bottom: 0.2rem; }
.founder-text h4 { color: var(--cta); margin-bottom: 1.5rem; font-family: var(--font-body); font-weight: 600; }
.founder-text blockquote { font-size: 1.15rem; font-style: italic; color: var(--text-gray); border-left: 3px solid var(--cta); padding-left: 1.2rem; line-height: 1.7; }

/* Industries & Regions */
.industries-regions { background: #fff; color: var(--bg-main); }
.industries-regions h3 { font-size: 1.8rem; margin-bottom: 1.5rem; color: var(--bg-main); }
.industry-list { list-style: none; }
.industry-list li { font-size: 1.1rem; padding: 0.8rem 0; border-bottom: 1px solid #eee; display: flex; align-items: center; gap: 12px; color: #444; }
.industry-list li i { color: var(--cta); font-size: 1.2rem; }
.service-areas { display: flex; gap: 1rem; flex-wrap: wrap; }
.area-badge { background: var(--bg-secondary); color: #fff; padding: 0.8rem 1.5rem; border-radius: 30px; font-weight: 600; display: flex; align-items: center; gap: 8px; }
.area-badge i { color: var(--safety-yellow); }

/* Terms & Conditions */
.terms-conditions { background: var(--bg-accent); }
.terms-conditions h2 { text-align: center; margin-bottom: 3rem; color: var(--bg-main); font-size: 2.5rem; }
.terms-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 1.5rem; }
.term-item { background: #fff; padding: 1.8rem; border-radius: 8px; border-left: 4px solid var(--cta); box-shadow: var(--shadow-light); }
.term-item h4 { color: var(--bg-main); margin-bottom: 0.8rem; font-size: 1.15rem; }
.term-item p, .term-item ul { font-size: 0.95rem; color: #555; line-height: 1.6; }
.term-item ul { margin-left: 1.5rem; margin-top: 0.5rem; }

/* Mobile Responsive Fixes for About Page */
@media (max-width: 768px) {
  .founder-content { grid-template-columns: 1fr; text-align: center; padding: 2rem; border-left: none; border-top: 5px solid var(--safety-yellow); }
  .founder-text blockquote { border-left: none; border-top: 3px solid var(--cta); padding-top: 1rem; padding-left: 0; }
  .company-visual { margin-top: 2rem; }
}
/* =========================================
   COMPREHENSIVE MOBILE OPTIMIZATION 
   ========================================= */

/* For Tablets and Smaller Laptops (max-width: 900px) */
@media (max-width: 900px) {
  nav.navbar { padding: 1rem 2rem; }
  nav.navbar.solid { padding: 0.8rem 2rem; }
  .hero-title { font-size: 3rem; }
}

/* For Standard Mobile Phones (max-width: 768px) */
@media (max-width: 768px) {
  /* Global Spacing & Typography */
  .section { padding: 3rem 1.2rem; }
  h1, h2 { font-size: 2.2rem !important; margin-bottom: 1.5rem; }
  
  /* Hero Section */
  .hero-title { font-size: 2.4rem; }
  .hero-sub { font-size: 1.1rem; margin-bottom: 2rem; }
  .video-hero { min-height: 80vh; }
  
  /* Buttons */
  .cta-buttons { flex-direction: column; width: 100%; gap: 1rem; }
  .cta-btn { width: 100%; justify-content: center; }

  /* Grids & Cards Setup */
  .hover-grid { 
    grid-template-columns: 1fr; /* 1 card per row on mobile */
    gap: 1.5rem; 
  }
  .reveal-card { height: 220px; }
  
  .services-grid { grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 1rem; }
  .service-card { padding: 1.5rem 1rem; }
  .service-card i { font-size: 2.5rem; }
  
  .vm-cards, .values-grid, .stats-grid, .terms-grid { 
    grid-template-columns: 1fr; 
    gap: 1.5rem; 
  }
  
  /* About Page Specifics */
  .two-column { grid-template-columns: 1fr; gap: 2rem; text-align: center; }
  .content-left h2 { font-size: 2rem; }
  .company-visual { padding: 2rem; margin-top: 1rem; }
  .founder-content { 
    grid-template-columns: 1fr; 
    text-align: center; 
    padding: 2rem 1rem; 
    border-left: none; 
    border-top: 4px solid var(--safety-yellow); 
  }
  .founder-text blockquote { 
    border-left: none; 
    border-top: 3px solid var(--cta); 
    padding-left: 0; 
    padding-top: 1rem; 
  }
  
  /* Stats Counter */
  .counter-wrap { font-size: 2.8rem; }
  .stat-item i { font-size: 2.5rem; }

  /* Footer Centering */
  .footer-main { flex-direction: column; gap: 2.5rem; text-align: center; }
  .footer-col h4::after { left: 50%; transform: translateX(-50%); }
  .footer-col ul li { justify-content: center; }
  .footer-socials { justify-content: center; }
}

/* For Small Phones (max-width: 480px) */
@media (max-width: 480px) {
  nav.navbar { padding: 0.8rem 1rem; }
  .logo img { height: 35px; }
  .hero-title { font-size: 2rem; }
  
  /* Product Search Bar */
  .search-box input { padding: 1rem 1rem 1rem 2.5rem; font-size: 1rem; }
  .search-box i { left: 12px; font-size: 1.1rem; }
  
  /* Smart WhatsApp Widget */
  .wa-widget-container { bottom: 20px; right: 20px; }
  .wa-float-btn { width: 55px; height: 55px; font-size: 2rem; }
  .wa-options { width: 250px; right: 0; margin-bottom: 10px; }
  .wa-option { font-size: 0.85rem; padding: 12px; }
}

/* =========================================
   TOUCH DEVICE UX (MOBILE HOVER FIX)
   ========================================= */
/* Phones par mouse hover nahi hota, "tap" hota hai. 
   Yeh us tap ko smooth banayega aur user ko hint dega */
@media (hover: none) {
  .reveal-front::after {
    content: "Tap to view details";
    display: block;
    font-size: 0.8rem;
    color: var(--text-gray);
    margin-top: 10px;
    font-family: var(--font-body);
    text-transform: none;
    letter-spacing: normal;
    background: rgba(0,0,0,0.3);
    padding: 4px 12px;
    border-radius: 20px;
  }
}

.reveal-card {
  overflow: hidden;
  isolation: isolate;
}

.products-overview {
  overflow: hidden;
}

.hover-grid {
  width: 100%;
  max-width: 100vw; /* Ensures it never exceeds the screen width */
  margin-left: auto;
  margin-right: auto;
  overflow: hidden;
}

html, body {
  width: 100%;
  margin: 0;
  padding: 0;
  overflow-x: hidden; /* Force clipping on both root elements */
  position: relative;
}

@media (max-width: 768px) {
  .inventory-category {
    padding: 1.2rem; /* Reduces the thick padding that pushes content off-screen */
  }
  
  .product-list {
    grid-template-columns: 1fr !important; /* Forces a single column, ignoring the 300px minimum */
  }

  .product-list li {
    word-break: break-word;
    white-space: normal;
    height: auto;
  }
}
