@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;600;700;800;900&family=Source+Sans+3:wght@300;400;600&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}

:root{
  --black:#111827;
  --black-soft:#1F2937;
  --gray-dark:#374151;
  --gray-mid:#6B7280;
  --gray-light:#9CA3AF;
  --gray-border:#E5E7EB;
  --gray-bg:#F9FAFB;
  --gray-bg2:#F3F4F6;
  --blue:#29ABE2;
  --indigo:#3D3094;
  --white:#ffffff;
  --green-wa:#25D366;
  --font-head:'Montserrat',sans-serif;
  --font-body:'Source Sans 3',sans-serif;
  --ease-luxury:cubic-bezier(0.16,1,0.3,1);
  --ease-smooth:cubic-bezier(0.4,0,0.2,1);
  --transition:0.2s ease;
  --shadow-sm:0 1px 3px rgba(0,0,0,0.06);
  --shadow-md:0 8px 32px rgba(0,0,0,0.10);
  --shadow-lg:0 20px 60px rgba(0,0,0,0.14);
}

html{scroll-behavior:smooth;}
body{font-family:var(--font-body);font-size:15px;line-height:1.7;color:var(--black);background:var(--white);-webkit-font-smoothing:antialiased;}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;}
ul,ol{list-style:none;}
video{display:block;}

/* TYPOGRAPHY */
h1,h2,h3,h4,h5{font-family:var(--font-head);font-weight:800;line-height:1.08;color:var(--black);letter-spacing:-0.5px;}
h1{font-size:clamp(1.9rem,3.5vw,2.8rem);}
h2{font-size:clamp(1.4rem,2.5vw,2rem);}
h3{font-size:clamp(1rem,1.8vw,1.3rem);}
p{color:var(--gray-dark);line-height:1.85;font-weight:300;}

.label{font-family:var(--font-head);font-size:0.6rem;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--blue);display:flex;align-items:center;gap:8px;margin-bottom:10px;}
.label::before{content:'';display:inline-block;width:24px;height:1.5px;background:var(--blue);flex-shrink:0;}

/* LAYOUT */
.container{max-width:1200px;margin:0 auto;padding:0 32px;}
.section{padding:80px 0;}
.section-sm{padding:48px 0;}
.section-lg{padding:100px 0;}

/* BUTTONS */
.btn{display:inline-block;font-family:var(--font-head);font-size:0.7rem;font-weight:700;letter-spacing:0.5px;padding:12px 24px;border-radius:2px;cursor:pointer;transition:all 0.3s var(--ease-luxury);border:none;text-align:center;}
.btn-primary{background:var(--black);color:var(--white);}
.btn-primary:hover{background:var(--black-soft);transform:translateY(-1px);box-shadow:0 8px 24px rgba(0,0,0,0.15);}
.btn-outline{background:transparent;color:var(--black);border:1px solid var(--black);}
.btn-outline:hover{background:var(--black);color:var(--white);transform:translateY(-1px);}
.btn-white{background:var(--white);color:var(--black);}
.btn-white:hover{background:var(--gray-bg);transform:translateY(-1px);}
.btn-whatsapp{background:var(--green-wa);color:var(--white);}
.btn-whatsapp:hover{background:#1ebe5d;transform:translateY(-1px);}

/* NAVBAR */
.navbar{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,0.96);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:0.5px solid var(--gray-border);height:68px;display:flex;align-items:center;transition:box-shadow 0.3s var(--ease-smooth);}
.navbar.scrolled{box-shadow:0 4px 24px rgba(0,0,0,0.08);}
.navbar .container{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:1200px;}
.navbar-brand{display:flex;align-items:center;gap:10px;}
.navbar-logo{height:44px;width:auto;}
.navbar-name{border-left:1px solid var(--gray-border);padding-left:10px;}
.navbar-name .company{font-family:var(--font-head);font-size:0.7rem;font-weight:700;color:var(--black);letter-spacing:0.5px;}
.navbar-name .group{font-family:var(--font-head);font-size:0.55rem;color:var(--gray-light);letter-spacing:0.5px;}
.navbar-nav{display:flex;align-items:center;gap:24px;}
.navbar-nav a{font-family:var(--font-head);font-size:0.68rem;font-weight:600;color:var(--gray-dark);transition:color var(--transition);position:relative;padding-bottom:2px;}
.navbar-nav a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--black);transition:width 0.3s var(--ease-luxury);}
.navbar-nav a:hover{color:var(--black);}
.navbar-nav a:hover::after,.navbar-nav a.active::after{width:100%;}
.navbar-nav a.active{color:var(--black);}
.navbar-cta{font-family:var(--font-head);font-size:0.65rem;font-weight:700;letter-spacing:0.5px;background:var(--black);color:#ffffff !important;padding:8px 18px;border-radius:2px;transition:all 0.3s var(--ease-luxury);}
.navbar-cta:hover{background:var(--black-soft);transform:translateY(-1px);color:#ffffff !important;}
.navbar-cta::after{display:none !important;}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;}
.hamburger span{display:block;width:22px;height:2px;background:var(--black);border-radius:2px;transition:all 0.3s var(--ease-smooth);}

/* SCROLL REVEAL ANIMATIONS */
.reveal{opacity:0;transform:translateY(32px);transition:opacity 1s var(--ease-luxury),transform 1s var(--ease-luxury);}
.reveal.visible{opacity:1;transform:translateY(0);}
.reveal-left{opacity:0;transform:translateX(-32px);transition:opacity 1s var(--ease-luxury),transform 1s var(--ease-luxury);}
.reveal-left.visible{opacity:1;transform:translateX(0);}
.reveal-right{opacity:0;transform:translateX(32px);transition:opacity 1s var(--ease-luxury),transform 1s var(--ease-luxury);}
.reveal-right.visible{opacity:1;transform:translateX(0);}
.reveal-scale{opacity:0;transform:scale(0.94);transition:opacity 1s var(--ease-luxury),transform 1s var(--ease-luxury);}
.reveal-scale.visible{opacity:1;transform:scale(1);}
.delay-1{transition-delay:0.1s;}
.delay-2{transition-delay:0.2s;}
.delay-3{transition-delay:0.3s;}
.delay-4{transition-delay:0.4s;}
.delay-5{transition-delay:0.5s;}

/* PRODUCT CARDS — floating on white */
.prod-card{background:var(--white);border:0.5px solid var(--gray-border);border-radius:4px;overflow:hidden;transition:box-shadow 0.5s var(--ease-luxury),transform 0.5s var(--ease-luxury);}
.prod-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-6px);}
.prod-img-wrap{position:relative;background:var(--white);display:flex;align-items:center;justify-content:center;overflow:hidden;padding:16px;}
.prod-img-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 60%,#f0f4f8 0%,#ffffff 65%);z-index:0;}
.prod-img-wrap img{position:relative;z-index:1;transition:transform 0.8s var(--ease-luxury);mix-blend-mode:multiply;}
.prod-card:hover .prod-img-wrap img{transform:scale(1.07);}
.prod-body{padding:22px 20px;}
.prod-badge{font-family:var(--font-head);font-size:0.55rem;font-weight:700;letter-spacing:0.5px;background:var(--gray-bg2);color:var(--gray-dark);padding:3px 8px;border-radius:2px;display:inline-block;margin-bottom:10px;}
.prod-name{font-family:var(--font-head);font-size:0.88rem;font-weight:800;color:var(--black);line-height:1.3;margin-bottom:8px;}
.prod-desc{font-size:0.72rem;color:var(--gray-mid);line-height:1.75;margin-bottom:12px;font-weight:300;}
.prod-caps{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:14px;}
.prod-cap{font-size:0.6rem;border:0.5px solid var(--gray-border);color:var(--gray-mid);padding:2px 8px;border-radius:2px;font-family:var(--font-head);}
.prod-link{font-family:var(--font-head);font-size:0.68rem;font-weight:700;color:var(--black);display:inline-flex;align-items:center;gap:6px;transition:gap 0.3s var(--ease-luxury);}
.prod-link::after{content:'→';transition:transform 0.3s var(--ease-luxury);}
.prod-card:hover .prod-link{gap:10px;}

/* SPEC TABLE */
.spec-table{width:100%;border-collapse:collapse;font-size:0.75rem;}
.spec-table thead th{background:var(--gray-bg2);padding:10px 16px;font-family:var(--font-head);font-size:0.6rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--black);text-align:left;border-bottom:0.5px solid var(--gray-border);}
.spec-table tbody td{padding:10px 16px;border-bottom:0.5px solid var(--gray-bg2);vertical-align:top;}
.spec-table tbody tr:nth-child(even) td{background:var(--gray-bg);}
.spec-table td:first-child{color:var(--gray-light);width:45%;}
.spec-table td:last-child{color:var(--black);font-weight:600;font-family:var(--font-head);}

/* PULL QUOTE */
.pull-quote{border-left:3px solid var(--blue);padding:18px 20px;background:var(--gray-bg);margin:28px 0;}
.pull-quote p{font-size:0.9rem;color:var(--black);font-style:italic;font-weight:400;}
.pull-quote cite{font-family:var(--font-head);font-size:0.6rem;font-weight:700;letter-spacing:0.5px;color:var(--gray-light);display:block;margin-top:8px;}

/* BREADCRUMB */
.breadcrumb{padding:12px 0;border-bottom:0.5px solid var(--gray-bg2);font-size:0.65rem;color:var(--gray-light);display:flex;align-items:center;gap:6px;}
.breadcrumb a{color:var(--gray-light);transition:color var(--transition);}
.breadcrumb a:hover{color:var(--black);}
.breadcrumb .current{color:var(--black);font-weight:600;}

/* PAGE HEADER */
.page-header{padding:64px 0 48px;border-bottom:0.5px solid var(--gray-bg2);}
.page-header h1{margin-bottom:14px;}
.page-header p{max-width:600px;font-size:0.9rem;}

/* DIVIDER */
.divider{border:none;border-top:0.5px solid var(--gray-border);margin:0;}

/* FORM STYLES */
.form-group{margin-bottom:16px;}
.form-label{display:block;font-family:var(--font-head);font-size:0.65rem;font-weight:700;color:var(--black);margin-bottom:6px;letter-spacing:0.3px;}
.form-control{width:100%;padding:10px 14px;border:0.5px solid var(--gray-border);border-radius:2px;font-family:var(--font-body);font-size:0.8rem;color:var(--black);background:var(--white);transition:border-color 0.3s var(--ease-smooth);outline:none;}
.form-control:focus{border-color:var(--black);}
.form-control::placeholder{color:var(--gray-light);}
textarea.form-control{resize:vertical;min-height:100px;}
select.form-control{cursor:pointer;}

/* NEWS CARD */
.news-card{border:0.5px solid var(--gray-border);border-radius:4px;overflow:hidden;display:flex;flex-direction:column;transition:box-shadow 0.5s var(--ease-luxury),transform 0.5s var(--ease-luxury);}
.news-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px);}
.news-card-img{height:160px;overflow:hidden;background:var(--gray-bg2);}
.news-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.8s var(--ease-luxury);}
.news-card:hover .news-card-img img{transform:scale(1.05);}
.news-card-body{padding:18px 16px;flex:1;display:flex;flex-direction:column;}
.news-card-region{font-family:var(--font-head);font-size:0.55rem;font-weight:700;letter-spacing:0.5px;background:var(--gray-bg2);color:var(--gray-dark);padding:2px 7px;border-radius:2px;display:inline-block;margin-bottom:8px;}
.news-card-title{font-family:var(--font-head);font-size:0.75rem;font-weight:700;color:var(--black);line-height:1.4;margin-bottom:8px;}
.news-card-excerpt{font-size:0.7rem;color:var(--gray-mid);line-height:1.65;flex:1;margin-bottom:12px;font-weight:300;}
.news-card-link{font-family:var(--font-head);font-size:0.65rem;font-weight:700;color:var(--black);border-bottom:1px solid var(--black);padding-bottom:1px;display:inline-block;transition:color 0.2s,border-color 0.2s;}
.news-card-link:hover{color:var(--blue);border-color:var(--blue);}

/* BLOG CARDS */
.blog-card{border:0.5px solid var(--gray-border);border-radius:4px;overflow:hidden;transition:box-shadow 0.5s var(--ease-luxury),transform 0.5s var(--ease-luxury);}
.blog-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px);}
.blog-card-img{height:180px;overflow:hidden;background:var(--gray-bg2);}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.8s var(--ease-luxury);}
.blog-card:hover .blog-card-img img{transform:scale(1.05);}
.blog-card-body{padding:20px 18px;}
.blog-category{font-family:var(--font-head);font-size:0.55rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--blue);margin-bottom:8px;}
.blog-card-title{font-family:var(--font-head);font-size:0.85rem;font-weight:700;color:var(--black);line-height:1.4;margin-bottom:8px;}
.blog-card-excerpt{font-size:0.72rem;color:var(--gray-mid);line-height:1.7;margin-bottom:14px;font-weight:300;}
.blog-card-meta{display:flex;align-items:center;justify-content:space-between;border-top:0.5px solid var(--gray-bg2);padding-top:12px;}
.blog-card-meta span{font-size:0.6rem;color:var(--gray-light);}
.blog-read-link{font-family:var(--font-head);font-size:0.65rem;font-weight:700;color:var(--black);border-bottom:1px solid var(--black);padding-bottom:1px;}

/* CTA BAND */
.cta-band{background:var(--black);padding:64px 0;}
.cta-band-inner{display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;}
.cta-band h2{color:var(--white);}
.cta-band p{color:rgba(255,255,255,0.5);font-weight:300;max-width:480px;margin-top:8px;}
.cta-band-btns{display:flex;gap:12px;flex-shrink:0;}

/* FOOTER */
.footer{background:#0B1929;padding:56px 0 0;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:40px;padding-bottom:40px;border-bottom:0.5px solid rgba(255,255,255,0.08);}
.footer-brand p{font-size:0.75rem;color:rgba(255,255,255,0.35);line-height:1.75;margin-top:10px;}
.footer-col-title{font-family:var(--font-head);font-size:0.55rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.4);margin-bottom:14px;}
.footer-links{display:flex;flex-direction:column;gap:8px;}
.footer-links a{font-size:0.75rem;color:rgba(255,255,255,0.35);transition:color var(--transition);}
.footer-links a:hover{color:rgba(255,255,255,0.7);}
.footer-contact-item{font-size:0.75rem;color:rgba(255,255,255,0.35);line-height:1.9;}
.footer-social{display:flex;gap:10px;margin-top:14px;}
.footer-social a{width:32px;height:32px;border:0.5px solid rgba(255,255,255,0.15);border-radius:2px;display:flex;align-items:center;justify-content:center;transition:border-color var(--transition),transform 0.3s var(--ease-luxury);}
.footer-social a:hover{border-color:rgba(255,255,255,0.5);transform:translateY(-2px);}
.footer-social svg{width:14px;height:14px;fill:rgba(255,255,255,0.4);}
.footer-bottom{padding:16px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;}
.footer-bottom span{font-size:0.65rem;color:rgba(255,255,255,0.2);}
.footer-bottom a{font-size:0.65rem;color:rgba(255,255,255,0.2);margin-left:16px;}
.footer-bottom a:hover{color:rgba(255,255,255,0.5);}
.footer-logo{height:36px;width:auto;margin-bottom:10px;}

/* CREDENTIALS STRIP */
.creds-strip{display:grid;grid-template-columns:repeat(6,1fr);border-top:0.5px solid var(--gray-border);border-bottom:0.5px solid var(--gray-border);}
.cred-item{padding:18px 20px;border-right:0.5px solid var(--gray-border);}
.cred-item:last-child{border-right:none;}
.cred-item .value{font-family:var(--font-head);font-size:0.7rem;font-weight:700;color:var(--black);}
.cred-item .desc{font-size:0.65rem;color:var(--gray-light);margin-top:2px;}

/* STAT BLOCKS */
.stat-num{font-family:var(--font-head);font-size:2rem;font-weight:800;color:var(--black);line-height:1;}
.stat-num span{font-size:1.1rem;color:var(--blue);}
.stat-label{font-size:0.7rem;color:var(--gray-light);margin-top:4px;}

/* CLIENT LOGO CHIPS */
.client-chip{border:0.5px solid var(--gray-border);border-radius:3px;padding:10px 18px;font-family:var(--font-head);font-size:0.72rem;font-weight:600;color:var(--gray-dark);transition:all 0.3s var(--ease-luxury);display:flex;align-items:center;gap:8px;}
.client-chip:hover{border-color:var(--black);color:var(--black);transform:translateY(-2px);box-shadow:var(--shadow-sm);}
.client-chip img{height:24px;width:auto;object-fit:contain;}

/* CLIENT LOGO IMAGES */
.client-logo-img{height:32px;width:auto;max-width:100px;object-fit:contain;filter:grayscale(100%);opacity:0.6;transition:filter 0.4s var(--ease-luxury),opacity 0.4s var(--ease-luxury),transform 0.4s var(--ease-luxury);}
.client-logo-img:hover{filter:grayscale(0%);opacity:1;transform:scale(1.08);}

/* GALLERY */
.gallery-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:28px;}
.gallery-filter{font-family:var(--font-head);font-size:0.65rem;font-weight:700;letter-spacing:0.5px;padding:7px 16px;border-radius:2px;cursor:pointer;transition:all 0.3s var(--ease-luxury);border:0.5px solid var(--gray-border);color:var(--gray-mid);background:var(--white);}
.gallery-filter.active,.gallery-filter:hover{background:var(--black);color:var(--white);border-color:var(--black);}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;}
.gallery-item{position:relative;overflow:hidden;background:var(--gray-bg2);aspect-ratio:4/3;cursor:pointer;}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.8s var(--ease-luxury);}
.gallery-item:hover img{transform:scale(1.06);}
.gallery-item-label{position:absolute;bottom:0;left:0;right:0;background:var(--black);color:rgba(255,255,255,0.6);font-size:0.6rem;padding:7px 10px;font-family:var(--font-head);font-weight:600;transform:translateY(100%);transition:transform 0.4s var(--ease-luxury);}
.gallery-item:hover .gallery-item-label{transform:translateY(0);}

/* VIDEO PLAYER */
.video-wrap{position:relative;border-radius:4px;overflow:hidden;background:var(--black);}
.video-wrap video{width:100%;display:block;}
.video-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.3);transition:background 0.3s var(--ease-smooth);cursor:pointer;}
.video-overlay:hover{background:rgba(0,0,0,0.15);}
.play-btn{width:56px;height:56px;background:rgba(255,255,255,0.9);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:transform 0.3s var(--ease-luxury),background 0.3s;}
.play-btn:hover{transform:scale(1.1);background:white;}
.play-btn svg{width:20px;height:20px;fill:var(--black);margin-left:3px;}

/* ARTICLE PAGE */
.article-layout{display:grid;grid-template-columns:1fr 300px;gap:0;align-items:start;}
.article-content{padding:48px 40px 80px 0;border-right:0.5px solid var(--gray-border);}
.article-sidebar{padding:48px 0 80px 28px;}
.article-standfirst{font-size:0.95rem;color:var(--gray-dark);line-height:1.85;border-left:3px solid var(--black);padding-left:18px;margin-bottom:28px;font-weight:400;}
.article-hero{width:100%;height:320px;object-fit:cover;border-radius:3px;margin-bottom:32px;}
.article-body h2{font-size:1.1rem;margin:32px 0 14px;}
.article-body p{font-size:0.82rem;color:var(--gray-dark);line-height:1.9;margin-bottom:18px;font-weight:300;}
.article-body sup{font-size:0.6rem;color:var(--blue);font-weight:700;}
.article-references{border-top:0.5px solid var(--gray-border);padding-top:24px;margin-top:40px;}
.article-references-title{font-family:var(--font-head);font-size:0.6rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--black);margin-bottom:12px;}
.article-ref{font-size:0.65rem;color:var(--gray-mid);line-height:1.6;margin-bottom:6px;}
.article-ref span{color:var(--blue);font-weight:700;}
.sidebar-section{margin-bottom:24px;}
.sidebar-title{font-family:var(--font-head);font-size:0.55rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--gray-light);margin-bottom:12px;}
.sidebar-card{border:0.5px solid var(--gray-border);border-radius:3px;padding:16px;}
.toc-link{font-size:0.72rem;padding:5px 0 5px 10px;border-left:2px solid var(--gray-border);color:var(--gray-mid);display:block;transition:all 0.3s;margin-bottom:4px;}
.toc-link:hover,.toc-link.active{border-left-color:var(--blue);color:var(--gray-dark);}

/* LIGHTBOX */
.lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.92);z-index:9999;align-items:center;justify-content:center;}
.lightbox.open{display:flex;}
.lightbox-inner{position:relative;max-width:90vw;max-height:90vh;}
.lightbox-inner video{max-width:100%;max-height:85vh;border-radius:4px;}
.lightbox-close{position:absolute;top:-40px;right:0;color:rgba(255,255,255,0.6);font-size:24px;cursor:pointer;font-family:var(--font-head);font-weight:300;transition:color 0.2s;}
.lightbox-close:hover{color:white;}

/* UTILITY */
.text-blue{color:var(--blue);}
.text-muted{color:var(--gray-mid);}
.text-center{text-align:center;}
.gap-grid-1{display:grid;gap:1px;background:var(--gray-border);border:0.5px solid var(--gray-border);border-radius:3px;overflow:hidden;}
.gap-grid-1>*{background:var(--white);}

/* RESPONSIVE */
@media(max-width:1024px){
  .container{padding:0 24px;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .creds-strip{grid-template-columns:repeat(3,1fr);}
}
@media(max-width:768px){
  .navbar-nav{display:none;}
  .hamburger{display:flex;}
  .navbar-nav.open{display:flex;flex-direction:column;position:absolute;top:68px;left:0;right:0;background:var(--white);border-bottom:0.5px solid var(--gray-border);padding:20px 24px;gap:16px;z-index:999;}
  .navbar-cta{display:none;}
  .article-layout{grid-template-columns:1fr;}
  .article-sidebar{padding:0 0 40px;border-top:0.5px solid var(--gray-border);}
  .article-content{border-right:none;padding-right:0;}
  .footer-grid{grid-template-columns:1fr;gap:28px;}
  .cta-band-inner{flex-direction:column;align-items:flex-start;}
  .gallery-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:480px){
  h1{font-size:1.6rem;}
  h2{font-size:1.3rem;}
  .section{padding:48px 0;}
  .creds-strip{grid-template-columns:repeat(2,1fr);}
  .gallery-grid{grid-template-columns:1fr;}
}

/* ============================================
   ANIMATIONS V2 — Premium site-wide motion
   ============================================ */

/* Base reveal states */
.reveal-up{opacity:0;transform:translateY(28px);transition:opacity 0.9s cubic-bezier(0.16,1,0.3,1),transform 0.9s cubic-bezier(0.16,1,0.3,1);}
.reveal-up.visible{opacity:1;transform:translateY(0);}

/* CINEMATIC REVEAL — curtain wipe */
.cinematic-reveal{position:relative;overflow:hidden;}
.cinematic-reveal::after{content:'';position:absolute;inset:0;background:#111827;transform:translateX(0%);transition:transform 1.1s cubic-bezier(0.77,0,0.18,1);z-index:2;transform-origin:left center;pointer-events:none;}
.cinematic-reveal.cinematic-revealed::after{transform:translateX(102%);}
.cinematic-reveal img,.cinematic-reveal video{transform:scale(1.06);transition:transform 1.4s cubic-bezier(0.16,1,0.3,1);}
.cinematic-reveal.cinematic-revealed img,.cinematic-reveal.cinematic-revealed video{transform:scale(1);}
.cinematic-reveal.delay-c1::after{transition-delay:0s;}
.cinematic-reveal.delay-c2::after{transition-delay:0.18s;}
.cinematic-reveal.delay-c3::after{transition-delay:0.36s;}
.cinematic-reveal.delay-c4::after{transition-delay:0.54s;}
.cinematic-reveal.delay-c1 img,.cinematic-reveal.delay-c1 video{transition-delay:0.05s;}
.cinematic-reveal.delay-c2 img,.cinematic-reveal.delay-c2 video{transition-delay:0.23s;}
.cinematic-reveal.delay-c3 img,.cinematic-reveal.delay-c3 video{transition-delay:0.41s;}
.cinematic-reveal.delay-c4 img,.cinematic-reveal.delay-c4 video{transition-delay:0.59s;}

/* TIMELINE DRAW */
.timeline-line{width:0;height:1px;background:#E5E7EB;transition:width 1.2s cubic-bezier(0.16,1,0.3,1) 0.3s;}
.timeline-line.timeline-active{width:100%;}

/* COUNT-UP — handled by JS, just style the element */
[data-target]{display:inline-block;}

/* HOVER effects on cards */
.prod-card,.news-card,.blog-card,.mini-product,.cert-card,.facility-card{will-change:transform;}

/* Stagger grid items */
.stagger-children > *{opacity:0;transform:translateY(20px);transition:opacity 0.7s cubic-bezier(0.16,1,0.3,1),transform 0.7s cubic-bezier(0.16,1,0.3,1);}
.stagger-children > *.visible{opacity:1;transform:translateY(0);}

/* LOGO STRIP — scroll-triggered grayscale to color */
.client-logo-img{opacity:0;transition:opacity 0.6s ease,filter 0.4s ease,transform 0.4s cubic-bezier(0.16,1,0.3,1);}
.client-logo-img.visible{opacity:0.55;}
.client-logo-img.visible:hover{opacity:1;filter:grayscale(0%);transform:scale(1.08);}

/* SVG CLIENT LOGOS */
.svg-logo{display:inline-flex;align-items:center;justify-content:center;padding:10px 16px;border:0.5px solid #E5E7EB;border-radius:3px;transition:all 0.4s cubic-bezier(0.16,1,0.3,1);cursor:default;opacity:0;transform:translateY(8px);}
.svg-logo.visible{opacity:1;transform:translateY(0);}
.svg-logo:hover{border-color:#111827;transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.08);}
.svg-logo svg{transition:all 0.4s ease;}

/* WORLD MAP */
.map-region{transition:opacity 0.4s ease,fill 0.4s ease;}
.map-region:hover{opacity:0.85;cursor:pointer;}
.map-tooltip{position:absolute;background:#111827;color:#fff;font-family:'Montserrat',sans-serif;font-size:0.6rem;font-weight:700;padding:5px 10px;border-radius:2px;pointer-events:none;opacity:0;transition:opacity 0.2s;white-space:nowrap;z-index:10;}
