
@import url('https://fonts.googleapis.com/css2?family=Exo+2:wght@400;500;600;700;800&family=Roboto:wght@400;500;700;900&display=swap');


/* ===== Global Variables ===== */
:root {
    --primary-dark: #0B2B3F;
    --primary-blue: #1a2e3f;
    --accent-cyan: #1acae1;
    --accent-purple: #8A2BE2;
    --gradient-primary:  linear-gradient(135deg, #0066ff, #00dbde) !important;
    --gradient-hover: linear-gradient(90deg, #8A2BE2, #1acae1);
    --text-dark: #111111;
    --text-gray: #6c757d;
    --text-light: #ffffff;
    --bg-light: #f8f9fa;
    --bg-white: #ffffff;
    --shadow-sm: 0 5px 20px rgba(0,0,0,0.05);
    --shadow-md: 0 10px 30px rgba(0,0,0,0.1);
    --shadow-lg: 0 15px 40px rgba(0,0,0,0.15);
    --border-radius: 8px;
    --border-radius-lg: 8px;
    --transition: all 0.3s ease;
      --heading-font:'Exo 2', sans-serif;
  --body-font:'Roboto', sans-serif;
  --font-main:'Roboto', sans-serif;

    /* ===== Font Family ===== */

  /*--font-main:'Plus Jakarta Sans','Inter',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;*/
}

*{margin:0;padding:0;box-sizing:border-box;}

html{
  scroll-behavior:smooth;
}

body{
  font-family:var(--font-main);
  background:var(--bg-page) !important;
  color:var(--text-dark);
  overflow-x:hidden;
  font-size:15px;
  font-weight:400;
  line-height:1.75;
}
body,
p,
a,
li,
div,
button,
input,
textarea,
select,
small,
label,
span{
  font-family:var(--body-font);
}

p{
  color:var(--text-gray);
  line-height:1.8;
  margin:0;
  font-size:15px;
  font-weight:400;
}

h1,h2,h3,h4,h5,h6,
.hero-title,
.visxp-h2-bold,
.title-wrap h2,
.story-wrap h3,
.rating-card h4,
.stat-pill h4,
.badge-card h5,
.industry-overlay h4{
  font-family:var(--heading-font) !important;
}

h1{
  font-size:52px;
  font-weight:800;
  letter-spacing:-1.5px;
  line-height:1.12;
}
h2{
  font-size:38px;
  font-weight:800;
  letter-spacing:-1.1px;
  line-height:1.18;
}
h3{
  font-size:28px;
  font-weight:800;
  letter-spacing:-0.7px;
  line-height:1.25;
}
h4{
  font-size:20px;
  font-weight:800;
  letter-spacing:-0.3px;
  line-height:1.3;
}
h5{
  font-size:16px;
  font-weight:700;
  letter-spacing:-0.1px;
  line-height:1.35;
}

.container {
    width: 100%;
    padding-right: 15px;
    padding-left: 15px;
    margin-right: auto;
    margin-left: auto;
}

/* ===== Section Titles ===== */
.section-title-wrapper {
    max-width: 750px;
    margin: 0 auto 60px;
    text-align: center;
}

.section-title {
    font-size: 34px;
    font-weight: 700;
    letter-spacing: -0.02em;
    margin-bottom: 12px;
    color: var(--text-dark);
}

.section-subtitle {
    font-size: 16px;
    color: var(--text-gray);
    line-height: 1.6;
    margin-bottom: 20px;
}

.section-divider {
    width: 150px;
    height: 4px;
    margin: 0 auto;
    border-radius: 8px;
    background: var(--gradient-primary);
}

/* ===== Buttons ===== */
.btn {
    display: inline-block;
    padding: 12px 30px;
    font-size: 16px;
    font-weight: 600;
    text-decoration: none;
    border-radius: 30px;
    transition: var(--transition);
    border: none;
    cursor: pointer;
    color: #fff;
}

.btn-glow {
    background: var(--gradient-primary);
    color: var(--text-light);
    box-shadow: 0 1px 2px rgba(26, 202, 225, 0.3);
}

.btn-glow:hover {
    color: #fff;
}

.btn-outline-light {
    background: transparent;
    color: var(--text-light);
    border: 2px solid var(--text-light);
}

/* ===== Hero Section ===== */
.hero {
    min-height: 80vh;
    display: flex;
    align-items: center;
    padding: 120px 0 80px;
    position: relative;
    overflow: hidden;
}

.hero::before {
    content: '';
    position: absolute;
    inset: 0;
    opacity: 0.1;
}

.hero-title {
    font-size: 44px;
    font-weight: 700;
    color: var(--text-light);
    margin-bottom: 20px;
    line-height: 1.2;
}

.hero-sub {
    font-size: 18px;
    color: rgba(255, 255, 255, 0.9);
    margin-bottom: 30px;
    max-width: 500px;
}

/* ===== Features Section ===== */
.features-section {
    padding: 80px 0;
    background: var(--bg-light);
}

.feature-card {
    background: var(--bg-white);
    padding: 30px;
    border-radius: var(--border-radius-lg);
    box-shadow: var(--shadow-sm);
    transition: var(--transition);
    height: 100%;
    text-align: center;
}

.feature-card:hover {
    transform: translateY(-10px);
    box-shadow: var(--shadow-lg);
}

.feature-icon i {
    font-size: 30px;
    color: var(--text-light);
}

.feature-card h5 {
    font-size: 20px;
    margin-bottom: 15px;
    color: var(--text-dark);
}

.feature-card p {
    color: var(--text-gray);
    margin-bottom: 0;
}

/* ===== Gallery Section ===== */
.gallery-section {
    padding: 80px 0;
    background: var(--bg-white);
}

.gallery-img {
    width: 100%;
    height: 260px;
    object-fit: cover;
    border-radius: var(--border-radius);
    cursor: pointer;
    transition: var(--transition);
    box-shadow: var(--shadow-sm);
}

.gallery-img:hover {
    transform: scale(1.05);
    box-shadow: var(--shadow-lg);
}

/* ===== Use Cases Section ===== */
.usecases-section {
    padding: 80px 0;
    background: var(--bg-light);
}

.usecase-card {
    background: var(--bg-white);
    border-radius: var(--border-radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: var(--transition);
    height: 100%;
}

.usecase-card:hover {
    transform: translateY(-10px);
    box-shadow: var(--shadow-lg);
}

.usecase-img {
    height: 220px;
    overflow: hidden;
}

.usecase-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: var(--transition);
}

.usecase-card:hover .usecase-img img {
    transform: scale(1.1);
}

.usecase-content {
    padding: 25px;
}

.usecase-content h5 {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 12px;
    color: var(--text-dark);
}

.usecase-content p {
    color: var(--text-gray);
    font-size: 15px;
    margin-bottom: 0;
}

/* ===== Applications Section ===== */
.applications-section {
    padding: 80px 0;
    background: var(--bg-white);
}

.app-img {
    width: 100%;
    height: 400px;
    object-fit: cover;
    border-radius: var(--border-radius-lg);
    box-shadow: var(--shadow-lg);
}

.application-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.application-list li {
    font-size: 18px;
    margin-bottom: 15px;
    font-weight: 500;
    color: var(--text-dark);
    display: flex;
    align-items: center;
}

.application-list li::before {
    content: '✔';
    color: #0066ff;
    font-weight: bold;
    margin-right: 10px;
    font-size: 20px;
}

/* ===== Trust Section ===== */
.trust {
    background: linear-gradient(135deg, var(--primary-dark), #02141f);
    padding: 80px 0;
    color: var(--text-light);
}

.trust h5 {
    font-size: 20px;
    color: var(--text-light);
    margin-bottom: 15px;
}

.trust p {
    color: rgba(255, 255, 255, 0.8);
}

/* ===== FAQ Section ===== */
.section-padding {
    padding: 80px 0;
}

.accordion-item {
    border: none;
    margin-bottom: 15px;
    border-radius: var(--border-radius) !important;
    overflow: hidden;
    box-shadow: var(--shadow-sm);
}

.accordion-header .accordion-button {
    font-weight: 600;
    color: var(--text-dark);
    background: var(--bg-white);
    padding: 20px 25px;
    border: none;
}

.accordion-header .accordion-button:not(.collapsed) {
    background: var(--gradient-primary);
    color: var(--text-light);
}

.accordion-header .accordion-button:focus {
    box-shadow: none;
    border-color: transparent;
}

.accordion-body {
    padding: 20px 25px;
    background: var(--bg-light);
    color: var(--text-gray);
}

/* ===== Demo Section ===== */
.demo {
    background: linear-gradient(135deg, var(--primary-dark), #02141f);
    padding: 80px 0;
}

.demo .form-control {
    padding: 15px 20px;
    border-radius: 8px;
    border: 2px solid transparent;
    transition: var(--transition);
    background: rgba(255, 255, 255, 0.1);
    color: var(--text-light);
}

.demo .form-control:focus {
    background: rgba(255, 255, 255, 0.15);
    border-color: var(--accent-cyan);
    box-shadow: none;
    outline: none;
}

.demo .form-control::placeholder {
    color: rgba(255, 255, 255, 0.5);
}

.demo .form-control.is-invalid {
    border-color: #dc3545;
    background: rgba(220, 53, 69, 0.1);
}

.invalid-feedback {
    color: #ff6b6b;
    font-size: 14px;
    margin-top: 5px;
}

/* ===== Sticky Button ===== */
.sticky-btn {
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 999;
}

.sticky-btn .btn {
    padding: 15px 30px;
    font-size: 16px;
    box-shadow: var(--shadow-lg);
}

/* ===== Image Modal ===== */
.image-modal {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.95);
    justify-content: center;
    align-items: center;
    z-index: 9999;
    cursor: pointer;
}

.image-modal img {
    max-width: 90%;
    max-height: 90%;
    border-radius: var(--border-radius-lg);
    box-shadow: var(--shadow-lg);
}

.image-modal.show {
    display: flex;
}

/* ===== Animation Classes ===== */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.fadeInUp {
    animation: fadeInUp 0.6s ease forwards;
}

/* ===== Utility Classes ===== */
.text-gradient {
    background: var(--gradient-primary);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.bg-gradient {
    background: var(--gradient-primary);
}

.shadow-hover {
    transition: var(--transition);
}

.shadow-hover:hover {
    box-shadow: var(--shadow-lg);
}

/* ===============================
   VISXP PREMIUM USECASE CARD
=================================*/
.visxp-card {
    position: relative;
    height: 240px;
    border-radius: 8px;
    overflow: hidden;
    cursor: pointer;
    box-shadow: 0 15px 35px rgba(0,0,0,0.12);
    transition: 0.4s ease;
    background: #000;
}

.visxp-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s ease;
}

.visxp-card:hover img {
    transform: scale(1.08);
}

.overlay {
    position: absolute;
    inset: 0;
    padding: 20px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    background: linear-gradient(
        to top,
        rgba(0,0,0,0.85) 25%,
        rgba(0,0,0,0.4) 60%,
        transparent 100%
    );
    color: #fff;
    transition: 0.4s ease;
}

.overlay h5 {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
    transition: transform 0.4s ease;
}

.card-content {
    opacity: 0;
    max-height: 0;
    overflow: hidden;
    transform: translateY(15px);
    transition: all 0.4s ease;
}

.visxp-card:hover .overlay h5 {
    transform: translateY(-10px);
}

.visxp-card:hover .card-content {
    opacity: 1;
    max-height: 200px;
    transform: translateY(0);
}

.card-content p {
    font-size: 14px;
    margin-top: 12px;
    line-height: 1.5;
    color: #fff;
}

.visxp-card:hover {
    box-shadow:
        0 20px 45px rgba(0,0,0,0.18),
        0 0 25px rgba(26,202,225,0.35);
}

/* ===== MINI KIOSK SECTION ===== */
.zk-mini-showcase {
  padding: 60px 0;
}

.zk-container {
  max-width: 920px;
  width: 100%;
  margin: auto;
  height: auto;
  padding: 0 16px;
}

.zk-title-main {
  text-align: center;
  font-weight: 600;
}

.zk-mini-card {
  width: 250px;
  height: auto;
  background: white;
  border-radius: 8px;
  padding: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.05);
  font-family: 'Inter', sans-serif;
}

.zk-image-container img {
  width: 100%;
  height: auto;
  object-fit: contain;
  border-radius: 8px;
}

.zk-heart-icon {
  position: absolute;
  top: 15px;
  right: 15px;
  background: rgba(0,0,0,0.2);
  color: white;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.zk-content-area {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 10px 10px 10px;
}

.zk-text-group h5 {
  margin: 0;
  font-size: 1.2rem;
  font-weight: 550;
  color: #333;
}

.zk-price {
  margin: 5px 0 0 0;
  font-weight: bold;
  font-size: 0.8rem;
  color: #0066ff;
}

.zk-action-btn {
  background: #f8f8f8;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.3s;
  cursor: pointer;
}

.zk-action-btn:hover { transform: scale(1.5); }

.brand-gradient {
    background: linear-gradient(135deg, #0066ff, #00dbde);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.visxp-h2-bold { 
    font-size: 2.5rem; 
    font-weight: 800; 
    letter-spacing: -1.5px; 
}

#bookDemo{
  margin-bottom: 50px;
}

.zk-stars i{
  color:#e6d938;
  font-size:12px;
}

/* ================= INTERACTIVE PRODUCT CARDS ================= */
.zk-mini-showcase{
  padding: 55px 0;
  background: #f3f4f6;
}

.zk-section-heading{
  text-align: center;
  margin-bottom: 28px;
}

.zk-section-heading h2{
  font-size: clamp(24px, 3.5vw, 32px);
  font-weight: 700;
  color: #111;
  margin-bottom: 8px;
  letter-spacing: -0.3px;
}

.zk-section-heading p{
  color: #6c757d;
  font-size: 13px;
  line-height: 1.6;
  max-width: 560px;
  margin: 0 auto;
}

.zk-heading-line{
  width: 100px;
  height: 3px;
  margin: 12px auto 0;
  border-radius: 50px;
  background: linear-gradient(90deg, #1acae1, #8A2BE2);
}

.zk-card-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(185px, 1fr));
  gap: 14px;
  align-items: stretch;
}

.zk-card{
  position: relative;
  overflow: hidden;
  border-radius: 8px;
  background: linear-gradient(180deg, #1a202d 0%, #0f141d 100%);
  border: 1px solid rgba(255,255,255,0.06);
  box-shadow: 0 12px 25px rgba(0,0,0,0.14);
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}

.zk-badge{
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 4;
  min-width: 42px;
  text-align: center;
  padding: 6px 8px;
  border-radius: 0 0 0 8px;
  background:  linear-gradient(135deg, #0066ff, #00dbde) !important;
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  line-height: 1;
  box-shadow: 0 8px 16px rgba(138,43,226,0.18);
}

.zk-card-visual{
  height: 185px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background:
    radial-gradient(circle at center, rgba(26,202,225,0.20) 0%, rgba(138,43,226,0.10) 28%, rgba(0,0,0,0) 62%),
    linear-gradient(180deg, #161c28 0%, #141a24 100%);
}

.zk-card-visual img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  margin-top:20px;
  margin-left:10px;
  margin-right:10px;
  border-radius: 8px;
  display: block;
  filter: drop-shadow(0 16px 22px rgba(0,0,0,0.35));
  transition: transform .35s ease;
}

.zk-card-body{
  background: linear-gradient(180deg, #3a3f49 0%, #2b3038 100%);
  padding: 12px 12px 11px;
  border-top-left-radius: 16px;
  border-top-right-radius: 16px;
  margin-top: -2px;
  position: relative;
}

.zk-card-content{
  display: grid;
  grid-template-columns: minmax(0, 1fr) 1px minmax(0, .92fr);
  gap: 10px;
  align-items: start;
}

.zk-left h3{
  margin: 0 0 8px;
  font-size: 18px;
  line-height: 0.95;
  font-weight: 800;
  color: #fff;
  text-transform: uppercase;
  letter-spacing: -0.4px;
}

.zk-left p{
  margin: 0 0 9px;
  font-size: 10.5px;
  line-height: 1.5;
  color: rgba(255,255,255,0.82);
}

.zk-stars{
  display: flex;
  gap: 5px;
}

.zk-divider{
  width: 1px;
  min-height: 100%;
  background: linear-gradient(
    180deg,
    rgba(255,255,255,0.02),
    rgba(26,202,225,0.95),
    rgba(138,43,226,0.65),
    rgba(255,255,255,0.02)
  );
  border-radius: 999px;
}

.zk-spec-col{
  display: grid;
  gap: 7px;
}

.zk-spec-item{
  line-height: 1.2;
}

.zk-spec-item span{
  display: block;
  margin-bottom: 2px;
  font-size: 8px;
  font-weight: 700;
  text-transform: uppercase;
  color: #1acae1;
  letter-spacing: .55px;
}

.zk-spec-item strong{
  display: block;
  font-size: 9px;
  font-weight: 500;
  line-height: 1.35;
  color: rgba(255,255,255,0.82);
}

.zk-btn-wrap{
  margin-top: 11px;
  display: flex;
  justify-content: center;
}

.zk-btn-view{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 104px;
  padding: 8px 14px;
  border-radius: 999px;
  color: #fff;
  text-decoration: none;
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .45px;
  background:  linear-gradient(135deg, #0066ff, #00dbde) !important;
  box-shadow: 0 10px 18px rgba(138,43,226,0.18);
  transition: transform .25s ease, box-shadow .25s ease;
}

.zk-btn-view:hover{
  transform: translateY(-2px);
  color: #fff;
}

/* ===== custom feature icons ===== */
.feature-card .feature-icon i {
    font-size: 45px;
    margin-bottom: 20px;
    display: inline-block;
    background: linear-gradient(90deg, #1acae1, #8A2BE2);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* ===== premium mobile only ===== */
@media (max-width: 767px) {
    :root{
        --fs-body:14px;
        --fs-h1:32px;
        --fs-h2:28px;
        --fs-h3:22px;
        --fs-h4:18px;
        --fs-h5:16px;
        --fs-h6:14px;
    }

    body{
        background:#f5f7fb;
    }

    p{
        font-size: var(--fs-body);
        line-height: 1.65;
    }

    .hero {
        padding: 88px 0 34px;
        text-align: left;
        min-height: auto;
    }

    .hero .container{
        padding-left:16px;
        padding-right:16px;
    }

    .hero-title,
    .visxp-h2-bold{
        font-size: 30px !important;
        line-height: 1.15 !important;
        letter-spacing: -0.8px !important;
        font-weight: 800 !important;
    }

    .hero-sub{
        font-size: 14px !important;
        line-height: 1.7 !important;
        max-width: 100% !important;
        margin-bottom: 18px !important;
    }

    .hero .mt-4{
        display:flex;
        flex-direction:column;
        gap:10px;
    }

    .hero .btn{
        display:flex !important;
        width:100% !important;
        justify-content:center;
        align-items:center;
        margin:0 !important;
        min-height:46px;
        border-radius:14px;
        font-size:14px;
    }

    .section-title,
    .section-title-wrapper .section-title,
    .zk-section-heading h2{
        font-size: 26px !important;
        line-height: 1.2 !important;
        letter-spacing: -0.6px !important;
        font-weight: 800 !important;
    }

    .section-subtitle,
    .zk-section-heading p{
        font-size: 14px !important;
        line-height: 1.65 !important;
    }

    .section-title-wrapper,
    .zk-section-heading{
        margin-bottom: 24px !important;
    }

    .section-divider,
    .zk-heading-line{
        width: 90px !important;
        height: 4px !important;
    }

    .features-section,
    .gallery-section,
    .usecases-section,
    .applications-section,
    .trust,
    .section-padding,
    .demo,
    .zk-mini-showcase{
        padding-top: 38px !important;
        padding-bottom: 38px !important;
    }

    .features-section .container,
    .gallery-section .container,
    .usecases-section .container,
    .applications-section .container,
    .trust .container,
    .section-padding .container,
    .demo .container,
    .zk-mini-showcase .zk-container{
        padding-left:16px !important;
        padding-right:16px !important;
    }

    .feature-card{
        padding:20px 16px !important;
        border-radius:20px !important;
        box-shadow:0 8px 24px rgba(11,43,63,.07) !important;
        background:rgba(255,255,255,.86) !important;
        backdrop-filter:blur(10px);
        -webkit-backdrop-filter:blur(10px);
    }

    .feature-card h5{
        font-size:18px !important;
        margin-bottom:10px !important;
        font-weight:700 !important;
    }

    .feature-card p{
        font-size:13px !important;
    }

    .feature-card .feature-icon i{
        font-size:38px !important;
        margin-bottom:14px !important;
    }

    .gallery-img{
        height:220px !important;
        border-radius:20px !important;
        box-shadow:0 10px 26px rgba(11,43,63,.08) !important;
    }

    .app-img{
        height:260px !important;
        border-radius:20px !important;
        box-shadow:0 10px 26px rgba(11,43,63,.08) !important;
        margin-bottom:20px !important;
    }

    .application-list li{
        font-size:14px !important;
        margin-bottom:12px !important;
        line-height:1.45 !important;
    }

    .accordion-item{
        border-radius:18px !important;
        overflow:hidden !important;
        box-shadow:0 8px 24px rgba(11,43,63,.07) !important;
    }

    .accordion-header .accordion-button{
        padding:16px 16px !important;
        font-size:15px !important;
    }

    .accordion-body{
        padding:14px 16px !important;
        font-size:13px !important;
        line-height:1.6 !important;
    }

    .demo .form-control{
        min-height:48px;
        font-size:14px;
        border-radius:14px;
        padding:12px 14px;
    }

    .demo .btn{
        width:100%;
        min-height:46px;
        border-radius:14px;
        font-size:14px;
    }

    .sticky-btn{
        bottom:12px;
        right:12px;
    }

    .sticky-btn .btn{
        padding:11px 14px;
        font-size:13px;
        border-radius:14px;
    }

    /* ===== premium touch carousels ===== */
    .visxp-mobile-carousel{
        overflow-x:auto !important;
        overflow-y:hidden !important;
        -webkit-overflow-scrolling:touch;
        scroll-snap-type:x mandatory;
        scrollbar-width:none;
        width:100%;
        padding-bottom:4px;
    }

    .visxp-mobile-carousel::-webkit-scrollbar{
        display:none;
    }

    .visxp-mobile-track{
        display:flex !important;
        flex-wrap:nowrap !important;
        gap:12px !important;
        width:max-content;
        align-items:stretch;
        padding-right:8px;
    }

    /* All Kiosk Categories carousel */
    #kioskCarousel{
        width:100%;
    }

    #kioskCarousel .visxp-mobile-track{
        display:flex !important;
        flex-wrap:nowrap !important;
        gap:12px !important;
        width:max-content !important;
    }

    #kioskCarousel .zk-card{
        flex:0 0 calc(100vw - 56px) !important;
        min-width:calc(100vw - 56px) !important;
        max-width:calc(100vw - 56px) !important;
        width:calc(100vw - 56px) !important;
        scroll-snap-align:start;
        border-radius:22px !important;
        overflow:hidden;
    }

    .zk-card-grid{
        display:flex !important;
        grid-template-columns:none !important;
        max-width:none !important;
        margin:0 !important;
    }

    .zk-card-visual{
        height:220px !important;
    }

    .zk-card-body{
        padding:14px 14px 12px !important;
        border-top-left-radius:20px !important;
        border-top-right-radius:20px !important;
    }

    .zk-left h3{
        font-size:17px !important;
        line-height:1.05 !important;
    }

    .zk-left p{
        font-size:11px !important;
    }

    .zk-spec-item span{
        font-size:8px !important;
    }

    .zk-spec-item strong{
        font-size:10px !important;
    }

    .zk-btn-view{
        min-width:110px !important;
        padding:9px 14px !important;
        font-size:10px !important;
    }

    /* built carousel */
    .visxp-built-carousel .col-md-3,
    .visxp-built-carousel .col-6{
        flex:0 0 calc(100vw - 56px) !important;
        max-width:calc(100vw - 56px) !important;
        min-width:calc(100vw - 56px) !important;
        margin-bottom:0 !important;
        scroll-snap-align:start;
    }

    .visxp-built-carousel .gallery-img{
        height:240px !important;
        width:100%;
        display:block;
    }

    /* use cases carousel */
    .visxp-usecase-carousel .col-lg-4,
    .visxp-usecase-carousel .col-md-6{
        flex:0 0 calc(100vw - 56px) !important;
        max-width:calc(100vw - 56px) !important;
        min-width:calc(100vw - 56px) !important;
        margin-bottom:0 !important;
        scroll-snap-align:start;
    }

    .visxp-usecase-carousel .visxp-card{
        height:280px !important;
        border-radius:22px !important;
        box-shadow:0 10px 26px rgba(11,43,63,.08) !important;
    }

    .visxp-usecase-carousel .overlay{
        padding:16px !important;
    }

    .visxp-usecase-carousel .overlay h5{
        font-size:18px !important;
    }

    .visxp-usecase-carousel .card-content p{
        font-size:13px !important;
        line-height:1.55 !important;
    }

    .visxp-card.active .overlay h5 {
        transform: translateY(-10px);
    }

    .visxp-card.active .card-content {
        opacity: 1;
        max-height: 200px;
        transform: translateY(0);
    }
}

@media (max-width: 575px) {
    .hero-title {
        font-size: 24px;
    }

    .hero .btn {
        display: block;
        width: 100%;
        margin: 10px 0;
    }

    .hero .me-3 {
        margin-right: 0 !important;
    }

    .section-title {
        font-size: 24px;
    }

    .section-subtitle {
        font-size: 14px;
    }

    .feature-icon {
        width: 60px;
        height: 60px;
    }

    .feature-icon i {
        font-size: 24px;
    }

    .feature-card h5 {
        font-size: 18px;
    }

    .feature-card p {
        font-size: 14px;
    }

    .gallery-img {
        height: 180px;
    }

    .usecase-content {
        padding: 20px;
    }

    .usecase-content h5 {
        font-size: 18px;
    }

    .usecase-content p {
        font-size: 14px;
    }

    .app-img {
        height: 250px;
    }

    .application-list li {
        font-size: 14px;
    }

    .accordion-header .accordion-button {
        padding: 15px 20px;
        font-size: 15px;
    }

    .accordion-body {
        padding: 15px 20px;
        font-size: 14px;
    }

    .sticky-btn {
        bottom: 15px;
        right: 15px;
    }

    .sticky-btn .btn {
        padding: 10px 20px;
        font-size: 13px;
    }
}

@media (max-width: 375px) {
    .hero-title {
        font-size: 22px;
    }

    .hero-sub {
        font-size: 14px;
    }

    .section-title {
        font-size: 22px;
    }

    .gallery-img {
        height: 160px;
    }

    .app-img {
        height: 200px;
    }

    .application-list li {
        font-size: 13px;
        margin-bottom: 10px;
    }

    .application-list li::before {
        font-size: 16px;
    }
}

@media print {
    .sticky-btn,
    .image-modal {
        display: none !important;
    }
}
