/* ==============================================
   EASYSTEPS LOGISTICS – Premium CSS v2.0
   Fonts: Syne (headings) + Nunito (body)
================================================ */

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

:root {
  --primary:    #0d2b4e;
  --primary-d:  #081b30;
  --secondary:  #e8521a;
  --sec-dark:   #c03e0e;
  --accent:     #f4a623;
  --light:      #f7f3ee;
  --white:      #ffffff;
  --dark:       #0a1929;
  --gray:       #64748b;
  --border:     #e5ddd4;
  --shadow:     0 8px 40px rgba(13,43,78,.10);
  --shadow-lg:  0 24px 64px rgba(13,43,78,.16);
  --radius:     14px;
  --tr:         .32s cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Nunito',sans-serif;background:var(--light);color:var(--dark);line-height:1.75;overflow-x:hidden;}
h1,h2,h3,h4,h5{font-family:'Syne',sans-serif;line-height:1.18;}
a{text-decoration:none;color:inherit;}
img{max-width:100%;display:block;}
ul{list-style:none;}
button{cursor:pointer;font-family:'Nunito',sans-serif;}

.container{max-width:1200px;margin:0 auto;padding:0 24px;}
.section-pad{padding:96px 0;}
.text-center{text-align:center;}

.btn{display:inline-flex;align-items:center;gap:9px;padding:14px 32px;border-radius:60px;font-family:'Nunito',sans-serif;font-weight:700;font-size:15px;border:2px solid transparent;cursor:pointer;transition:var(--tr);white-space:nowrap;}
.btn-primary{background:var(--secondary);color:#fff;border-color:var(--secondary);}
.btn-primary:hover{background:var(--sec-dark);border-color:var(--sec-dark);transform:translateY(-2px);box-shadow:0 10px 28px rgba(232,82,26,.36);}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.7);}
.btn-outline:hover{background:#fff;color:var(--secondary);border-color:#fff;}
.btn-ghost{background:var(--light);color:var(--primary);border-color:var(--border);}
.btn-ghost:hover{background:var(--primary);color:#fff;border-color:var(--primary);}
.btn-white{background:#fff;color:var(--secondary);border-color:#fff;font-weight:700;}
.btn-white:hover{background:transparent;color:#fff;}

.section-tag{display:inline-flex;align-items:center;gap:7px;background:rgba(232,82,26,.1);color:var(--secondary);font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:5px 14px;border-radius:60px;margin-bottom:14px;}
.section-title{font-size:clamp(26px,3.8vw,44px);color:var(--primary);margin-bottom:14px;}
.section-sub{color:var(--gray);font-size:17px;max-width:560px;font-weight:400;}

/* TOPBAR */
.topbar{background:var(--primary-d);color:rgba(255,255,255,.82);font-size:13px;font-weight:500;padding:9px 0;}
.topbar .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;}
.topbar a{color:rgba(255,255,255,.82);transition:color var(--tr);}
.topbar a:hover{color:var(--accent);}
.topbar-item{display:flex;align-items:center;gap:7px;}
.topbar-left,.topbar-right{display:flex;gap:22px;align-items:center;}
.topbar-icon{width:16px;height:16px;flex-shrink:0;color:var(--accent);}

/* HEADER */
header{background:#fff;box-shadow:0 2px 20px rgba(0,0,0,.06);position:sticky;top:0;z-index:998;}
.navbar{display:flex;align-items:center;justify-content:space-between;padding:13px 0;}
.logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0;}
.logo-img{
  height: 52px;
  width: auto;
  max-width: 210px;
  object-fit: contain;
  display: block;
  /* Sharp rendering on Retina / OLED */
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  transform: translateZ(0);
  image-rendering: -webkit-optimize-contrast;
}
.nav-links{display:flex;align-items:center;gap:2px;}
.nav-links > li > a{padding:8px 13px;border-radius:8px;font-size:14px;font-weight:600;color:var(--dark);transition:var(--tr);display:flex;align-items:center;gap:5px;}
.nav-links > li > a:hover,.nav-links > li > a.active{background:var(--primary);color:#fff;}
.chevron-down{width:12px;height:12px;transition:transform var(--tr);}
.has-dropdown{position:relative;}
.has-dropdown:hover .chevron-down{transform:rotate(180deg);}
.dropdown{display:none;position:absolute;top:calc(100% + 8px);left:0;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:235px;overflow:hidden;z-index:100;border:1px solid var(--border);}
.dropdown a{display:flex;align-items:center;gap:10px;padding:11px 16px;font-size:14px;font-weight:600;color:var(--dark);border-bottom:1px solid var(--border);transition:var(--tr);}
.dropdown a:last-child{border-bottom:none;}
.dropdown a:hover{background:var(--light);color:var(--secondary);padding-left:22px;}
.has-dropdown:hover .dropdown{display:block;}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:5px;}
.hamburger span{width:24px;height:2.5px;background:var(--primary);border-radius:3px;transition:var(--tr);}

/* HERO */
.hero{background:linear-gradient(135deg,var(--primary) 0%,#0a1e38 55%,#132e4e 100%);min-height:90vh;display:flex;align-items:center;position:relative;overflow:hidden;}
.hero-bg-pattern{position:absolute;inset:0;background-image:radial-gradient(circle at 70% 20%,rgba(244,166,35,.09) 0%,transparent 50%),radial-gradient(circle at 15% 80%,rgba(232,82,26,.08) 0%,transparent 45%);pointer-events:none;}
.hero-grid-lines{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:60px 60px;pointer-events:none;}
.hero .container{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center;}
.hero-content{animation:fadeInUp .8s ease both;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(244,166,35,.15);border:1px solid rgba(244,166,35,.3);color:var(--accent);padding:7px 16px;border-radius:60px;font-size:13px;font-weight:700;margin-bottom:22px;letter-spacing:.5px;}
.hero h1{font-size:clamp(36px,5.2vw,64px);color:#fff;margin-bottom:20px;line-height:1.1;}
.hero h1 span{color:var(--accent);}
.hero-desc{color:rgba(255,255,255,.75);font-size:18px;margin-bottom:34px;max-width:500px;font-weight:400;}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;}
.hero-trust{display:flex;gap:28px;margin-top:44px;padding-top:28px;border-top:1px solid rgba(255,255,255,.1);flex-wrap:wrap;}
.trust-item{display:flex;align-items:center;gap:10px;}
.trust-icon{width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.trust-icon svg{width:20px;height:20px;color:var(--accent);}
.trust-text .num{font-family:'Syne',sans-serif;font-size:22px;font-weight:800;color:#fff;line-height:1;}
.trust-text .lbl{font-size:12px;color:rgba(255,255,255,.55);margin-top:2px;}
.hero-visual{animation:fadeInRight .9s .2s ease both;}
.hero-cards{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.hero-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:22px 18px;text-align:center;backdrop-filter:blur(8px);transition:var(--tr);}
.hero-card:hover{background:rgba(255,255,255,.13);transform:translateY(-5px);}
.hero-card-icon{width:52px;height:52px;border-radius:12px;margin:0 auto 12px;background:rgba(244,166,35,.15);display:flex;align-items:center;justify-content:center;}
.hero-card-icon svg{width:28px;height:28px;color:var(--accent);}
.hero-card h4{color:#fff;font-family:'Nunito',sans-serif;font-size:13px;font-weight:700;}

/* MARQUEE */
.marquee-bar{background:var(--secondary);padding:13px 0;overflow:hidden;}
.marquee-track{display:inline-flex;animation:marquee 22s linear infinite;align-items:center;}
.marquee-item{display:flex;align-items:center;gap:10px;color:#fff;font-weight:700;font-size:13.5px;letter-spacing:.5px;padding:0 22px;white-space:nowrap;}
.marquee-item svg{width:15px;height:15px;color:rgba(255,255,255,.8);flex-shrink:0;}
.marquee-dot{width:5px;height:5px;background:rgba(255,255,255,.45);border-radius:50%;flex-shrink:0;}

/* WHY US */
.why-us{background:#fff;}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center;}
.why-img-wrap{position:relative;}
.why-img{border-radius:22px;width:100%;height:500px;object-fit:cover;}
.why-badge-card{position:absolute;bottom:-24px;right:-24px;background:var(--secondary);color:#fff;padding:22px 28px;border-radius:18px;box-shadow:var(--shadow-lg);text-align:center;}
.why-badge-card .big{font-family:'Syne',sans-serif;font-size:44px;font-weight:800;line-height:1;}
.why-badge-card .small{font-size:13px;font-weight:600;opacity:.9;}
.why-features{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:30px;}
.why-feat{display:flex;gap:12px;align-items:flex-start;padding:16px;background:var(--light);border-radius:var(--radius);transition:var(--tr);border:1px solid transparent;}
.why-feat:hover{background:var(--primary);border-color:var(--primary);}
.why-feat:hover .wf-title{color:#fff;}
.why-feat:hover .wf-text{color:rgba(255,255,255,.7);}
.why-feat:hover .wf-icon{background:rgba(255,255,255,.15);}
.why-feat:hover .wf-icon svg{color:#fff;}
.wf-icon{width:42px;height:42px;border-radius:10px;background:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 8px rgba(0,0,0,.06);transition:var(--tr);}
.wf-icon svg{width:22px;height:22px;color:var(--secondary);}
.wf-title{font-family:'Nunito',sans-serif;font-weight:700;font-size:14px;color:var(--primary);margin-bottom:3px;transition:var(--tr);}
.wf-text{font-size:12.5px;color:var(--gray);line-height:1.6;transition:var(--tr);}

/* SERVICES */
.services{background:var(--light);}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px;}
.service-card{background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.05);transition:var(--tr);border:1px solid var(--border);}
.service-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:var(--secondary);}
.service-icon-band{background:linear-gradient(135deg,var(--primary),#0a1e38);padding:32px;text-align:center;position:relative;overflow:hidden;}
.service-icon-band::after{content:'';position:absolute;bottom:-30px;right:-30px;width:90px;height:90px;border-radius:50%;background:rgba(244,166,35,.12);}
.s-icon{width:68px;height:68px;border-radius:18px;margin:0 auto;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;}
.s-icon svg{width:36px;height:36px;color:var(--accent);}
.service-body{padding:24px;}
.service-body h3{font-family:'Nunito',sans-serif;font-weight:700;font-size:18px;color:var(--primary);margin-bottom:9px;}
.service-body p{color:var(--gray);font-size:14px;margin-bottom:18px;line-height:1.7;}
.srv-link{display:inline-flex;align-items:center;gap:6px;color:var(--secondary);font-weight:700;font-size:14px;transition:var(--tr);}
.srv-link svg{width:16px;height:16px;transition:transform var(--tr);}
.srv-link:hover svg{transform:translateX(3px);}

/* PROCESS */
.process{background:var(--primary);}
.process .section-tag{background:rgba(244,166,35,.2);color:var(--accent);}
.process .section-title{color:#fff;}
.process .section-sub{color:rgba(255,255,255,.6);}
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:52px;}
.step-card{text-align:center;position:relative;}
.step-card::after{content:'';position:absolute;top:30px;right:-20px;width:40px;height:2px;background:linear-gradient(90deg,rgba(244,166,35,.6),transparent);}
.step-card:last-child::after{display:none;}
.step-num{width:62px;height:62px;border-radius:50%;margin:0 auto 18px;background:rgba(244,166,35,.12);border:2px solid rgba(244,166,35,.4);display:flex;align-items:center;justify-content:center;}
.step-num svg{width:28px;height:28px;color:var(--accent);}
.step-card h4{color:#fff;font-family:'Nunito',sans-serif;font-weight:700;font-size:16px;margin-bottom:9px;}
.step-card p{color:rgba(255,255,255,.58);font-size:13px;}

/* TESTIMONIALS */
.testimonials{background:#fff;}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:46px;}
.testi-card{background:var(--light);border-radius:18px;padding:28px;border:1px solid var(--border);transition:var(--tr);position:relative;overflow:hidden;}
.testi-card::before{content:'"';font-family:'Syne',sans-serif;font-size:100px;font-weight:800;color:var(--secondary);opacity:.08;position:absolute;top:5px;left:14px;line-height:1;}
.testi-card:hover{border-color:var(--secondary);transform:translateY(-4px);box-shadow:var(--shadow);}
.stars{display:flex;gap:3px;margin-bottom:12px;}
.stars svg{width:16px !important;height:16px !important;min-width:16px;min-height:16px;color:var(--accent);flex-shrink:0;}
.testi-card p{color:var(--gray);font-size:15px;font-style:italic;margin-bottom:20px;position:relative;z-index:1;}
.testi-author{display:flex;align-items:center;gap:12px;}
.testi-av{width:46px;height:46px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--primary),var(--secondary));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:17px;font-family:'Syne',sans-serif;}
.testi-author h5{font-family:'Nunito',sans-serif;font-weight:700;font-size:15px;color:var(--primary);margin-bottom:1px;}
.testi-author span{font-size:12px;color:var(--gray);}

/* Google Rating Bar */
.google-rating-bar{display:inline-flex;align-items:center;gap:10px;background:#fff;border:1.5px solid #e2e8f0;border-radius:60px;padding:10px 22px;margin-top:18px;box-shadow:0 2px 12px rgba(0,0,0,.07);}
.google-stars{display:flex;gap:2px;}
.google-stars svg{width:17px !important;height:17px !important;min-width:17px;min-height:17px;flex-shrink:0;}
.google-score{font-size:18px;font-weight:800;color:var(--primary);font-family:'Syne',sans-serif;}
.google-count{font-size:13px;color:var(--gray);font-weight:600;}

/* Google Review CTA */
.google-review-cta{margin-top:44px;}
.google-review-cta-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;background:linear-gradient(135deg,#f8faff 0%,#eef2ff 100%);border:1.5px solid #c7d7ff;border-radius:18px;padding:24px 32px;}
.google-review-cta-text{display:flex;align-items:center;gap:16px;}
.google-review-cta-text div{display:flex;flex-direction:column;}
.google-review-cta-text strong{font-size:16px;font-weight:800;color:var(--primary);font-family:'Syne',sans-serif;}
.google-review-cta-text span{font-size:13px;color:var(--gray);margin-top:2px;}
.btn-google-review{display:inline-flex;align-items:center;gap:9px;background:#fff;color:var(--primary);border:2px solid #4285F4;border-radius:60px;padding:12px 24px;font-family:'Nunito',sans-serif;font-size:15px;font-weight:700;text-decoration:none;transition:var(--tr);white-space:nowrap;box-shadow:0 4px 14px rgba(66,133,244,.18);}
.btn-google-review:hover{background:#4285F4;color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px rgba(66,133,244,.35);}
.btn-google-review:hover svg path{fill:#fff !important;}

/* CTA BANNER */
.cta-banner{background:linear-gradient(135deg,var(--secondary),#c03e0e);padding:90px 0;text-align:center;position:relative;overflow:hidden;}
.cta-banner::before{content:'';position:absolute;width:500px;height:500px;background:rgba(255,255,255,.04);top:-200px;left:-100px;border-radius:50%;}
.cta-banner::after{content:'';position:absolute;width:400px;height:400px;background:rgba(255,255,255,.04);bottom:-180px;right:-80px;border-radius:50%;}
.cta-inner{position:relative;z-index:2;}
.cta-banner h2{color:#fff;font-size:clamp(28px,4vw,50px);margin-bottom:14px;}
.cta-banner p{color:rgba(255,255,255,.88);font-size:18px;margin-bottom:34px;}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* FOOTER */
footer{background:var(--dark);color:rgba(255,255,255,.72);padding:80px 0 0;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.6fr;gap:40px;}

.footer-brand p{font-size:14px;line-height:1.85;max-width:290px;}
.footer-socials{display:flex;gap:10px;margin-top:24px;}
.soc-btn{width:38px;height:38px;border-radius:9px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;transition:var(--tr);}
.soc-btn svg{width:18px;height:18px;color:rgba(255,255,255,.7);}
.soc-btn:hover{background:var(--secondary);}
.soc-btn:hover svg{color:#fff;}
.footer-col h4{font-family:'Nunito',sans-serif;font-weight:700;font-size:15px;color:#fff;margin-bottom:20px;}
.footer-col ul li{margin-bottom:10px;}
.footer-col ul li a{font-size:14px;color:rgba(255,255,255,.62);transition:var(--tr);}
.footer-col ul li a:hover{color:var(--accent);padding-left:5px;}
.footer-contact li{display:flex;gap:11px;font-size:14px;margin-bottom:14px;align-items:flex-start;}
.fc-icon{width:20px;height:20px;flex-shrink:0;margin-top:1px;}
.fc-icon svg{width:20px;height:20px;color:var(--accent);}
.footer-contact a{color:rgba(255,255,255,.72);transition:var(--tr);}
.footer-contact a:hover{color:var(--accent);}
.footer-bottom{margin-top:60px;padding:20px 0;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center;font-size:13px;flex-wrap:wrap;gap:10px;}
.footer-bottom a{color:rgba(255,255,255,.45);}
.footer-bottom a:hover{color:var(--accent);}

/* PAGE HERO */
.page-hero{background:linear-gradient(135deg,var(--primary),#0a1e38);padding:78px 0;text-align:center;}
.page-hero h1{color:#fff;margin-bottom:12px;}
.breadcrumb{display:flex;justify-content:center;gap:8px;font-size:14px;color:rgba(255,255,255,.55);align-items:center;}
.breadcrumb a{color:rgba(255,255,255,.55);}
.breadcrumb a:hover{color:var(--accent);}
.breadcrumb svg{width:12px;height:12px;}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1.55fr;gap:60px;margin-top:52px;}
.contact-box{display:flex;gap:16px;margin-bottom:22px;}
.cb-icon{width:52px;height:52px;border-radius:13px;background:var(--primary);flex-shrink:0;display:flex;align-items:center;justify-content:center;}
.cb-icon svg{width:24px;height:24px;color:#fff;}
.cb-title{font-family:'Nunito',sans-serif;font-weight:700;color:var(--primary);font-size:15px;margin-bottom:4px;}
.cb-val{color:var(--gray);font-size:14px;}
.cb-val a{color:var(--gray);transition:var(--tr);}
.cb-val a:hover{color:var(--secondary);}
.map-wrap{border-radius:16px;overflow:hidden;margin-top:24px;border:2px solid var(--border);}
.contact-form-wrap{background:#fff;padding:40px;border-radius:22px;box-shadow:var(--shadow);}
.contact-form-wrap h3{color:var(--primary);font-size:24px;margin-bottom:28px;}
.form-group{margin-bottom:18px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-group label{display:block;font-size:13px;font-weight:700;color:var(--primary);margin-bottom:6px;letter-spacing:.3px;}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:13px 16px;border:2px solid var(--border);border-radius:10px;font-family:'Nunito',sans-serif;font-size:14px;color:var(--dark);background:var(--light);transition:var(--tr);outline:none;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);background:#fff;}
.form-group textarea{resize:vertical;min-height:110px;}

/* GALLERY */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:46px;}
.gallery-item{border-radius:14px;overflow:hidden;aspect-ratio:4/3;cursor:pointer;position:relative;}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease;}
.gallery-item:hover img{transform:scale(1.08);}
.gallery-overlay{position:absolute;inset:0;background:rgba(13,43,78,.6);display:flex;align-items:center;justify-content:center;opacity:0;transition:var(--tr);}
.gallery-overlay svg{width:40px;height:40px;color:#fff;}
.gallery-item:hover .gallery-overlay{opacity:1;}

/* ABOUT */
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px;}
.value-card{padding:32px 24px;background:#fff;border-radius:18px;text-align:center;border:1px solid var(--border);transition:var(--tr);}
.value-card:hover{border-color:var(--primary);box-shadow:var(--shadow);}
.vc-icon{width:68px;height:68px;border-radius:16px;margin:0 auto 18px;background:var(--light);display:flex;align-items:center;justify-content:center;}
.vc-icon svg{width:34px;height:34px;color:var(--secondary);}
.value-card h3{font-family:'Nunito',sans-serif;font-weight:700;font-size:18px;color:var(--primary);margin-bottom:9px;}
.value-card p{color:var(--gray);font-size:14px;}

/* SERVICE DETAIL */
.service-detail{background:#fff;}
.service-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start;}
.service-features-list li{display:flex;gap:12px;margin-bottom:13px;align-items:flex-start;font-size:15px;color:var(--dark);}
.check-icon{width:22px;height:22px;flex-shrink:0;margin-top:1px;}
.check-icon svg{width:22px;height:22px;color:var(--secondary);}
.service-sidebar{background:var(--light);padding:26px;border-radius:var(--radius);border:1px solid var(--border);}
.service-sidebar h4{color:var(--primary);font-size:16px;margin-bottom:14px;padding-bottom:10px;border-bottom:2px solid var(--secondary);}
.sidebar-link{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border);font-size:14px;color:var(--dark);font-weight:600;transition:var(--tr);}
.sidebar-link:hover{color:var(--secondary);padding-left:4px;}
.sidebar-link:last-child{border-bottom:none;}
.sidebar-link svg{width:14px;height:14px;color:var(--gray);}

/* POLICY */
.policy-content{background:#fff;padding:80px 0;}
.policy-content .container{max-width:840px;}
.policy-content h2{font-size:24px;color:var(--primary);margin:36px 0 13px;}
.policy-content p{color:var(--gray);font-size:15px;margin-bottom:15px;line-height:1.85;}
.policy-content ul{margin:10px 0 18px 22px;list-style:disc;}
.policy-content ul li{color:var(--gray);font-size:15px;margin-bottom:7px;}

/* FLOATING BUTTONS */
.float-cta{position:fixed;bottom:24px;right:24px;z-index:997;display:flex;flex-direction:column;gap:10px;}
.float-btn{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);cursor:pointer;transition:var(--tr);text-decoration:none;border:none;}
.float-btn svg{width:26px;height:26px;}
.float-btn:hover{transform:scale(1.12);}
.float-wa{background:#25d366;}
.float-wa svg{color:#fff;}
.float-call{background:var(--secondary);}
.float-call svg{color:#fff;}
.back-top{background:var(--primary);}
.back-top svg{color:#fff;}

/* POPUP MODAL */
.popup-overlay{position:fixed;inset:0;background:rgba(10,25,41,.78);z-index:9999;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .4s ease,visibility .4s ease;padding:20px;}
.popup-overlay.active{opacity:1;visibility:visible;}
.popup-modal{background:#fff;border-radius:24px;overflow:hidden;width:100%;max-width:620px;box-shadow:0 32px 80px rgba(0,0,0,.3);transform:translateY(30px) scale(.96);transition:transform .4s cubic-bezier(.34,1.56,.64,1);position:relative;}
.popup-overlay.active .popup-modal{transform:translateY(0) scale(1);}
.popup-header{background:linear-gradient(135deg,var(--primary),#0a1e38);padding:24px 28px 20px;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;}
.popup-header-text{flex:1;}
.popup-header h2{color:#fff;font-size:20px;margin-bottom:4px;}
.popup-header p{color:rgba(255,255,255,.72);font-size:13px;margin:0;}
.popup-badge{display:inline-block;background:var(--accent);color:var(--primary);padding:3px 10px;border-radius:60px;font-size:11px;font-weight:700;margin-bottom:6px;}
.popup-close{flex-shrink:0;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.15);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--tr);margin-top:2px;}
.popup-close svg{width:16px;height:16px;color:#fff;}
.popup-close:hover{background:rgba(255,255,255,.28);}
.popup-body{padding:22px 28px 26px;}
.popup-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.popup-form .form-group{margin-bottom:14px;}
.popup-form label{display:block;font-size:12px;font-weight:700;color:var(--primary);margin-bottom:5px;letter-spacing:.3px;text-transform:uppercase;}
.popup-form input,.popup-form select{width:100%;padding:12px 14px;border:2px solid var(--border);border-radius:9px;font-family:'Nunito',sans-serif;font-size:14px;background:var(--light);color:var(--dark);outline:none;transition:var(--tr);}
.popup-form input:focus,.popup-form select:focus{border-color:var(--primary);background:#fff;}
.popup-submit{width:100%;padding:15px;background:var(--secondary);color:#fff;border:none;border-radius:60px;font-family:'Nunito',sans-serif;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:9px;transition:var(--tr);margin-top:6px;}
.popup-submit svg{width:18px;height:18px;}
.popup-submit:hover{background:var(--sec-dark);transform:translateY(-2px);box-shadow:0 8px 24px rgba(232,82,26,.35);}
.popup-footer{text-align:center;margin-top:10px;font-size:13px;color:var(--gray);}
.popup-footer a{color:var(--secondary);font-weight:700;}
.popup-msg{display:none;text-align:center;padding:12px;border-radius:9px;font-weight:600;font-size:14px;margin-top:8px;}

/* ANIMATIONS */
@keyframes fadeInUp{from{opacity:0;transform:translateY(28px);}to{opacity:1;transform:translateY(0);}}
@keyframes fadeInLeft{from{opacity:0;transform:translateX(-28px);}to{opacity:1;transform:translateX(0);}}
@keyframes fadeInRight{from{opacity:0;transform:translateX(28px);}to{opacity:1;transform:translateX(0);}}
@keyframes marquee{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}
@keyframes pulse{0%,100%{transform:scale(1);}50%{transform:scale(1.05);}}
.float-wa{animation:pulse 2.5s ease-in-out infinite;}

/* RESPONSIVE */
@media(max-width:1024px){.footer-grid{grid-template-columns:1fr 1fr;}.services-grid{grid-template-columns:repeat(2,1fr);}.steps-grid{grid-template-columns:repeat(2,1fr);}.hero .container{grid-template-columns:1fr;}.hero-visual{display:none;}.why-grid{grid-template-columns:1fr;}.why-img{height:360px;}}
@media(max-width:768px){
  .topbar{display:none;}

  /* ── Mobile Nav Menu ── */
  .nav-links{
    display:none;
    position:fixed;
    top:0; left:0; right:0;
    bottom: 0;
    background:#fff;
    flex-direction:column;
    padding: 80px 24px 32px;
    box-shadow: 0 8px 40px rgba(0,0,0,.18);
    z-index:1000;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    gap: 4px;
  }
  .nav-links.open{display:flex;}

  /* Bigger tap targets for nav items */
  .nav-links > li > a{
    padding: 14px 16px;
    font-size: 16px;
    border-radius: 10px;
    -webkit-tap-highlight-color: transparent;
  }

  /* Hamburger – always on top */
  .hamburger{
    display:flex;
    position: relative;
    z-index: 1100;
    -webkit-tap-highlight-color: transparent;
    padding: 8px;
  }
  /* Animate hamburger to X when open */
  .hamburger.open span:nth-child(1){ transform: translateY(7.5px) rotate(45deg); }
  .hamburger.open span:nth-child(2){ opacity: 0; transform: scaleX(0); }
  .hamburger.open span:nth-child(3){ transform: translateY(-7.5px) rotate(-45deg); }
  .hamburger span{ transition: transform .25s ease, opacity .2s ease; }

  /* Dropdown inside mobile nav */
  .has-dropdown .dropdown{position:static;box-shadow:none;border:none;background:var(--light);border-radius:10px;margin-top:4px;}

  /* Nav CTA - handled above globally */

  /* Grid fixes */
  .testi-grid,.services-grid,.values-grid,.gallery-grid{grid-template-columns:1fr;}
  .google-rating-bar{flex-wrap:wrap;justify-content:center;gap:8px;padding:10px 16px;}
  .google-review-cta-inner{flex-direction:column;text-align:center;padding:20px 18px;gap:16px;}
  .google-review-cta-text{flex-direction:column;align-items:center;text-align:center;gap:10px;}
  .btn-google-review{width:100%;justify-content:center;}
  .steps-grid{grid-template-columns:1fr 1fr;}
  .contact-grid,.service-detail-grid,.why-features{grid-template-columns:1fr;}
  .hero h1{font-size:34px;}
  .footer-grid{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;text-align:center;}
  .form-row,.popup-form .form-row{grid-template-columns:1fr;}

  /* ══ POPUP – MOBILE FULL FIX ══ */
  .popup-overlay{
    padding: 0;
    align-items: flex-end;
    background: rgba(10,25,41,.65);
  }
  .popup-modal{
    border-radius: 22px 22px 0 0;
    max-height: 88vh;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    width: 100%;
    box-shadow: 0 -8px 40px rgba(0,0,0,.22);
    transform: translateY(100%);
  }
  .popup-overlay.active .popup-modal{
    transform: translateY(0);
  }

  /* Compact header */
  .popup-header{
    padding: 14px 16px 12px;
    display: flex;
    align-items: center;
    gap: 10px;
    position: relative;
  }
  .popup-header h2{
    font-size: 15px;
    margin-bottom: 2px;
    padding-right: 40px; /* space for close btn */
  }
  .popup-header p{
    font-size: 12px;
  }
  /* Badge above title, not overlapping close btn */
  .popup-badge{
    position: static;
    display: inline-block;
    font-size: 10px;
    padding: 2px 8px;
    margin-bottom: 4px;
    border-radius: 60px;
  }
  /* Close btn always top-right */
  .popup-close{
    position: absolute;
    top: 12px;
    right: 12px;
    width: 32px;
    height: 32px;
  }

  /* Compact body */
  .popup-body{
    padding: 12px 16px 16px;
  }
  .popup-form .form-group{
    margin-bottom: 8px;
  }
  .popup-form label{
    font-size: 10px;
    margin-bottom: 3px;
  }
  .popup-form input,
  .popup-form select{
    font-size: 16px; /* CRITICAL – prevents iOS Safari zoom on focus */
    padding: 10px 12px;
    border-radius: 8px;
  }
  .popup-submit{
    padding: 13px;
    font-size: 15px;
    margin-top: 4px;
    border-radius: 60px;
  }
  .popup-footer{
    font-size: 12px;
    margin-top: 8px;
    padding-bottom: 4px;
  }

  .section-pad{padding:60px 0;}
}

/* ═══════════════════════════════════════
   LOGO – Perfect display all devices
═══════════════════════════════════════ */
/* Footer logo */
.footer-logo {
  height: 52px;
  width: auto;
  max-width: 210px;
  object-fit: contain;
  display: block;
  background: #ffffff;
  border-radius: 10px;
  padding: 6px 14px;
  margin-bottom: 20px;
  box-shadow: 0 2px 12px rgba(0,0,0,.15);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
.logo-link { display:inline-flex; align-items:center; }

/* Icon-wrap for contact boxes */
.icon-wrap {
  width: 52px; height: 52px;
  background: var(--primary);
  border-radius: 13px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.icon-wrap svg { width: 24px; height: 24px; color: #fff; }

/* ═══ GALLERY PAGE ═══ */
.gallery-filter-bar {
  display: flex; gap: 10px; justify-content: center;
  flex-wrap: wrap; margin: 36px 0 40px;
}
.filter-btn {
  padding: 10px 22px; border-radius: 60px;
  font-family: 'Nunito', sans-serif; font-weight: 700; font-size: 14px;
  border: 2px solid var(--border); background: #fff; color: var(--dark);
  cursor: pointer; transition: var(--tr);
}
.filter-btn.active, .filter-btn:hover {
  background: var(--secondary); color: #fff; border-color: var(--secondary);
}

/* Masonry-style gallery grid */
.gallery-grid-v2 {
  columns: 3; column-gap: 16px; margin-top: 0;
}
.gallery-item-v2 {
  break-inside: avoid; margin-bottom: 16px;
  border-radius: 14px; overflow: hidden;
  position: relative; cursor: pointer;
  display: block;
}
.gallery-item-v2 img {
  width: 100%; display: block;
  transition: transform .45s ease;
}
.gallery-item-v2:hover img { transform: scale(1.05); }
.gallery-item-v2 .g-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(0deg, rgba(13,43,78,.7) 0%, transparent 60%);
  opacity: 0; transition: var(--tr);
  display: flex; flex-direction: column;
  justify-content: flex-end; padding: 16px;
}
.gallery-item-v2:hover .g-overlay { opacity: 1; }
.g-overlay h4 { color: #fff; font-family: 'Nunito', sans-serif; font-size: 14px; font-weight: 700; margin-bottom: 4px; }
.g-overlay span { color: rgba(255,255,255,.75); font-size: 12px; }
.g-zoom-icon {
  position: absolute; top: 12px; right: 12px;
  width: 36px; height: 36px; border-radius: 50%;
  background: rgba(255,255,255,.15);
  backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: var(--tr);
}
.g-zoom-icon svg { width: 18px; height: 18px; color: #fff; }
.gallery-item-v2:hover .g-zoom-icon { opacity: 1; }

/* Video gallery */
.video-grid {
  display: grid; grid-template-columns: repeat(2,1fr); gap: 22px; margin-top: 40px;
}
.video-card {
  border-radius: 16px; overflow: hidden;
  background: var(--primary);
  box-shadow: var(--shadow);
  transition: var(--tr);
}
.video-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); }
.video-thumb {
  position: relative; aspect-ratio: 16/9; overflow: hidden; cursor: pointer;
}
.video-thumb img { width:100%; height:100%; object-fit:cover; transition:transform .45s ease; }
.video-card:hover .video-thumb img { transform: scale(1.04); }
.play-btn {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  background: rgba(13,43,78,.4);
  transition: var(--tr);
}
.play-btn svg { width: 64px; height: 64px; color: #fff; filter: drop-shadow(0 4px 12px rgba(0,0,0,.4)); transition: transform var(--tr); }
.video-card:hover .play-btn { background: rgba(13,43,78,.6); }
.video-card:hover .play-btn svg { transform: scale(1.1); }
.video-info { padding: 18px 20px; }
.video-info h4 { color: #fff; font-family: 'Nunito', sans-serif; font-weight: 700; font-size: 16px; margin-bottom: 5px; }
.video-info p { color: rgba(255,255,255,.6); font-size: 13px; }
.video-badge {
  position: absolute; top: 12px; left: 12px;
  background: var(--secondary); color: #fff;
  padding: 4px 10px; border-radius: 60px;
  font-size: 11px; font-weight: 700; letter-spacing: .5px;
}

/* Video Modal */
.video-modal-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.92);
  z-index: 9999; display: flex; align-items: center; justify-content: center;
  opacity: 0; visibility: hidden;
  transition: opacity .3s ease, visibility .3s ease;
  padding: 20px;
}
.video-modal-overlay.active { opacity: 1; visibility: visible; }
.video-modal-wrap {
  position: relative; width: 100%; max-width: 900px;
  border-radius: 16px; overflow: hidden;
  transform: scale(.92);
  transition: transform .35s cubic-bezier(.34,1.56,.64,1);
}
.video-modal-overlay.active .video-modal-wrap { transform: scale(1); }
.video-modal-wrap iframe, .video-modal-wrap video {
  width: 100%; aspect-ratio: 16/9; display: block; border: none;
}
.video-modal-close {
  position: absolute; top: -46px; right: 0;
  width: 38px; height: 38px; border-radius: 50%;
  background: rgba(255,255,255,.15); border: none;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: var(--tr); z-index: 2;
}
.video-modal-close svg { width: 20px; height: 20px; color: #fff; }
.video-modal-close:hover { background: var(--secondary); }

/* Lightbox */
.lightbox-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.94);
  z-index: 9998; display: flex; align-items: center; justify-content: center;
  opacity: 0; visibility: hidden;
  transition: opacity .3s ease, visibility .3s ease;
}
.lightbox-overlay.active { opacity: 1; visibility: visible; }
.lightbox-img { max-width: 90vw; max-height: 90vh; border-radius: 12px; display: block; }
.lightbox-close {
  position: absolute; top: 20px; right: 20px;
  width: 42px; height: 42px; border-radius: 50%;
  background: rgba(255,255,255,.12); border: none;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: var(--tr);
}
.lightbox-close svg { width: 22px; height: 22px; color: #fff; }
.lightbox-close:hover { background: var(--secondary); }
.lightbox-nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 46px; height: 46px; border-radius: 50%;
  background: rgba(255,255,255,.12); border: none;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: var(--tr);
}
.lightbox-nav svg { width: 22px; height: 22px; color: #fff; }
.lightbox-nav:hover { background: var(--secondary); }
.lightbox-prev { left: 20px; }
.lightbox-next { right: 20px; }
.lightbox-caption {
  position: absolute; bottom: 20px; left: 50%; transform: translateX(-50%);
  background: rgba(0,0,0,.6); color: #fff; padding: 8px 20px;
  border-radius: 60px; font-size: 14px; font-family: 'Nunito', sans-serif;
  white-space: nowrap;
}

/* Responsive gallery */
@media(max-width:768px) {
  .gallery-grid-v2 { columns: 2; }
  .video-grid { grid-template-columns: 1fr; }
  .logo-img { height: 40px; max-width: 150px; }
}
@media(max-width:480px) {
  .gallery-grid-v2 { columns: 1; }
  .logo-img { height: 36px; max-width: 130px; }
}
/* iOS Safari — force GPU compositing for crisp logo */
@supports (-webkit-touch-callout: none) {
  .logo-img {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    will-change: transform;
  }
  .popup-modal { -webkit-overflow-scrolling: touch; }
  .popup-overlay { height: 100%; height: -webkit-fill-available; }
}

/* Extra small phones (iPhone SE, Galaxy A series etc.) */
@media(max-width:390px){
  .popup-header h2 { font-size: 14px; }
  .popup-header { padding: 12px 14px 10px; }
  .popup-body { padding: 10px 14px 14px; }
  .popup-badge { display: none; }
  .popup-form input, .popup-form select { padding: 9px 11px; }
  .popup-submit { padding: 12px; font-size: 14px; }
  .nav-links { padding: 72px 16px 28px; }
}
