@charset "UTF-8";
/* =========================================
   1. MOBILE DEVICES & SMALL SCREENS
   ========================================= */

/* --- Mobile Small (max-width: 480px) --- */
@media (max-width: 480px) {
    .container, .container-sm { max-width: 100%; }
    .navbar { padding: 10px 0; }
    .logo-wrapper { width: 110px; height: 55px; min-width: 110px; }
    #hero-section {height: auto;padding: 70px 0 0px !important;}
    .hero-title {font-size: 18px;padding-left: 19px;margin: 52px 0;}
    .hero-subtitle { font-size: 14px; padding: 18px 18px 18px 17px; margin-top: -34px; }
	.section-title { font-size: 24px; margin-bottom: 0px; }
    #smarter-cities { min-height: auto; }
    .smarter-graphic-wrapper { height: 220px; margin-bottom: 28px !important; }
    .smarter-title { font-size: 18px; margin-bottom: 12px; }
    .section-padding { padding: 31px 26px 0 16px; margin-bottom: 66px; }
    .clients-title { font-size: 24px; }
    .section-desc, .ps-desc, .contact-desc, .smarter-desc, .clients-subtitle { font-size: 16px; margin-top: 0px; }
    /* Products Section */
    .ps-header { margin-bottom: 28px; }
    .ps-label { font-size: 11px; letter-spacing: 2px; margin-bottom: 10px; }
    .ps-title { font-size: 26px; }
    .ps-desc { font-size: 16px; }
    .ps-card-img img { height: 160px; }
    .ps-card-body { padding: 16px 3px 20px; }
    .ps-card-title { font-size: 18px; }
    .ps-card-desc { font-size: 16px; margin-bottom: 16px; }
    .ps-card-btn { font-size: 13px; padding: 9px 24px; }
    .get-in-touch { justify-content: center; align-items: center; text-align: center; }
    #stats-section { padding: 50px 10px; }
    .contact-title { font-size: 24px; text-align: center; }
    .btn-custom { width: 200px; height: auto; margin: 0 auto; text-align: center; }
    #site-footer { padding: 20px; }
    .footer-logo-merged { margin: 0 auto 20px; }
    .social-icons { justify-content: center; }
    /* Subnav */
    .subnav-hamburger { display: flex; }
    .subnav-links { flex-direction: column; gap: 20px; max-height: 0; }
    /* Timeline */
    #section-timeline { padding: 40px 20px 50px; }
    .timeline-header { margin-bottom: 32px; }
    .timeline-header h2 { font-size: 22px; }
    .nav-arrow svg { width: 50px; height: 50px; }
    .big-number { font-size: 120px; right: 0; top: 40%; }
    .timeline-graphic { height: 50px; margin-bottom: 32px; }
    .slide-content-wrapper { flex-direction: column; gap: 20px; }
    .image-circle-container { width: 160px; height: 160px; }
    .timeline-content p { font-size: 15px; }
    /* Awards */
    #section-awards { padding: 0px 15px 13px; }
    .section-header h2 { font-size: 1.8rem; }
    .section-header p { font-size: 0.9rem; padding: 0 10px; }
    .subtitle { font-size: 13px; }
    .award-card { height: 250px; padding: 12px; }
    .award-card p { font-size: 13px; }
    .award-img { width: 100px; height: 100px; }
    .arrow-group img { width: 26px; height: 26px; }
    /* Testimonials */
    #section-testimonials { padding: 18px 15px; }
    .testi-card { padding: 22px 16px; min-height: 280px; }
    .testi-card h3 { font-size: 17px; }
    .testi-card .quote { font-size: 14px; }
    .testi-card .author strong { font-size: 15px; }
    /* About */
    #section-about { padding: 40px 20px; }
    .about-heading { font-size: 24px; text-align: left; }
    .about-label { font-size: 13px; }
    /* Vision/Mission */
    .vm-heading { font-size: 26px; }
    .vm-block { padding: 24px 0; }
    .vm-block h2 { font-size: 26px; text-align: center; }
    #section-vision-mission { padding: 40px 20px; }
    /* Lead / Mentor */
    #lead-example { padding: 0px 16px; }
    #mentor-card { padding: 0px 16px; }
    .lead-wrapper { flex-direction: column; padding: 28px 20px 0; text-align: center; align-items: center; }
    .mentor-wrapper { flex-direction: column; padding: 28px 20px 0; text-align: center; align-items: center; }
    .lead-left, .lead-right { width: 100%; text-align: center; padding-bottom: 0; }
    .mentor-left, .mentor-right { width: 100%; text-align: center; padding-bottom: 0; }
    .lead-tagline { font-size: 24px; }
    .lead-name { font-size: 18px; }
    .lead-role { font-size: 14px; }
    .lead-right img { max-width: 260px; height: 200px; margin: 0 auto; }
    .lead-bio { column-count: 1; font-size: 14px; margin-top: 20px; }
    .mentor-name { font-size: 26px; }
    .mentor-subtitle { font-size: 15px; }
    .mentor-right img { max-width: 260px; height: 200px; margin: 0 auto; }
    /* Work */
    .work-container { flex-direction: column; gap: 30px; text-align: center; }
    .work-content h2 { font-size: 26px; text-align: center; }
    .work-content p { font-size: 15px; }
    .btn-work { margin: 0 auto; display: inline-block; }
    #section-work { padding: 50px 20px; }
    /* Team */
    .team-container { padding: 14px 20px; }
    .section-label { text-align: center; }
    .section-header { padding: 19px 1rem; }
    /* Products Grid */
    .product-grid { grid-template-columns: 1fr; padding: 1rem 15px; }
    .product-row, .product-row:nth-child(even) { flex-direction: column; gap: 2rem; }
    .product-info h3 { font-size: 1.5rem; text-align: center; }
    .product-image img { max-height: 250px; }
    .pleft, .pright { text-align: center; }
    .row-text p { text-align: center; }
    .content-row-placeholder { min-height: 180px; }

    /* Line decorators */
    .line-1 { top: 21%; left: 11%; width: 45%; }
    .line-2 { bottom: 21%; right: 11%; width: 45%; }
}

/* --- Mobile (max-width: 767px) --- */
@media (max-width: 767px) {
    .design-img { height: 140%; }
    .card-title { font-size: 20px; }
    .logo-item { max-height: 45px; }
}

/* --- Mobile / Tablet Boundary (max-width: 768px) --- */
@media (max-width: 768px) {
    .subnav-indicator { width: 4px !important; height: 20px; left: 0; bottom: auto; top: 0; transform: translateY(0); }
    .subnav-links { flex-direction: column; position: relative; }
    #section-timeline { padding: 40px 20px; }
    .timeline-header { margin-top: 0; margin-bottom: 30px; }
    .timeline-header h2 { font-size: 26px; }
    .timeline-graphic { height: auto; min-height: 460px; display: flex; flex-direction: column; align-items: center; margin-top: 20px; }
    .timeline-line, .dot-small-2 { display: none; }
    .big-number { font-size: 180px; opacity: 0.2; top: 15%; right: 50%; transform: translateX(50%); }
    .active-point-container { position: static; transform: none; flex-direction: row; gap: 15px; margin-bottom: 30px; }
    .year-label { margin-bottom: 0; }
    .slide-content-wrapper { margin-left: 0; width: 100%; align-items: center; text-align: center; }
    .image-circle-container { margin-top: 0; width: 200px; height: 200px; margin-bottom: 20px; border: none; }
    .timeline-content p { max-width: 100%; font-size: 16px; }
    .image-sweep img { height: 360px; }
    .team-overlay { bottom: 22px; left: 22px; }
}

/* =========================================
   2. TABLETS (Portrait & Landscape)
   ========================================= */

/* --- Tablets (481px to 768px) --- */
@media (min-width: 481px) and (max-width: 768px) {
    .container, .container-sm { max-width: 650px; }
    .navbar { padding: 14px 0; }
    .logo-wrapper { width: 130px; height: 75px; }
    #hero-section {height: auto;padding: 140px 0 60px;}
    .smarter-graphic-wrapper { height: 345px; margin-bottom: 36px !important; }
    .smarter-title { font-size: 30px; }
    .hero-title { font-size: 26px; }
    /* Products Section */
    .ps-header { margin-bottom: 36px; }
    .ps-title { font-size: 36px; }
    .ps-desc { font-size: 18px; }
    .ps-card-img img { height: 185px; }
    .ps-card-btn { padding: 10px 28px; }
    .contact-title { font-size: 40px; }
    .clients-title { font-size: 40px; }
    #stats-section { padding: 50px 0; }
    .btn-custom { width: 200px; height: auto; margin: 0 auto; text-align: center; }
    .section-header { padding: 31px 1rem; }
    .footer-logo-merged { margin: 0 auto; }
    .social-icons { justify-content: center; }
    /* Subnav */
    .subnav-hamburger { display: flex; }
    .subnav-links { flex-direction: column; gap: 22px; max-height: 0; }
    .big-number { font-size: 166px; }
    /* Awards */
    #section-awards { padding: 10px 18px 60px; }
    .section-header h2 { font-size: 2.2rem; }
    .subtitle { font-size: 15px; }
    .award-card { height: 280px; }
    .award-img { width: 125px; height: 125px; }
    .arrow-group img { width: 28px; height: 28px; }
    /* Testimonials */
    .testi-card { padding: 28px 20px; min-height: 300px; }
    .testi-card h3 { font-size: 18px; }
    .testi-card .quote { font-size: 15px; }
    /* Lead / Mentor */
    .lead-wrapper { flex-direction: column; padding: 32px 24px 0; text-align: center; }
    .mentor-wrapper { flex-direction: column; padding: 32px 24px 0; text-align: center; }
    .lead-left, .lead-right { width: 100%; text-align: center; }
    .mentor-left, .mentor-right { width: 100%; text-align: center; }
    .lead-tagline { font-size: 28px; }
    .lead-name { font-size: 20px; }
    .lead-bio { column-count: 1; }
    .lead-right img { max-width: 260px; height: 220px; margin: 20px auto 0; }
    .mentor-name { font-size: 28px; }
    .mentor-subtitle { font-size: 16px; }
    .mentor-right img { max-width: 260px; height: 220px; margin: 20px auto 0; }
    /* Vision/Mission */
    .vm-heading { font-size: 30px; }
    #section-vision-mission { padding: 50px 30px; }
    /* Work */
    .work-container { flex-direction: column; text-align: center; }
    .work-content h2 { font-size: 30px; }
    .btn-work { margin: 0 auto; }
    /* Products Grid */
    .product-grid { grid-template-columns: 1fr; }
    .product-row, .product-row:nth-child(even) { flex-direction: column; gap: 2rem; text-align: center; }
    .product-image img { max-height: 300px; }
    /* Line decorators */
    .line-1 { top: 8%; left: 6%; width: 52%; }
    .line-2 { bottom: 8%; right: 6%; width: 52%; }
}

/* --- Specific Tablet Range (540px to 720px) --- */
@media (min-width: 540px) and (max-width: 720px) {
    .subnav-hamburger { display: flex; }
    .subnav-links { gap: 24px; }
    .smarter-graphic-wrapper { height: 250px; margin-bottom: 36px !important; }
    .big-number { font-size: 220px; }
    .award-card { height: 270px; }
    .award-img { width: 120px; height: 120px; }
    .testi-card { min-height: 310px; }
    .lead-tagline { font-size: 30px; }
    .lead-right img { max-width: 315px; }
    .mentor-name { font-size: 30px; }
    .mentor-right img { max-width: 280px; }
    .ps-card-img img { height: 190px; }
    .work-content h2 { font-size: 32px; }
    #site-footer { padding: 40px; }
    .footer-logo-merged { margin: 0px; }
    .social-icons { justify-content: center; }
    .line-1 { top: 9%; left: 5%; width: 52%; }
    .line-2 { bottom: 9%; right: 5%; width: 52%; }
}

/* --- Min 600px grid --- */
@media (min-width: 600px) {
    .awards-grid { grid-template-columns: repeat(2, 1fr); }
}

/* =========================================
   3. LAPTOPS & SMALL DESKTOPS
   ========================================= */

/* --- iPad / Retina landscape (768px–1024px @2x) --- */
@media only screen and (min-device-width: 768px) and (max-device-width: 1024px) and (-webkit-min-device-pixel-ratio: 2) {
    .navbar { padding: 18px 0; }
    #hero-section { height: auto; min-height: 40vh; padding: 100px 46px 80px; }
    .smarter-graphic-wrapper { height: 270px; margin-bottom: 56px !important; }
    #smarter-cities { min-height: auto; }
    .smarter-title { font-size: 30px; }
    .hero-title { font-size: 38px; }
    .ps-title { font-size: 42px; }
    .ps-card-img img { height: 200px; }
    .ps-card-body { padding: 20px 20px 24px; }
    .contact-title { font-size: 40px; }
    .row { --bs-gutter-x: 3rem; }
    #site-footer { text-align: left; }
    .contact-row { justify-content: flex-start; }
    .social-icons { justify-content: flex-start; }
    .subnav-hamburger { display: flex; }
    .subnav-links { flex-direction: column; gap: 26px; max-height: 0; }
    #section-timeline { padding: 30px 30px; }
    .year-label { margin-bottom: 15px; }
    .big-number { font-size: 300px; right: 5%; top: 48%; transform: translateY(-50%); }
    .timeline-line, .dot-small-2 { display: block; }
    .active-point-container { position: absolute; transform: translate(-50%, -50%); flex-direction: column; }
    .slide-content-wrapper { margin-left: 0; width: 90%; align-items: flex-start; text-align: left; }
    .image-circle-container { width: 150px; height: 150px; margin-top: -48px; margin-bottom: 127px; border: 6px solid #491084; }
    #section-awards { padding: 50px 70px; }
    .section-header h2 { font-size: 30px; }
    .subtitle { font-size: 17px; }
    .award-card { height: 300px; }
    .award-img { width: 140px; height: 140px; }
    .arrow-group img { width: 30px; height: 30px; }
    #section-testimonials { padding: 50px 70px; }
    .testi-card { padding: 35px 26px; min-height: 340px; }
    .testi-card h3 { font-size: 20px; }
    .testi-card .quote { font-size: 16px; }
    .lead-wrapper { flex-direction: row; padding: 48px 0 0 40px; }
    .mentor-wrapper { flex-direction: row; padding: 48px 0 0 40px; }
    .lead-left { width: 60%; }
    .lead-right { width: 40%; }
    .lead-right img { max-width: 300px; }
    .lead-tagline { font-size: 36px; }
    .lead-bio { column-count: 2; }
    .mentor-left { width: 60%; }
    .mentor-right { width: 40%; }
    .mentor-right img { max-width: 300px; }
    .mentor-name { font-size: 34px; }
    #section-about { padding: 25px 70px; }
    .product-grid { grid-template-columns: repeat(2, 1fr); padding: 2rem 5%; }
    .product-row, .product-row:nth-child(even) { flex-direction: column; gap: 2rem; text-align: center; }
    .work-container { gap: 40px; }
    .work-content h2 { font-size: 34px; }
}

/* --- Medium Tablet / Small Laptops (min-width: 768px) --- */
@media (min-width: 768px) {
    #section-vision-mission { padding: 100px 70px; }
    .vm-heading { font-size: 48px; }
    .smarter-graphic-wrapper { height: 430px; margin-bottom: 56px !important; position: relative; left: 0; }
}

/* --- Laptop Range (850px to 1023px) --- */
@media (min-width: 850px) and (max-width: 1023px) {
    .smarter-graphic-wrapper { height: 490px; margin-bottom: 64px !important; }
    .line-1 { top: 12%; left: 8%; width: 44%; }
    .line-2 { bottom: 12%; right: 18%; width: 44%; }
    .subnav-links { gap: 30px; }
    .timeline-graphic { height: 320px; }
    .big-number { font-size: 280px; }
    .image-circle-container { width: 200px; height: 200px; margin-top: -100px; }
    .section-header h2 { font-size: 30px; }
    .award-card { height: 300px; }
    .testi-card { min-height: 330px; }
    .lead-tagline { font-size: 34px; }
    .lead-left { width: 58%; }
    .lead-right { width: 42%; }
    .lead-right img { max-width: 330px; }
    .mentor-name { font-size: 34px; }
    .mentor-left { width: 58%; }
    .mentor-right { width: 42%; }
    .mentor-right img { max-width: 330px; }
    .product-grid { grid-template-columns: repeat(2, 1fr); }
    .product-row { gap: 2rem; }
    .ps-title { font-size: 40px; }
    .ps-card-img img { height: 195px; }
    .work-content h2 { font-size: 34px; }
    .footer-desc { font-size: 15px; }
}

/* --- Max Width Constraints (Up to 991px) --- */
@media (max-width: 991px) {
    .navbar-collapse { background-color: #8A00FF; padding: 20px; margin-top: 10px; border-radius: 8px; }
    #hero-section { height: auto; }
}

/* --- Desktop Start (Min Width 992px) --- */
@media (min-width: 992px) {
    .col-lg-8 { width: 68%; }
}

/* --- Max Width Constraints (Up to 1024px) --- */
@media (max-width: 1024px) {
    #section-timeline { height: auto; min-height: 600px; }
    .big-number { font-size: 250px; right: 3%; top: 44%; }
    .section-header h2 { font-size: 26px; }
    #section-subnav { top: 72px; }
}

/* =========================================
   4. DESKTOPS & LARGE SCREENS
   ========================================= */

/* --- Tablet Landscape to Desktop (1024px and up) --- */
@media (min-width: 1024px) {
    .smarter-graphic-wrapper { height: 320px; margin-bottom: 72px !important; }
    #smarter-cities { padding: 80px 40px; }
    .smarter-title { font-size: 38px; }
    .big-number { font-size: clamp(200px, 25vw, 400px); }
    .slide-content-wrapper { width: 75%; }
    .section-header h2 { font-size: 3rem; }
    .product-grid { grid-template-columns: repeat(3, 1fr); }
    .product-row { flex-direction: row; }
    .product-row:nth-child(even) { flex-direction: row-reverse; }
    #section-subnav { top: 72px; }
}

/* --- Standard Desktop Range (1024px to 1368px) --- */
@media (min-width: 1024px) and (max-width: 1368px) {
    .smarter-graphic-wrapper { height: 350px; margin-bottom: 68px !important; }
    .line-1 {top: 8%;left: 10%;width: 46%;}
    .line-2 {bottom: 8%;right: 10%;width: 46%;}
    .subnav-links { gap: 35px; }
    .image-circle-container { width: 220px; height: 220px; margin-top: -110px; margin-bottom: 62px; }
    .timeline-content p { font-size: 17px; }
    .section-header h2 { font-size: 34px; }
    .award-img { width: 140px; height: 140px; }
    #section-testimonials { padding: 70px 30px 90px; }
    .testi-card { min-height: 350px; padding: 36px 28px; }
    .lead-wrapper { padding: 48px 0 0 60px; }
    .lead-tagline { font-size: 40px; }
    .lead-left { width: 55%; }
    .lead-right { width: 45%; }
    .mentor-wrapper { padding: 48px 0 0 60px; }
    .mentor-name { font-size: 36px; }
    .mentor-left { width: 55%; }
    .mentor-right { width: 45%; }
    .product-detail-container { max-width: 1100px; }
    .product-grid { gap: 3rem; }
    .work-content h2 { font-size: 36px; }
    #site-footer { padding: 80px 0 50px; }
    .ps-header { margin-bottom: 52px; }
    .ps-title { font-size: clamp(28px, 4vw, 46px); }
    .ps-card-img img { height: 210px; }
    .ps-card-title { font-size: 14px; }
    .ps-card-desc { font-size: 14px; }
    .ps-card-btn { font-size: 14px; padding: 11px 32px; }
}

/* --- Desktops Main (1025px and up) --- */
@media (min-width: 1025px) {
    .smarter-graphic-wrapper { height: 360px; margin-bottom: 64px !important; position: relative; left: 0; }
    .line-1 {top: 19%;left: 7%;width: 50%;}
    .line-2 {bottom: 19%;right: 7%;width: 50%;}
    .subnav-hamburger { display: none !important; }
    #section-subnav { padding: 40px 70px 0; }
    /* About */
    #section-about { padding: 100px 122px; }
    .about-container { flex-direction: row; gap: 70px; }
    .about-image { flex: 0 0 48%; max-width: 48%; }
    .about-content { flex: 1; }
    .image-mask { height: 600px; }
    .about-heading { font-size: 40px; }
    .section-title { font-size: 40px; }
    /* Timeline */
    #section-timeline { padding: 72px 122px 88px; }
    .timeline-header { height: 152px; margin-bottom: 139px; }
    .timeline-header h2 { font-size: 48px; }
    .big-number { font-size: 376px; top: 301px; }
    .image-circle-container { width: 220px; height: 220px; margin-top: -110px; margin-bottom: 62px; border: 6px solid #491084; }
    .timeline-line, .dot-small-2 { display: block; }
    .active-point-container { position: absolute; transform: translate(-50%, -50%); flex-direction: column; }
    .year-label { margin-bottom: 15px; }
    .slide-content-wrapper { margin-left: 0; width: 90%; align-items: flex-start; text-align: left; }
    /* Vision/Mission */
    #section-vision-mission { padding: 80px 122px; }
    .vm-container { flex-direction: row; gap: 0; align-items: stretch; }
    .vm-block { padding: 20px 60px 20px 0; }
    .vm-block:last-child { padding: 20px 0 20px 60px; }
    .vm-divider { width: 1px; height: auto; min-height: 200px; flex-shrink: 0; }
    .vm-heading { font-size: 50px; }
    /* Awards */
    #section-awards { padding: 60px 122px 100px; }
    .awards-grid { grid-template-columns: repeat(4, 1fr); }
    .section-header h2 { font-size: 48px; }
    .arrow-group img { width: 32px; height: 32px; }
    /* Testimonials */
    #section-testimonials { padding: 60px 122px 100px; }
    .testimonials-grid { grid-template-columns: repeat(3, 1fr); }
    .testi-card { min-height: 360px; padding: 40px 30px; }
    /* Lead */
    #lead-example { padding: 0 122px; margin: 40px auto; }
    .lead-wrapper { flex-direction: row; padding: 48px 0 0 80px; align-items: flex-end; }
    .lead-left { width: 55%; padding-bottom: 48px; }
    .lead-right { width: 45%; }
    .lead-tagline { font-size: 42px; }
    .lead-name { font-size: 22px; }
    .lead-bio { column-count: 2; column-gap: 48px; font-size: 15px; margin-top: 32px; }
    .lead-right img { max-width: 470px; height: 340px; }
    /* Mentor */
    #mentor-card { padding: 0 122px; margin: 40px auto; }
    .mentor-wrapper { flex-direction: row; padding: 48px 0 0 80px; align-items: flex-end; }
    .mentor-left { width: 55%; padding-bottom: 48px; }
    .mentor-right { width: 45%; }
    .mentor-name { font-size: 42px; }
    .mentor-subtitle { font-size: 22px; }
    .mentor-right img { max-width: 470px; height: 340px; }
    /* Work */
    #section-work { padding: 100px 70px; }
    .work-container { flex-direction: row; gap: 80px; }
    .work-content h2 { font-size: 48px; }
    /* Products */
    .product-grid { max-width: 1400px; }
    /* Footer */
    #site-footer { text-align: left; }
    .contact-row { justify-content: flex-start; }
    .social-icons { justify-content: flex-start; }
}

/* =========================================
   5. SPECIALTY DEVICES
   ========================================= */

/* --- Surface Pro High-Density Screen (1000px–1400px @1.5dppx) --- */
@media screen and (min-width: 1000px) and (max-width: 1400px) and (min-resolution: 1.5dppx) {
    .smarter-graphic-wrapper { height: 400px; margin-bottom: 60px !important; position: relative; left: 0; }
    .subnav-links { gap: 38px; }
    .subnav-item { font-size: 17px; }
    .award-card p { font-size: 17px; }
    .section-header h2 { font-size: 35px; }
    .award-img { width: 145px; height: 145px; }
    .testi-card h3 { font-size: 30px; }
    .testi-card .quote { font-size: 17px; }
    .lead-right img { max-width: 360px; }
    .lead-tagline { font-size: 38px; }
    .lead-bio { font-size: 17px; }
    .mentor-right img { max-width: 360px; }
    .mentor-name { font-size: 38px; }
    .ps-title { font-size: 36px; }
    .ps-card-img img { height: 205px; }
    .ps-card-desc { font-size: 0.9rem; }
    .image-mask img { transform: scale(1.05); }
    .footer-desc { font-size: 16px; }
    .big-number { font-size: 280px; }
    .image-circle-container { width: 240px; height: 240px; }
}

/* --- Ultra Wide (1600px and up) --- */
@media (min-width: 1600px) {
    .hero-title { font-size: 50px; }
    .section-title { font-size: 56px; }
    .ps-title { font-size: 60px; }
    .ps-card-img img { height: 240px; }
    .ps-card-body { padding: 28px 28px 32px; }
    .ps-card-title { font-size: 15px; }
    .ps-card-btn { padding: 13px 38px; font-size: 15px; }
    .contact-title { font-size: 80px; }
}

/* =========================================
   LINE DECORATORS — interlocked "S" shape
   ========================================= */

/* 320px – 375px */
@media (min-width: 320px) and (max-width: 375px) {
    .line-1 {top: 20%;left: 5%;width: 52%;}
    .line-2 {bottom: 20%;right: 5%;width: 52%;}
}
/* 376px – 412px */
@media (min-width: 376px) and (max-width: 412px) {
    .line-1 {top: 16%;left: 5%;width: 52%;}
    .line-2 {bottom: 16%;right: 5%;width: 52%;}
}
/* 413px – 480px */
@media (min-width: 413px) and (max-width: 480px) {
    .line-1 {top: 15%;left: 5%;width: 52%;}
    .line-2 {bottom: 15%;right: 5%;width: 52%;}
}
/* 481px – 540px */
@media (min-width: 481px) and (max-width: 540px) {
    .line-1 {top: 12%;left: 4%;width: 52%;}
    .line-2 {bottom: 12%;right: 4%;width: 52%;}
}
/* 721px – 768px */
@media (min-width: 721px) and (max-width: 768px) {
    .line-1 {top: 15%;left: 5%;width: 52%;}
    .line-2 {bottom: 15%;right: 5%;width: 52%;}
}
/* 769px – 1023px */
@media (min-width: 769px) and (max-width: 1023px) {
    .line-1 {top: 17%;left: 5%;width: 52%;}
    .line-2 {bottom: 17%;right: 5%;width: 52%;}
}
/* 1369px and up */
@media (min-width: 1369px) {
    .line-1 { top: 17%; left: 5%; width: 52%; transform: none; }
    .line-2 { bottom: 17%; right: 5%; left: auto; width: 52%; transform: none; }
}

/* =========================================
   TIMELINE RESPONSIVE
   ========================================= */

@media (min-width: 481px) and (max-width: 768px) {
    #section-timeline { padding: 40px 24px 56px; }
    .timeline-header h2 { font-size: 26px; }
    .big-number { font-size: 160px; }
    .image-circle-container { width: 180px; height: 180px; }
}
@media (min-width: 769px) and (max-width: 1024px) {
    #section-timeline { padding: 50px 40px; }
    .timeline-header h2 { font-size: 30px; }
    .big-number { font-size: 260px; }
    .timeline-graphic { height: 56px; }
    .image-circle-container { width: 200px; height: 200px; }
}
@media (min-width: 850px) and (max-width: 1023px) {
    .big-number { font-size: 240px; }
    .image-circle-container { width: 210px; height: 210px; }
}
@media (min-width: 1025px) and (max-width: 1368px) {
    #section-timeline { padding: 64px 80px 80px; }
    .timeline-header h2 { font-size: 36px; }
    .big-number { font-size: clamp(200px, 22vw, 360px); }
    .timeline-graphic { height: 64px; }
    .image-circle-container { width: 260px; height: 260px; }
    .timeline-content p { font-size: 18px; }
}

/* =========================================
   6. NARROW MOBILE — max-width: 360px
   ========================================= */
@media (max-width: 360px) {
    .container, .container-sm { max-width: 100%; padding-left: 14px; padding-right: 14px; }
    /* Navbar */
	 .mobile-header { padding: 6px 12px; min-height: 64px; }
    .mobile-logo img, .mobile-logo .custom-logo { height: 44px; }
    .mobile-toggle { font-size: 24px; padding-right: 14px; }
    /* Hero */
    #hero-section { min-height: auto; height: auto; padding: 56px 0 28px; }
    .hero-title { font-size: 22px; line-height: 1.2; padding-left: 16px; margin: 28px 0 14px; }
    .hero-subtitle { font-size: 14px; line-height: 1.6; padding-left: 14px; margin-top: 0; max-width: 100%; }
    .hero-image { position: absolute; width: 100%; bottom: 0; margin-top: 18px; }
    .section-padding { padding: 35px 40px !important; }
    /* Design Future */
    #design-future { padding-top: 51px !important; padding-bottom: 0px !important; }
    .section-title { font-size: 22px !important; margin-bottom: 0px; }
    .section-desc { font-size: 14px; text-align: left; margin-top: -13px; }
    .design-img { height: 120px; border-radius: 6px; }
    /* Smarter Cities */
    #smarter-cities { padding: 30px 12px 40px !important; min-height: auto !important; }
    .smarter-graphic-wrapper { height: 229px !important; margin-bottom: 0 !important; }
    .smarter-title { font-size: 18px; margin-bottom: 10px; }
    .smarter-desc { font-size: 14px; line-height: 1.65; margin-bottom: 20px; padding: 0 4px; }
    .btn-pill-white { padding: 10px 28px; font-size: 13px; }
    /* Products Section */
    #products-section { padding: 36px 0 44px; }
    .ps-header { margin-bottom: 20px; }
    .ps-label { font-size: 10px; letter-spacing: 1.5px; margin-bottom: 8px; }
	.ps-card-img img { height: 170px; }
    .ps-title { font-size: 22px; }
    .ps-desc { font-size: 14px; padding: 0 4px; }
    .ps-card { padding: 1.25rem; }
    .ps-card-img { height: 150px; }

    .ps-card-body { padding: 0; }
    .ps-card-title { font-size: 16px; }
    .ps-card-desc { font-size: 16px; margin-bottom: 12px; }
    .ps-card-btn { font-size: 13px; padding: 8px 20px; }
    /* Stats */
    #stats-section { padding: 36px 0; }
    .stat-number { font-size: clamp(22px, 6vw, 28px); }
    .stat-label { font-size: 10px; }
    .stat-item { padding-left: 12px; }
    /* Clients */
    .clients-title { font-size: 22px; }
    .clients-subtitle { font-size: 14px; }
    .logo-item { max-height: 100px; }
    /* Contact CTA */
    .section-padding { padding: 30px 26px !important; }
    .contact-title { font-size: 22px; text-align: left; }
    .contact-desc { font-size: 14px; }
    .contact-img { border-radius: 6px; }
    .get-in-touch { text-align: left; }
    .btn-custom { width: auto; padding: 10px 26px; font-size: 13px; display: inline-block; margin: 0; }
    /* Footer */
    #site-footer { padding: 36px 0 0; }
    .footer-grid { grid-template-columns: 1fr; gap: 24px; padding-bottom: 30px; }
    .footer-col-logo { text-align: left; }
    .footer-logo-wrap img, .footer-logo-wrap .custom-logo { width: 100px; }
    .footer-col-heading { font-size: 11px; margin-bottom: 14px; }
    .footer-info-text { font-size: 13px; }
    .footer-nav-list a { font-size: 13px; }
    .footer-col-social { flex-direction: column; align-items: flex-start; gap: 12px; }
    .footer-social-btn { width: 32px; height: 32px; }
    .footer-social-btn img { width: 14px; height: 14px; }
    .footer-tagline { font-size: 12px; max-width: 100%; }
    .footer-bottom-bar { padding: 14px 0; }
    .footer-copyright-text { font-size: 11px; }
    /* Timeline */
    #section-timeline { padding: 32px 14px 40px; }
    .timeline-header { margin-bottom: 24px; }
    .timeline-header h2 { font-size: 18px; }
    .big-number { font-size: 100px; }
    .image-circle-container { width: 140px; height: 140px; }
    .timeline-content p { font-size: 13px; }
    /* Awards */
    #section-awards { padding: 0 12px 20px; }
    .award-card { height: 220px; padding: 10px; }
    .award-img { width: 85px; height: 85px; }
    .section-header h2 { font-size: 1.5rem; }
    .section-header p { font-size: 0.82rem; }
    /* Testimonials */
    #section-testimonials { padding: 16px 12px; }
    .testi-card { padding: 18px 12px; min-height: 240px; }
    .testi-card h3 { font-size: 15px; }
    .testi-card .quote { font-size: 12px; }
    /* Lead / Mentor */
    .lead-wrapper, .mentor-wrapper { flex-direction: column; padding: 20px 14px 0; text-align: center; align-items: center; }
    .lead-left, .lead-right, .mentor-left, .mentor-right { width: 100%; text-align: center; }
    .lead-tagline { font-size: 20px; }
    .lead-name { font-size: 15px; }
    .lead-role { font-size: 12px; }
    .lead-right img, .mentor-right img { max-width: 220px; height: 170px; margin: 0 auto; }
    .lead-bio { column-count: 1; font-size: 13px; margin-top: 14px; }
    .mentor-name { font-size: 20px; }
    .mentor-subtitle { font-size: 13px; }
    /* Work */
    #section-work { padding: 36px 14px; }
    .work-container { flex-direction: column; gap: 20px; text-align: center; }
    .work-content h2 { font-size: 20px; text-align: center; }
    .work-content p { font-size: 13px; }
    .btn-work { margin: 0 auto; display: inline-block; }
    /* Vision / Mission */
    #section-vision-mission { padding: 28px 14px; }
    .vm-heading { font-size: 20px; }
    .vm-block { padding: 16px 0; }
    .vm-block h2 { font-size: 20px; }
    /* About */
    #section-about { padding: 28px 14px; }
    .about-heading { font-size: 20px; }
    .about-label { font-size: 12px; }
}

/* =========================================
   7. NARROW MOBILE — 361px to 375px
   ========================================= */

@media (min-width: 361px) and (max-width: 375px) {
    .container, .container-sm { max-width: 100%; padding-left: 15px; padding-right: 15px; }
    /* Navbar */
    .mobile-header { padding: 4px 10px; min-height: 65px; }
    .mobile-logo img, .mobile-logo .custom-logo { height: 48px; }
    .mobile-toggle { font-size: 24px; padding-right: 16px; }
    /* Hero */
    #hero-section { min-height: auto; height: auto; padding: 72px 0 30px; }
    .hero-title { font-size: 20px; line-height: 1.2; padding-left: 15px; margin: 0px 0 14px; }
    .hero-subtitle { font-size: 13px; padding-left: 15px; margin-top: -18px; max-width: 100%; }
    .hero-image { position: absolute; width: 100%; bottom: 0; margin-top: 20px; }
    /* Design Future */
    #design-future { padding-top: 30px !important; padding-bottom: 24px !important; }
    .section-title { font-size: 22px; margin-bottom: 0px; }
    .section-desc { font-size: 13px; text-align: left; }
    .design-img { height: 130px; border-radius: 6px; }
    /* Smarter Cities */
    #smarter-cities { padding: 32px 14px 44px !important; min-height: auto !important; }
    .smarter-graphic-wrapper { height: 195px !important; margin-bottom: 0 !important; }
    .smarter-title { font-size: 16px; margin-bottom: 10px; }
    .smarter-desc { font-size: 13px; line-height: 1.65; margin-bottom: 22px; padding: 0 4px; }
    .btn-pill-white { padding: 10px 30px; font-size: 13px; }
    .line-1 {top: 16%;left: 4%;width: 52%;}
    .line-2 {bottom: 16%;right: 4%;width: 52%;}
    /* Products Section */
    #products-section { padding: 38px 0 46px; }
    .ps-header { margin-bottom: 22px; }
    .ps-label { font-size: 10px; letter-spacing: 2px; margin-bottom: 8px; }
    .ps-title { font-size: 22px; }
    .ps-desc { font-size: 13px; padding: 0 4px; }
    .ps-card { padding: 1.35rem; }
    .ps-card-img { height: 160px; }
    .ps-card-img img { height: 160px; }
    .ps-card-body { padding: 0; }
    .ps-card-title { font-size: 15px; }
    .ps-card-desc { font-size: 14px; margin-bottom: 14px; }
    .ps-card-btn { font-size: 12px; padding: 9px 22px; }
    /* Stats */
    #stats-section { padding: 38px 0; }
    .stat-number { font-size: clamp(24px, 6.5vw, 32px); }
    .stat-label { font-size: 10px; }
    .stat-item { padding-left: 14px; }
    /* Clients */
    .clients-title { font-size: 22px; }
    .clients-subtitle { font-size: 13px; }
    .logo-item { max-height: 40px; }
    /* Contact CTA */
    .section-padding { padding: 32px 0 !important; }
    .contact-title { font-size: 23px; text-align: left; }
    .contact-desc { font-size: 13px; }
    .get-in-touch { text-align: left; }
    .btn-custom { width: auto; padding: 10px 28px; font-size: 13px; display: inline-block; margin: 0; }
    /* Footer */
    #site-footer { padding: 38px 0 0; }
    .footer-grid { grid-template-columns: 1fr; gap: 26px; padding-bottom: 32px; }
    .footer-col-logo { text-align: left; }
    .footer-logo-wrap img, .footer-logo-wrap .custom-logo { width: 110px; }
    .footer-col-heading { font-size: 12px; margin-bottom: 14px; }
    .footer-info-text { font-size: 13px; }
    .footer-nav-list a { font-size: 13px; }
    .footer-col-social { flex-direction: column; align-items: flex-start; gap: 14px; }
    .footer-social-btn { width: 34px; height: 34px; }
    .footer-social-btn img { width: 15px; height: 15px; }
    .footer-tagline { font-size: 12.5px; max-width: 100%; }
    .footer-bottom-bar { padding: 14px 0; }
    .footer-copyright-text { font-size: 10px; }
    /* Timeline */
    #section-timeline { padding: 34px 15px 42px; }
    .timeline-header { margin-bottom: 26px; }
    .timeline-header h2 { font-size: 19px; }
    .big-number { font-size: 110px; }
    .image-circle-container { width: 150px; height: 150px; }
    .timeline-content p { font-size: 14px; }
    /* Awards */
    #section-awards { padding: 0 14px 22px; }
    .award-card { height: 230px; padding: 10px; }
    .award-img { width: 90px; height: 90px; }
    .section-header h2 { font-size: 1.6rem; }
    .section-header p { font-size: 0.85rem; }
    /* Testimonials */
    #section-testimonials { padding: 16px 14px; }
    .testi-card { padding: 20px 14px; min-height: 250px; }
    .testi-card h3 { font-size: 16px; }
    .testi-card .quote { font-size: 13px; }
    /* Lead / Mentor */
    .lead-wrapper, .mentor-wrapper { flex-direction: column; padding: 22px 15px 0; text-align: center; align-items: center; }
    .lead-left, .lead-right, .mentor-left, .mentor-right { width: 100%; text-align: center; }
    .lead-tagline { font-size: 21px; }
    .lead-name { font-size: 16px; }
    .lead-role { font-size: 13px; }
    .lead-right img, .mentor-right img { max-width: 230px; height: 175px; margin: 0 auto; }
    .lead-bio { column-count: 1; font-size: 13px; margin-top: 14px; }
    .mentor-name { font-size: 21px; }
    .mentor-subtitle { font-size: 13px; }
    /* Work */
    #section-work { padding: 38px 15px; }
    .work-container { flex-direction: column; gap: 22px; text-align: center; }
    .work-content h2 { font-size: 22px; text-align: center; }
    .work-content p { font-size: 13px; }
    .btn-work { margin: 0 auto; display: inline-block; }
    /* Vision / Mission */
    #section-vision-mission { padding: 30px 15px; }
    .vm-heading { font-size: 22px; }
    .vm-block { padding: 18px 0; }
    .vm-block h2 { font-size: 22px; }
    /* About */
    #section-about { padding: 30px 15px; }
    .about-heading { font-size: 22px; }
    .about-label { font-size: 12px; }
}

/* =========================================
   8. MOBILE MENU HEADER OFFSET (≤991px)
   ========================================= */

@media (max-width: 991px) {
    #hero-section {padding-top: 108px;padding-left: 31px;}
    .navbar-collapse { display: none !important; }
    .col-sm-6 { width: 100% !important; max-width: 100% !important; flex: 0 0 100% !important; }
    .footer-grid { grid-template-columns: 1fr !important; gap: 28px !important; }
    .footer-col-logo { text-align: left; }
    .footer-col-social { flex-direction: column; align-items: flex-start; gap: 16px; }
    .footer-tagline { max-width: 100%; }
    #stats-section .row { display: grid; grid-template-columns: 1fr 1fr; gap: 24px 16px; }
    #stats-section .col-6 { width: 100% !important; max-width: 100% !important; flex: none !important; }
}





/* =========================================
   10. 376px–410px OVERRIDES
   ========================================= */

@media (min-width: 376px) and (max-width: 410px) {
    .mobile-header { padding: 6px 14px; min-height: 65px; }
    .mobile-logo img, .mobile-logo .custom-logo { height: 52px; }
    .mobile-toggle { font-size: 24px; }
    #hero-section { padding-top: 62px !important; padding-left: 0px !important; }
    .hero-title { font-size: 22px; line-height: 1.2; padding-left: 14px; }
    .hero-subtitle { font-size: 13px; padding: 0px 28px 15px 14px; }
    .col-sm-6 { width: 100% !important; max-width: 100% !important; flex: 0 0 100% !important; }
    .ps-card-img img { height: 175px; }
    .ps-title { font-size: 24px; }
    .stat-number { font-size: 30px; }
    .stat-label { font-size: 10px; }
    .footer-grid { grid-template-columns: 1fr !important; gap: 26px !important; padding-bottom: 30px !important; }
}

/* --- max-width 320px --- */
@media (max-width: 320px) {
    .smarter-graphic-wrapper { height: 200px !important; margin-bottom: 0px !important; }
}
