/* ============================================================
   YourTechBuddy — Core Styles
   Design system derived from the provided UI mockups.
   ============================================================ */

:root{
  --navy:#071829;
  --navy-2:#0b2238;
  --navy-3:#0e2a45;
  --blue:#1294FF;
  --blue-dark:#0c79d6;
  --cyan:#3AD6FF;
  --white:#FFFFFF;
  --bg:#F5F8FC;
  --border:#DCE4EE;
  --text:#2b3a4a;
  --muted:#6a7b8c;
  --muted-2:#8a99a8;
  --radius:16px;
  --radius-sm:10px;
  --radius-lg:24px;
  --shadow-sm:0 2px 10px rgba(7,24,41,.06);
  --shadow:0 10px 30px rgba(7,24,41,.08);
  --shadow-lg:0 20px 50px rgba(7,24,41,.14);
  --glow:0 8px 24px rgba(18,148,255,.35);
  --maxw:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --header-h:74px;
  --font:'Plus Jakarta Sans','Manrope',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;font-family:var(--font);color:var(--text);background:var(--white);
  line-height:1.6;font-size:16px;overflow-x:hidden;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
h1,h2,h3,h4{font-family:var(--font);color:var(--navy);line-height:1.18;margin:0 0 .5em;font-weight:800;letter-spacing:-.02em;}
h1{font-size:clamp(2rem,4.6vw,3.3rem);}
h2{font-size:clamp(1.6rem,3.2vw,2.3rem);}
h3{font-size:1.18rem;}
p{margin:0 0 1rem;}
ul{margin:0;padding:0;list-style:none;}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px;}
.section{padding:74px 0;}
.section-sm{padding:48px 0;}
.center{text-align:center;}
.muted{color:var(--muted);}
.eyebrow{display:inline-block;font-weight:700;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--blue);margin-bottom:10px;}
.section-head{max-width:680px;margin:0 auto 44px;text-align:center;}
.section-head p{color:var(--muted);font-size:1.05rem;}
.lead{font-size:1.12rem;color:var(--muted);}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-weight:700;font-size:.96rem;padding:13px 24px;border-radius:12px;
  transition:transform .18s var(--ease),box-shadow .25s var(--ease),background .2s,color .2s;
  white-space:nowrap;border:2px solid transparent;}
.btn:active{transform:translateY(1px) scale(.99);}
.btn-primary{background:linear-gradient(135deg,var(--cyan) 0%,var(--blue) 45%,var(--blue-dark) 100%);background-size:160% 160%;background-position:0% 50%;color:#fff;box-shadow:0 8px 20px rgba(18,148,255,.35);}
.btn-primary:hover{background-position:100% 50%;box-shadow:0 12px 30px rgba(18,148,255,.5),0 0 0 1px rgba(58,214,255,.3);transform:translateY(-2px);}
.btn-outline{background:linear-gradient(180deg,#fff 0%,#f3f8ff 100%);color:var(--navy);border-color:var(--border);box-shadow:0 2px 8px rgba(7,24,41,.05);}
.btn-outline:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-2px);box-shadow:0 8px 22px rgba(18,148,255,.18);background:linear-gradient(180deg,#fff 0%,#eaf4ff 100%);}
.btn-ghost-light{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.3);backdrop-filter:blur(6px);}
.btn-ghost-light:hover{background:rgba(255,255,255,.16);transform:translateY(-2px);}
.btn-white{background:#fff;color:var(--navy);}
.btn-white:hover{transform:translateY(-2px);box-shadow:var(--shadow);}
.btn-sm{padding:9px 16px;font-size:.85rem;border-radius:10px;}
.btn-lg{padding:15px 30px;font-size:1.02rem;}
.btn svg{width:18px;height:18px;flex-shrink:0;}
.btn-lg svg{width:20px;height:20px;}
.btn-block{width:100%;}
.btn .ic{width:18px;height:18px;}

.link-more{display:inline-flex;align-items:center;gap:6px;color:var(--blue);font-weight:700;font-size:.9rem;transition:gap .2s var(--ease);}
.link-more svg{width:16px;height:16px;flex-shrink:0;}
.link-more:hover{gap:11px;}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(150%) blur(12px);border-bottom:1px solid var(--border);}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);gap:18px;}
.logo{display:flex;align-items:center;}
.logo img{height:36px;width:auto;}
.main-nav{display:flex;align-items:center;gap:6px;}
.main-nav a{padding:9px 14px;border-radius:9px;font-weight:600;font-size:.95rem;color:#3a4b5c;
  position:relative;transition:color .2s,background .2s;}
.main-nav a:hover{color:var(--blue);background:rgba(18,148,255,.07);}
.main-nav a.active{color:var(--blue);}
.main-nav a.active::after{content:"";position:absolute;left:14px;right:14px;bottom:2px;height:2px;background:var(--blue);border-radius:2px;}
.header-actions{display:flex;align-items:center;gap:12px;}
.cart-link{position:relative;display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;
  border-radius:11px;border:1px solid var(--border);color:var(--navy);transition:.2s;}
.cart-link:hover{border-color:var(--blue);color:var(--blue);}
.cart-link svg{width:21px;height:21px;}
.cart-count{position:absolute;top:-7px;right:-7px;background:var(--blue);color:#fff;font-size:.68rem;
  font-weight:700;min-width:19px;height:19px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 5px;
  box-shadow:0 2px 6px rgba(18,148,255,.4);}
.menu-toggle{display:none;width:44px;height:44px;border-radius:11px;border:1px solid var(--border);
  flex-direction:column;gap:5px;align-items:center;justify-content:center;}
.menu-toggle span{width:20px;height:2px;background:var(--navy);border-radius:2px;transition:.3s var(--ease);}
.menu-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.menu-toggle.open span:nth-child(2){opacity:0;}
.menu-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:80;visibility:hidden;}
.mobile-menu .overlay{position:absolute;inset:0;background:rgba(7,24,41,.5);opacity:0;transition:opacity .3s;}
.mobile-menu .panel{position:absolute;top:0;right:0;height:100%;width:min(86vw,360px);background:var(--navy);
  transform:translateX(100%);transition:transform .35s var(--ease);display:flex;flex-direction:column;padding:22px;overflow-y:auto;}
.mobile-menu.open{visibility:visible;}
.mobile-menu.open .overlay{opacity:1;}
.mobile-menu.open .panel{transform:translateX(0);}
.mm-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:26px;}
.mm-top img{height:32px;}
.mm-close{color:#fff;font-size:1.6rem;width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.08);}
.mobile-menu nav a{display:flex;align-items:center;justify-content:space-between;color:#cfe0f0;font-weight:600;
  font-size:1.05rem;padding:15px 8px;border-bottom:1px solid rgba(255,255,255,.08);transition:.2s;}
.mobile-menu nav a:hover,.mobile-menu nav a.active{color:#fff;padding-left:14px;}
.mobile-menu nav a svg{width:20px;height:20px;flex-shrink:0;color:var(--blue);}
.mobile-menu .mm-cta{margin-top:auto;padding-top:22px;display:flex;flex-direction:column;gap:12px;}

/* ---------- Hero ---------- */
.hero{position:relative;background:var(--navy);color:#fff;overflow:hidden;}
.hero-media{position:absolute;inset:0;z-index:0;}
.hero-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:right center;
  border-radius:0;box-shadow:none;transform-origin:70% 50%;animation:heroDrift 24s ease-in-out infinite alternate;}
@keyframes heroDrift{
  0%{transform:scale(1.04) translate(0,0);}
  100%{transform:scale(1.12) translate(-1.5%,-1%);}
}
/* homepage hero crossfade slideshow */
.hero-slideshow .hero-slide{opacity:0;transition:opacity 1.6s ease-in-out;will-change:opacity;}
.hero-slideshow .hero-slide.is-active{opacity:1;}
@media (prefers-reduced-motion:reduce){
  .hero-slideshow .hero-slide{transition:opacity .6s ease-in-out;animation:none;transform:scale(1.04);}
}
.hero-glow{display:none;}
.hero::before{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg,var(--navy) 0%,var(--navy) 24%,rgba(7,24,41,.96) 42%,rgba(7,24,41,.68) 58%,rgba(7,24,41,.28) 76%,rgba(7,24,41,.05) 92%,rgba(7,24,41,0) 100%);}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;
  padding:74px 0 80px;min-height:480px;}
.hero h1{color:#fff;}
.hero p.sub{color:#bcd0e4;font-size:1.12rem;max-width:520px;margin-bottom:26px;}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:30px;}
.trust-badges{display:flex;flex-wrap:nowrap;gap:8px;}
.trust-badge{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.15);border-radius:10px;padding:7px 11px;font-size:.78rem;font-weight:600;color:#e6eef6;white-space:nowrap;}
.trust-badge .tb-ic{width:22px;height:22px;border-radius:6px;background:rgba(18,148,255,.22);color:var(--cyan);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.trust-badge svg{width:13px;height:13px;}

/* page hero (inner pages) */
.page-hero{position:relative;background:var(--navy);color:#fff;overflow:hidden;}
.page-hero{position:relative;background:var(--navy);color:#fff;overflow:hidden;isolation:isolate;}
.page-hero-media{position:absolute;inset:0;z-index:0;}
.page-hero-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:right center;
  border-radius:0;box-shadow:none;transform-origin:75% 45%;animation:heroDrift 28s ease-in-out infinite alternate;}
.page-hero::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(90deg,var(--navy) 0%,var(--navy) 26%,rgba(7,24,41,.94) 42%,rgba(7,24,41,.62) 58%,rgba(7,24,41,.2) 78%,rgba(7,24,41,0) 100%);}
.page-hero::before{display:none;}
.page-hero-grid{position:static;display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center;padding:56px 0;min-height:340px;}
.page-hero-grid>*{position:relative;z-index:2;}
.page-hero h1{color:#fff;}
.page-hero p{color:#bcd0e4;font-size:1.08rem;max-width:540px;}
.breadcrumb{display:flex;gap:8px;align-items:center;font-size:.85rem;color:#8fb0cf;margin-bottom:16px;}
.breadcrumb a:hover{color:#fff;}
.breadcrumb span{opacity:.6;}

/* ---------- Cards: generic ---------- */
.grid{display:grid;gap:24px;}
.g-2{grid-template-columns:repeat(2,1fr);}
.g-3{grid-template-columns:repeat(3,1fr);}
.g-4{grid-template-columns:repeat(4,1fr);}
.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:26px;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s;}
.card.hoverable:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:#c4d4e6;}

/* support-type cards */
.support-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:-58px;position:relative;z-index:5;align-items:stretch;}
.support-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);
  transition:transform .25s var(--ease),box-shadow .25s;display:flex;flex-direction:column;}
.support-card.reveal:hover,.support-card:hover{transform:translateY(-8px) scale(1.03);box-shadow:0 22px 48px rgba(7,24,41,.18),0 0 0 1px rgba(18,148,255,.2);z-index:2;}
.support-card .ic-round{width:62px;height:62px;border-radius:16px;background:#eaf4ff;display:flex;align-items:center;justify-content:center;margin-bottom:16px;transition:transform .28s var(--ease),background .28s;}
.support-card:hover .ic-round{transform:scale(1.08) rotate(-4deg);background:#dcecff;}
.support-card .ic-round img{width:38px;height:38px;}
.support-card h3{margin-bottom:8px;}
.support-card p{color:var(--muted);font-size:.95rem;margin-bottom:18px;}
.support-card .btn{margin-top:auto;}

/* service cards */
.service-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:24px;
  transition:transform .28s var(--ease),box-shadow .28s,border-color .28s;display:flex;flex-direction:column;}
.service-card.reveal:hover,.service-card:hover{transform:translateY(-8px) scale(1.035);box-shadow:0 22px 48px rgba(7,24,41,.16),0 0 0 1px rgba(18,148,255,.25);border-color:transparent;z-index:2;}
.service-card .ic{width:52px;height:52px;border-radius:13px;background:#eaf4ff;display:flex;align-items:center;justify-content:center;margin-bottom:14px;
  transition:transform .28s var(--ease),background .28s;}
.service-card:hover .ic{transform:scale(1.1) rotate(-4deg);background:#dcecff;}
.service-card .ic img{width:32px;height:32px;}
.service-card h3{font-size:1.05rem;margin-bottom:6px;}
.service-card p{color:var(--muted);font-size:.9rem;margin-bottom:14px;flex:1;}
.service-card .row{display:flex;align-items:center;justify-content:space-between;margin-top:auto;}
.service-card .link-more{background:#eaf4ff;color:var(--blue);padding:8px 14px;border-radius:10px;font-size:.85rem;
  transition:gap .2s var(--ease),background .2s,color .2s,box-shadow .2s,transform .2s;}
.service-card:hover .link-more{background:linear-gradient(135deg,var(--cyan),var(--blue));color:#fff;
  box-shadow:0 6px 16px rgba(18,148,255,.35);gap:10px;}
.price-from{font-weight:800;color:var(--navy);font-size:.95rem;}
.price-from small{font-weight:600;color:var(--muted);font-size:.72rem;display:block;}

/* product cards */
.product-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .25s var(--ease),box-shadow .25s;}
.product-card.reveal:hover,.product-card:hover{transform:translateY(-8px) scale(1.025);box-shadow:0 22px 48px rgba(7,24,41,.16),0 0 0 1px rgba(18,148,255,.2);z-index:2;}
.product-card .pimg{position:relative;background:#f1f5fa;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.product-card .pimg img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease);}
.product-card:hover .pimg img{transform:scale(1.05);}
.badge{position:absolute;top:12px;left:12px;background:var(--blue);color:#fff;font-size:.7rem;font-weight:700;
  padding:5px 10px;border-radius:20px;letter-spacing:.02em;box-shadow:0 3px 8px rgba(18,148,255,.3);}
.badge.green{background:#16a34a;box-shadow:0 3px 8px rgba(22,163,74,.3);}
.badge.amber{background:#f59e0b;}
.badge.navy{background:var(--navy);}
.product-card .pbody{padding:18px;display:flex;flex-direction:column;flex:1;}
.product-card h3{font-size:1rem;margin-bottom:6px;}
.product-card .pdesc{color:var(--muted);font-size:.85rem;margin-bottom:12px;flex:1;}
.product-card .pprice{font-weight:800;color:var(--navy);font-size:1.15rem;margin-bottom:12px;}
.product-card .pactions{display:flex;gap:8px;}
.product-card .pactions .btn{flex:1;}
.rating{display:inline-flex;align-items:center;gap:4px;color:#f59e0b;font-size:.85rem;font-weight:700;}
.rating .stars{letter-spacing:1px;}
.rating .count{color:var(--muted);font-weight:600;}

/* category chips */
.cat-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;
  transition:transform .25s var(--ease),box-shadow .25s;}
.cat-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);}
.cat-card .cimg{aspect-ratio:1/1;background:#f1f5fa;overflow:hidden;}
.cat-card .cimg img{width:100%;height:100%;object-fit:cover;}
.cat-card .cbody{padding:16px;}
.cat-card h3{font-size:1rem;margin-bottom:4px;}
.cat-card .cprice{color:var(--blue);font-weight:800;font-size:.95rem;}
.cat-card p{font-size:.82rem;color:var(--muted);margin-bottom:10px;}

/* how it works */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;position:relative;}
.steps::before{content:"";position:absolute;top:36px;left:12%;right:12%;height:2px;
  background:repeating-linear-gradient(90deg,var(--border) 0 8px,transparent 8px 16px);z-index:0;}
.step{text-align:center;position:relative;z-index:1;}
.step .num{position:absolute;top:-6px;left:50%;transform:translateX(22px);background:var(--blue);color:#fff;
  width:24px;height:24px;border-radius:50%;font-size:.78rem;font-weight:700;display:flex;align-items:center;justify-content:center;border:3px solid #fff;}
.step .ic{width:74px;height:74px;border-radius:50%;background:#fff;border:1px solid var(--border);margin:0 auto 16px;
  display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);}
.step .ic img{width:42px;height:42px;}
.step h3{font-size:1.02rem;margin-bottom:6px;}
.step p{color:var(--muted);font-size:.88rem;}

/* why choose / trust */
.trust-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:24px;text-align:center;
  transition:transform .25s var(--ease),box-shadow .25s;}
.trust-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);}
.trust-card .ic{width:58px;height:58px;border-radius:50%;background:#eaf4ff;margin:0 auto 14px;display:flex;align-items:center;justify-content:center;}
.trust-card .ic img{width:34px;height:34px;}
.trust-card h3{font-size:1rem;margin-bottom:6px;}
.trust-card p{color:var(--muted);font-size:.86rem;}

/* recent fixes */
.fix-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;
  transition:transform .25s var(--ease),box-shadow .25s;}
.fix-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);}
/* About — Who We Help cards (desktop keeps full descriptions) */
.who-card{padding:24px;position:relative;}
.who-card h3{margin-bottom:8px;}
.who-card .muted{margin:0;}
.who-toggle{display:none;}
.fix-card .fimg{aspect-ratio:16/10;overflow:hidden;background:#f1f5fa;}
.fix-card .fimg img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease);}
.fix-card:hover .fimg img{transform:scale(1.05);}
.fix-card .fbody{padding:20px;}
.chip{display:inline-block;background:#eaf4ff;color:var(--blue);font-size:.7rem;font-weight:700;padding:4px 11px;border-radius:20px;margin-bottom:10px;}
.fix-card h3{font-size:1.05rem;margin-bottom:6px;}
.fix-card p{color:var(--muted);font-size:.88rem;}

/* Recent Tech Fixes laid out as carousel slides (3 per view on desktop) */
.carousel-track{align-items:stretch;}
.carousel-track .fix-card{flex:0 0 calc((100% - 48px)/3);}

/* testimonials — Google-style review slider */
.reviews-summary{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:30px;}
.reviews-summary .rs-score{font-size:1.7rem;font-weight:800;color:var(--navy);}
.reviews-summary .rs-stars{color:#fbbc05;letter-spacing:2px;font-size:1.3rem;}
.reviews-summary .rs-meta{color:var(--muted);font-size:.9rem;}
.reviews-summary .rs-g{display:inline-flex;align-items:center;gap:6px;font-weight:700;color:var(--navy);font-size:.9rem;
  background:#fff;border:1px solid var(--border);border-radius:30px;padding:6px 14px;box-shadow:var(--shadow-sm);}
.reviews-summary .rs-g svg{width:16px;height:16px;}

.reviews-slider{position:relative;display:flex;align-items:center;gap:14px;}
.reviews-viewport{overflow:hidden;flex:1;}
.testimonials{display:flex;gap:24px;transition:transform .55s cubic-bezier(.4,0,.2,1);will-change:transform;}
.testi{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:26px;
  flex:0 0 calc((100% - 48px)/3);box-sizing:border-box;box-shadow:0 6px 20px rgba(7,24,41,.05);
  display:flex;flex-direction:column;}
.testi-head{display:flex;align-items:center;gap:12px;margin-bottom:12px;}
.testi-avatar{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:700;font-size:1rem;flex-shrink:0;}
.testi-id{flex:1;min-width:0;}
.testi-id b{display:block;color:var(--navy);font-size:.95rem;}
.testi-id span{color:var(--muted);font-size:.78rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.testi-g{flex-shrink:0;}
.testi-g svg{width:22px;height:22px;display:block;}
.testi-stars{display:flex;align-items:center;gap:8px;margin-bottom:12px;}
.testi-stars svg{width:17px;height:17px;fill:#fbbc05;}
.testi-when{color:var(--muted);font-size:.78rem;margin-left:2px;}
.testi blockquote{margin:0;color:#3a4b5c;font-size:.95rem;line-height:1.6;}
.rev-arrow{flex-shrink:0;width:46px;height:46px;border-radius:50%;background:#fff;border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;color:var(--navy);box-shadow:var(--shadow-sm);
  transition:background .2s,color .2s,transform .2s,box-shadow .2s;cursor:pointer;}
.rev-arrow:hover{background:var(--blue);color:#fff;border-color:var(--blue);box-shadow:0 8px 20px rgba(18,148,255,.35);transform:scale(1.08);}
.rev-arrow svg{width:20px;height:20px;}
.rev-prev svg{transform:rotate(180deg);}
.reviews-dots{display:flex;justify-content:center;gap:8px;margin-top:26px;}
.reviews-dots button{width:9px;height:9px;border-radius:50%;background:#c4d4e6;border:none;cursor:pointer;
  transition:width .25s,background .25s;padding:0;}
.reviews-dots button.active{width:26px;border-radius:6px;background:var(--blue);}

/* CTA band */
.cta-band{position:relative;border-radius:var(--radius-lg);overflow:hidden;color:#fff;padding:46px;background:var(--navy);}
.cta-band .bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.55;}
.cta-band::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,24,41,.92),rgba(7,24,41,.6));}
.cta-band .cta-inner{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;}
.cta-band h2{color:#fff;margin-bottom:6px;}
.cta-band p{color:#bcd0e4;margin:0;}
.cta-band .cta-actions{display:flex;gap:12px;flex-wrap:wrap;}
.cta-icon{width:64px;height:64px;border-radius:16px;background:rgba(18,148,255,.25);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.cta-icon svg{width:30px;height:30px;color:#fff;}
.cta-left{display:flex;align-items:center;gap:20px;}

/* wide promo banner */
.promo{position:relative;border-radius:var(--radius-lg);overflow:hidden;min-height:230px;display:flex;align-items:center;color:#fff;}
.promo img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.promo::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,24,41,.9),rgba(7,24,41,.35));}
.promo .promo-inner{position:relative;z-index:2;padding:36px 44px;max-width:560px;}
.promo h2{color:#fff;}
.promo p{color:#cfe0f0;}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy);color:#a9bdd2;padding:60px 0 24px;}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr 1.4fr;gap:34px;}
.site-footer .f-logo img{height:34px;margin-bottom:16px;}
.site-footer p{font-size:.9rem;color:#9fb4c9;}
.site-footer h4{color:#fff;font-size:.95rem;letter-spacing:.04em;margin-bottom:16px;}
.site-footer ul li{margin-bottom:9px;}
.site-footer ul a{font-size:.88rem;color:#a9bdd2;transition:color .2s,padding .2s;}
.site-footer ul a:hover{color:#fff;}
.f-contact li{display:flex;align-items:flex-start;gap:10px;font-size:.88rem;margin-bottom:12px;}
.f-contact svg{width:17px;height:17px;color:var(--blue);flex-shrink:0;margin-top:3px;}
.f-social{display:flex;gap:10px;margin-top:18px;}
.f-social a{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;transition:.2s;}
.f-social a:hover{background:var(--blue);transform:translateY(-2px);}
.f-social svg{width:18px;height:18px;color:#fff;}
.newsletter-form{display:flex;gap:8px;margin-top:6px;flex-wrap:wrap;}
.newsletter-form input{flex:1;min-width:0;padding:11px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);color:#fff;font-family:inherit;font-size:.88rem;}
.newsletter-form input::placeholder{color:#7e93a8;}
.newsletter-form input:focus{outline:none;border-color:var(--blue);}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:40px;padding-top:22px;display:flex;
  justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.82rem;color:#8298ad;}
.footer-bottom a:hover{color:#fff;}
.form-note{font-size:.82rem;margin-top:8px;}
.form-note.ok{color:#5bd6a0;}

/* ---------- Forms ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:4px;}
.field.full{grid-column:1/-1;}
.field label{font-weight:600;font-size:.88rem;color:var(--navy);}
.field label .req{color:#e23b3b;}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1.5px solid var(--border);
  border-radius:11px;font-family:inherit;font-size:.95rem;color:var(--text);background:#fff;transition:border-color .2s,box-shadow .2s;}
.field textarea{resize:vertical;min-height:120px;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);
  box-shadow:0 0 0 4px rgba(18,148,255,.12);}
.field input.invalid,.field select.invalid,.field textarea.invalid{border-color:#e23b3b;box-shadow:0 0 0 4px rgba(226,59,59,.1);}
.field .err{color:#e23b3b;font-size:.78rem;display:none;}
.field .err.show{display:block;}
.check-row{display:flex;align-items:flex-start;gap:10px;font-size:.88rem;color:var(--muted);}
.check-row input{width:18px;height:18px;margin-top:3px;accent-color:var(--blue);flex-shrink:0;}
.form-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow-sm);}
.form-success{display:none;background:#e8f8ef;border:1px solid #b6e6cc;color:#157a4c;border-radius:12px;padding:16px 18px;
  font-weight:600;margin-bottom:18px;animation:popIn .4s var(--ease);}
.form-success.show{display:block;}

/* info cards (booking/contact side) */
.info-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px;}
.info-card .ic{width:46px;height:46px;border-radius:12px;background:#eaf4ff;display:flex;align-items:center;justify-content:center;margin-bottom:12px;}
.info-card .ic img{width:28px;height:28px;}
.info-card .ic svg{width:24px;height:24px;color:var(--blue);}
.info-card h3{font-size:1rem;margin-bottom:6px;}
.info-card p{font-size:.88rem;color:var(--muted);margin:0;}
.booking-aside .info-card .bk-toggle{display:none;}

/* ---------- FAQ accordion ---------- */
.faq-cats{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:30px;}
.faq-cat{padding:9px 18px;border-radius:30px;border:1.5px solid var(--border);background:#fff;font-weight:600;
  font-size:.88rem;color:var(--navy);transition:.2s;}
.faq-cat:hover{border-color:var(--blue);color:var(--blue);}
.faq-cat.active{background:var(--blue);color:#fff;border-color:var(--blue);}

/* Help Center categories — single scrollable row, styled like the Products page */
.faq-cat-bar{margin-bottom:30px;}
.faq-cat-bar .faq-cat{flex:0 0 auto;padding:8px 17px;border:1px solid var(--border);border-radius:999px;
  background:#fff;color:var(--navy);font-family:inherit;font-weight:600;font-size:.88rem;line-height:1;
  white-space:nowrap;cursor:pointer;box-shadow:0 1px 3px rgba(7,24,41,.05);
  transition:transform .22s var(--ease),box-shadow .25s,border-color .22s,background .25s,color .22s;}
.faq-cat-bar .faq-cat:hover{transform:translateY(-2px);border-color:var(--blue);box-shadow:0 10px 24px rgba(18,148,255,.16);}
.faq-cat-bar .faq-cat:focus-visible{outline:2px solid var(--blue);outline-offset:2px;}
.faq-cat-bar .faq-cat.active{background:linear-gradient(135deg,var(--cyan) 0%,var(--blue) 55%,var(--blue-dark) 100%);
  border-color:transparent;color:#fff;box-shadow:0 10px 26px rgba(18,148,255,.4);}
.accordion{max-width:820px;margin:0 auto;}

/* ---------- Products: icon category filter strip ---------- */
.cat-filter-strip{padding:36px 0 4px;}
.section--shop{padding-top:30px;}
.cat-filter-wrap{position:relative;}
.cat-filter-bar{overflow-x:auto;padding:6px 22px;
  scrollbar-width:none;-ms-overflow-style:none;}
.cat-filter-bar::-webkit-scrollbar{display:none;}
.cat-filter-track{display:flex;gap:10px;width:max-content;margin:0 auto;}

/* edge fades — only visible when there is more to scroll that way */
.cat-filter-wrap::before,
.cat-filter-wrap::after{content:"";position:absolute;top:0;bottom:0;width:60px;z-index:2;
  pointer-events:none;opacity:0;transition:opacity .25s;}
.cat-filter-wrap::before{left:0;background:linear-gradient(90deg,var(--white) 20%,rgba(255,255,255,0));}
.cat-filter-wrap::after{right:0;background:linear-gradient(270deg,var(--white) 20%,rgba(255,255,255,0));}
.cat-filter-wrap.can-prev::before{opacity:1;}
.cat-filter-wrap.can-next::after{opacity:1;}

/* chevron scroll buttons — appear only when scrollable in that direction */
.cat-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:3;
  width:38px;height:38px;border-radius:50%;border:1px solid var(--border);background:#fff;
  color:var(--navy);display:flex;align-items:center;justify-content:center;cursor:pointer;
  box-shadow:0 6px 18px rgba(7,24,41,.16);
  opacity:0;visibility:hidden;transition:opacity .25s,visibility .25s,background .2s,color .2s,border-color .2s;}
.cat-nav svg{width:18px;height:18px;}
.cat-nav--prev{left:4px;}
.cat-nav--next{right:4px;}
.cat-nav:hover{background:var(--blue);color:#fff;border-color:var(--blue);}
.cat-nav:focus-visible{outline:2px solid var(--blue);outline-offset:2px;}
.cat-filter-wrap.can-prev .cat-nav--prev{opacity:1;visibility:visible;}
.cat-filter-wrap.can-next .cat-nav--next{opacity:1;visibility:visible;}

.cat-filter{flex:0 0 auto;display:inline-flex;align-items:center;gap:9px;
  padding:6px 16px 6px 6px;background:#fff;border:1px solid var(--border);border-radius:999px;cursor:pointer;
  font-family:inherit;font-weight:600;font-size:.84rem;color:var(--navy);line-height:1;white-space:nowrap;
  box-shadow:0 1px 3px rgba(7,24,41,.05);
  transition:transform .22s var(--ease),box-shadow .25s,border-color .22s,background .25s,color .22s;}
.cat-filter .ci{width:32px;height:32px;border-radius:50%;background:#eaf4ff;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;transition:background .25s;}
.cat-filter .ci img{width:20px;height:20px;}
.cat-filter .ci svg{width:17px;height:17px;color:var(--blue);}
.cat-filter:hover{transform:translateY(-2px);border-color:var(--blue);
  box-shadow:0 10px 24px rgba(18,148,255,.16);}
.cat-filter:focus-visible{outline:2px solid var(--blue);outline-offset:2px;}
.cat-filter.active{background:linear-gradient(135deg,var(--cyan) 0%,var(--blue) 55%,var(--blue-dark) 100%);
  border-color:transparent;color:#fff;box-shadow:0 10px 26px rgba(18,148,255,.4);}
.cat-filter.active .ci{background:#fff;}
.cat-filter.active .ci svg{color:var(--blue);}
.acc-item{background:#fff;border:1px solid var(--border);border-radius:12px;margin-bottom:12px;overflow:hidden;transition:box-shadow .2s,border-color .2s;}
.acc-item.open{box-shadow:var(--shadow-sm);border-color:#c4d4e6;}
.acc-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 22px;
  text-align:left;font-weight:700;color:var(--navy);font-size:1rem;}
.acc-q .plus{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:#eaf4ff;color:var(--blue);
  display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:transform .3s var(--ease);}
.acc-item.open .acc-q .plus{transform:rotate(45deg);}
.acc-a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease);}
.acc-a-inner{padding:0 22px 20px;color:var(--muted);font-size:.94rem;}

/* search bar */
.search-bar{max-width:600px;margin:0 auto;position:relative;}
.search-bar>svg{position:absolute;left:20px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--muted);pointer-events:none;z-index:2;}
.search-bar:has(>svg) input{padding-left:52px;}
.search-bar input{width:100%;padding:16px 56px 16px 22px;border-radius:40px;border:none;font-size:1rem;font-family:inherit;
  box-shadow:0 10px 30px rgba(7,24,41,.15);}
.search-bar input:focus{outline:none;box-shadow:0 10px 30px rgba(18,148,255,.3);}
.search-bar button{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;
  background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;}
.search-bar button svg{width:20px;height:20px;}

/* service detail */
.sd-overview{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;}
.check-list li{display:flex;gap:12px;align-items:flex-start;margin-bottom:14px;font-size:.96rem;color:#3a4b5c;}
.check-list li svg{width:22px;height:22px;color:#16a34a;flex-shrink:0;margin-top:1px;}
.pricing-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:26px;text-align:center;
  transition:transform .25s var(--ease),box-shadow .25s,border-color .2s;}
.pricing-card.featured{border-color:var(--blue);box-shadow:var(--glow);position:relative;}
.pricing-card.featured::before{content:"Most Popular";position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--blue);color:#fff;font-size:.72rem;font-weight:700;padding:4px 14px;border-radius:20px;}
.pricing-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);}
.pricing-card h3{font-size:1.05rem;}
.pricing-card .amount{font-size:2.1rem;font-weight:800;color:var(--navy);margin:10px 0;}
.pricing-card .amount small{font-size:.9rem;font-weight:600;color:var(--muted);}
.pricing-card ul{margin:16px 0 22px;text-align:left;}
.pricing-card ul li{font-size:.88rem;color:#3a4b5c;padding:7px 0;border-bottom:1px solid #eef3f8;display:flex;gap:8px;}
.pricing-card ul li::before{content:"✓";color:#16a34a;font-weight:800;}
.pricing-card .price-toggle{display:none;}

/* product detail */
.pd-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;}
.pd-gallery .main-img{background:#f1f5fa;border-radius:var(--radius);overflow:hidden;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;}
.pd-gallery .main-img img{width:100%;height:100%;object-fit:cover;}
.pd-thumbs{display:flex;gap:12px;margin-top:14px;}
.pd-thumbs .thumb{width:74px;height:74px;border-radius:11px;overflow:hidden;border:2px solid var(--border);cursor:pointer;background:#f1f5fa;transition:.2s;}
.pd-thumbs .thumb.active,.pd-thumbs .thumb:hover{border-color:var(--blue);}
.pd-thumbs .thumb img{width:100%;height:100%;object-fit:cover;}
.pd-info h1{font-size:1.9rem;}
.pd-price{font-size:2rem;font-weight:800;color:var(--navy);margin:8px 0;}
.avail{display:inline-flex;align-items:center;gap:7px;color:#16a34a;font-weight:700;font-size:.88rem;}
.avail .dot{width:9px;height:9px;border-radius:50%;background:#16a34a;}
.qty-row{display:flex;align-items:center;gap:14px;margin:20px 0;}
.qty{display:flex;align-items:center;border:1.5px solid var(--border);border-radius:11px;overflow:hidden;}
.qty button{width:40px;height:42px;font-size:1.2rem;color:var(--navy);background:#f5f8fc;transition:.15s;}
.qty button:hover{background:#e7eef6;color:var(--blue);}
.qty input{width:48px;height:42px;text-align:center;border:none;font-family:inherit;font-weight:700;font-size:1rem;}
.spec-table{width:100%;border-collapse:collapse;}
.spec-table td{padding:12px 14px;border-bottom:1px solid var(--border);font-size:.92rem;}
.spec-table td:first-child{font-weight:700;color:var(--navy);width:42%;}
.spec-table tr:nth-child(even){background:#f8fbfe;}
.tabs{display:flex;gap:6px;border-bottom:1px solid var(--border);margin-bottom:24px;flex-wrap:wrap;}
.tab-btn{padding:12px 18px;font-weight:700;color:var(--muted);border-bottom:3px solid transparent;transition:.2s;}
.tab-btn.active{color:var(--blue);border-color:var(--blue);}
.tab-panel{display:none;}
.tab-panel.active{display:block;animation:fadeUp .35s var(--ease);}

/* cart */
.cart-layout{display:grid;grid-template-columns:1.7fr 1fr;gap:30px;align-items:start;}
.cart-item{display:grid;grid-template-columns:88px 1fr auto;gap:18px;align-items:center;padding:18px;
  background:#fff;border:1px solid var(--border);border-radius:14px;margin-bottom:14px;}
.cart-item .ci-img{width:88px;height:88px;border-radius:11px;overflow:hidden;background:#f1f5fa;}
.cart-item .ci-img img{width:100%;height:100%;object-fit:cover;}
.cart-item h3{font-size:1rem;margin-bottom:3px;}
.cart-item .ci-meta{color:var(--muted);font-size:.82rem;margin-bottom:8px;}
.cart-item .ci-bottom{display:flex;align-items:center;gap:16px;}
.ci-remove{color:#e23b3b;font-size:.82rem;font-weight:600;}
.ci-remove:hover{text-decoration:underline;}
.ci-price{font-weight:800;color:var(--navy);text-align:right;font-size:1.05rem;}
.summary{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:26px;position:sticky;top:90px;}
.summary h3{margin-bottom:18px;}
.sum-row{display:flex;justify-content:space-between;padding:9px 0;font-size:.94rem;color:#3a4b5c;}
.sum-row.total{border-top:1px solid var(--border);margin-top:8px;padding-top:16px;font-size:1.2rem;font-weight:800;color:var(--navy);}
.addon{display:flex;gap:12px;align-items:flex-start;background:#f5f8fc;border:1px solid var(--border);border-radius:12px;padding:14px;margin:16px 0;}
.addon input{width:18px;height:18px;margin-top:3px;accent-color:var(--blue);}
.addon label b{color:var(--navy);}
.addon label span{font-size:.84rem;color:var(--muted);display:block;}
.secure-badges{display:flex;gap:14px;align-items:center;justify-content:center;margin-top:16px;color:var(--muted);font-size:.78rem;flex-wrap:wrap;}
.secure-badges .sb{display:flex;align-items:center;gap:6px;}
.secure-badges svg{width:16px;height:16px;color:#16a34a;}
.empty-cart{text-align:center;padding:60px 20px;}
.empty-cart .ec-ic{width:90px;height:90px;border-radius:50%;background:#eaf4ff;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;}
.empty-cart svg{width:46px;height:46px;color:var(--blue);}

/* confirmation */
.confirm-wrap{max-width:760px;margin:0 auto;text-align:center;}
.confirm-check{width:120px;height:120px;margin:0 auto 24px;}
.confirm-check img{width:100%;}
.summary-box{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;text-align:left;margin:30px 0;}
.summary-box .sb-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 30px;}
.sb-item label{font-size:.76rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted-2);font-weight:700;}
.sb-item div{font-weight:600;color:var(--navy);}

/* blog */
.featured-article{display:grid;grid-template-columns:1.2fr 1fr;gap:0;background:#fff;border:1px solid var(--border);
  border-radius:var(--radius-lg);overflow:hidden;}
.featured-article .fa-img{min-height:300px;background:#f1f5fa;overflow:hidden;}
.featured-article .fa-img img{width:100%;height:100%;object-fit:cover;}
.featured-article .fa-body{padding:40px;display:flex;flex-direction:column;justify-content:center;}
.article-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;
  transition:transform .25s var(--ease),box-shadow .25s;}
.article-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);}
.article-card .ac-img{aspect-ratio:16/10;overflow:hidden;background:#f1f5fa;}
.article-card .ac-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease);}
.article-card:hover .ac-img img{transform:scale(1.05);}
.article-card .ac-body{padding:20px;display:flex;flex-direction:column;flex:1;}
.article-card h3{font-size:1.05rem;margin-bottom:8px;}
.article-card p{color:var(--muted);font-size:.88rem;flex:1;}
.article-meta{font-size:.78rem;color:var(--muted-2);margin-top:12px;}

/* about */
.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.stat-band{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center;}
.stat .n{font-size:2.4rem;font-weight:800;color:var(--blue);}
.stat .l{color:var(--muted);font-size:.9rem;}

/* toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(120%);background:var(--navy);color:#fff;
  padding:14px 22px;border-radius:12px;font-weight:600;font-size:.92rem;z-index:200;box-shadow:var(--shadow-lg);
  display:flex;align-items:center;gap:10px;transition:transform .4s var(--ease);}
.toast.show{transform:translateX(-50%) translateY(0);}
.toast svg{width:20px;height:20px;color:var(--cyan);}

/* reveal animation */
.reveal{opacity:1;transform:none;transition:opacity .6s var(--ease),transform .6s var(--ease);}
html.js .reveal{opacity:0;transform:translateY(24px);}
html.js .reveal.in{opacity:1;transform:none;}

/* card hover growth — placed after reveal rules to win the cascade */
html.js .service-card.reveal:hover,.service-card:hover{transform:translateY(-8px) scale(1.035)!important;}
html.js .support-card.reveal:hover,.support-card:hover{transform:translateY(-8px) scale(1.03)!important;}
html.js .product-card.reveal:hover,.product-card:hover{transform:translateY(-8px) scale(1.025)!important;}

@keyframes popIn{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important;}.reveal{opacity:1;transform:none;}}

/* loading spinner (buttons) */
.spin{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.4);
  border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

/* ============================================================
   Page-specific components (products, booking, about, contact,
   faq, blog, checkout, confirmation)
   ============================================================ */

/* generic round icon badge */
.ic-round{width:62px;height:62px;border-radius:16px;background:#eaf4ff;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.ic-round img{width:38px;height:38px;}
.ic-round svg{width:30px;height:30px;color:var(--blue);}
.ic-round.small{width:48px;height:48px;border-radius:12px;}
.ic-round.small img{width:28px;height:28px;}
.ic-round.small svg{width:24px;height:24px;color:var(--blue);}

/* shop category chip row */
.cat-chip-row{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;}
.cat-chip-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:18px 12px;
  display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center;font-weight:700;color:var(--navy);
  transition:transform .2s var(--ease),box-shadow .2s,border-color .2s;font-size:.9rem;}
.cat-chip-card img{width:42px;height:42px;}
.cat-chip-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--blue);color:var(--blue);}

/* product detail extras */
.pd-rating{display:flex;align-items:center;gap:8px;margin:6px 0 4px;}
.pd-rating .stars{color:#f59e0b;letter-spacing:2px;}
.pd-avail{display:inline-flex;align-items:center;gap:7px;color:#16a34a;font-weight:600;font-size:.9rem;margin-bottom:16px;}
.pd-avail svg{width:18px;height:18px;}
.pd-info .badge{position:static;display:inline-block;margin-bottom:12px;}
.pd-highlights{margin:4px 0 22px;}
.qty-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.reviews{display:flex;flex-direction:column;gap:18px;}
.review-item{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px;}
.rev-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.rev-head .stars{color:#f59e0b;letter-spacing:2px;}
.review-item p{color:var(--muted);margin:0;}

/* booking + contact layouts */
.booking-layout{display:grid;grid-template-columns:1.7fr 1fr;gap:34px;align-items:start;}
.contact-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:34px;align-items:start;}
.booking-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow-sm);}
.booking-card h2{font-size:1.3rem;margin-bottom:20px;}
.booking-aside .info-card,.info-card:has(.ic-round){display:flex;gap:14px;align-items:flex-start;}
.info-card:has(.ic-round) h4{margin-bottom:4px;font-size:1rem;}
.contact-mini{display:block !important;}
.contact-mini p{display:flex;align-items:center;gap:9px;margin:8px 0;font-size:.9rem;}
.contact-mini svg{width:17px;height:17px;color:var(--blue);flex-shrink:0;}
.form-foot{margin-top:14px;font-size:.82rem;text-align:center;}
.check-field .checkbox{display:flex;gap:10px;align-items:flex-start;cursor:pointer;font-size:.9rem;color:var(--text);}
.check-field .checkbox input{width:18px;height:18px;margin-top:2px;accent-color:var(--blue);flex-shrink:0;}
.req{color:#e0483d;}

/* contact cards */
.contact-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:26px;text-align:center;
  transition:transform .2s var(--ease),box-shadow .2s;}
.contact-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);}
.contact-card .ic-round{margin:0 auto 14px;}
.contact-card h4{font-size:1rem;margin-bottom:6px;}
.cc-main{font-weight:700;color:var(--navy);margin-bottom:2px;}
.cc-main a{color:var(--blue);}

/* success message */
.success-msg{display:none;align-items:center;gap:10px;background:#eafaf0;border:1px solid #b9e6c9;color:#15803d;
  border-radius:12px;padding:14px 16px;margin-bottom:18px;font-weight:600;font-size:.92rem;}
.success-msg.show{display:flex;}
.success-msg svg{width:20px;height:20px;flex-shrink:0;}

/* about values + who */
.value-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:26px;text-align:center;
  transition:transform .2s var(--ease),box-shadow .2s;}
.value-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);}
.value-card .ic-round{margin:0 auto 14px;}
.value-card h3{font-size:1.05rem;margin-bottom:8px;}
.value-card p{font-size:.9rem;color:var(--muted);}
.stat-band{background:var(--navy);border-radius:var(--radius-lg);padding:40px;}
.stat-band .stat strong{display:block;font-size:2rem;color:#fff;font-weight:800;}
.stat-band .stat span{color:#9fc0dd;font-size:.9rem;}

/* faq + topic cards */
.topic-grid{}
.topic-card{display:flex;align-items:center;gap:16px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:20px 22px;transition:transform .2s var(--ease),box-shadow .2s,border-color .2s;}
.topic-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--blue);}
.topic-card>svg{width:22px;height:22px;color:var(--blue);margin-left:auto;flex-shrink:0;}
.topic-card h4{font-size:1rem;margin-bottom:3px;}
.topic-card p{font-size:.86rem;color:var(--muted);margin:0;}

/* blog */
.ac-tag{display:inline-block;background:#eaf4ff;color:var(--blue);font-size:.72rem;font-weight:700;
  padding:4px 12px;border-radius:30px;margin-bottom:12px;text-transform:uppercase;letter-spacing:.04em;}
.fc-img{aspect-ratio:16/10;overflow:hidden;}
.fc-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease);}
.fix-card:hover .fc-img img{transform:scale(1.05);}
.fc-body{padding:22px;}
.fc-body h3{font-size:1.1rem;margin-bottom:8px;}
.fc-body p{color:var(--muted);font-size:.92rem;}
.newsletter-band{background:var(--navy);border-radius:var(--radius-lg);padding:40px 44px;display:flex;align-items:center;
  justify-content:space-between;gap:24px;flex-wrap:wrap;}
.newsletter-band h2{color:#fff;margin-bottom:4px;}
.newsletter-band .muted{color:#9fc0dd;}
.newsletter-band .newsletter-form{margin:0;min-width:300px;}

/* checkout mini items + confirmation */
.checkout-items{margin-bottom:8px;border-bottom:1px solid var(--border);padding-bottom:8px;}
.checkout-items .co-line{display:flex;justify-content:space-between;gap:10px;font-size:.9rem;padding:6px 0;color:var(--text);}
.checkout-items .co-line span:first-child{color:var(--muted);}
.confirm-next{max-width:520px;margin:0 auto;text-align:left;}
.confirm-next h3{text-align:center;margin-bottom:18px;}
.next-steps{list-style:none;display:flex;flex-direction:column;gap:14px;}
.next-steps li{display:flex;align-items:center;gap:14px;color:var(--text);font-weight:500;}
.next-steps li span{width:32px;height:32px;border-radius:50%;background:var(--blue);color:#fff;font-weight:800;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.page-hero.short{padding:50px 0 40px;}
.page-hero.short p{max-width:600px;}

/* compact cart items inside checkout summary */
.checkout-items .cart-item{grid-template-columns:54px 1fr auto;gap:12px;padding:12px 0;margin:0;border:none;border-bottom:1px solid var(--border);border-radius:0;}
.checkout-items .cart-item:last-child{border-bottom:none;}
.checkout-items .cart-item .ci-img{width:54px;height:54px;}
.checkout-items .cart-item h3{font-size:.9rem;}
.checkout-items .cart-item .ci-bottom .qty{transform:scale(.85);transform-origin:left;}
.checkout-items .cart-item .ci-price{font-size:.95rem;}

/* ============================================================
   CUSTOM CURSOR EFFECT  (YourTechBuddy)  — added feature
   Small electric-blue dot + soft cyan/blue glow follower that
   eases behind the pointer, with a subtle fading trail.
   Enabled by JS (adds `.ytb-cursor-on` to <html>) ONLY on
   desktop/laptop with a fine pointer + hover, and never when
   prefers-reduced-motion is set (see main.js).
   All layers use pointer-events:none so they never block
   clicks, links, or the site's existing hover effects.
   The default system cursor is intentionally kept visible
   for usability (especially over text and form fields).
   ============================================================ */
.ytb-cursor-dot,
.ytb-cursor-glow,
.ytb-cursor-trail{
  position:fixed;
  top:0; left:0;
  pointer-events:none;          /* never intercept clicks/hover */
  border-radius:50%;
  opacity:0;                    /* revealed on first mouse move */
  will-change:transform,opacity;
}
.ytb-cursor-dot{  z-index:99999; }
.ytb-cursor-glow{ z-index:99998; }
.ytb-cursor-trail{ z-index:99997; }

/* bright electric-blue dot — tracks the real pointer exactly */
.ytb-cursor-dot{
  width:8px; height:8px;
  background:var(--blue);
  box-shadow:0 0 8px 1px rgba(18,148,255,.95);
  transition:opacity .25s ease;
}

/* soft cyan/blue glow — eased & slightly delayed behind the dot */
.ytb-cursor-glow{
  width:22px; height:22px;
  background:radial-gradient(circle,
              rgba(58,214,255,.28) 0%,
              rgba(18,148,255,.14) 45%,
              rgba(18,148,255,0)   72%);
  transition:width .28s var(--ease), height .28s var(--ease),
             opacity .28s ease, background .28s ease;
}

/* hover state over clickable elements — ring grows + brightens (gently) */
.ytb-cursor-glow.ytb-hover{
  width:30px; height:30px;
  background:radial-gradient(circle,
              rgba(58,214,255,.4) 0%,
              rgba(18,148,255,.2) 45%,
              rgba(18,148,255,0)  72%);
}

/* subtle fading trail particles (created/removed in JS) */
.ytb-cursor-trail{
  width:7px; height:7px;
  background:radial-gradient(circle, rgba(58,214,255,.6) 0%, rgba(18,148,255,0) 70%);
  opacity:.6;
  transition:opacity .5s ease, transform .5s ease;
}

/* hide all cursor layers unless JS has enabled the effect */
html:not(.ytb-cursor-on) .ytb-cursor-dot,
html:not(.ytb-cursor-on) .ytb-cursor-glow,
html:not(.ytb-cursor-on) .ytb-cursor-trail{ display:none; }
/* ==================== end custom cursor ===================== */

/* ============================================================
   Legal pages (Privacy Policy / Terms of Service) — added
   Scoped layout: sticky table of contents + clean prose.
   ============================================================ */
.legal-section{padding:56px 0 76px;}
.legal-layout{display:grid;grid-template-columns:268px 1fr;gap:48px;align-items:start;}
.legal-toc{position:sticky;top:calc(var(--header-h) + 20px);background:#fff;border:1px solid var(--border);
  border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm);}
.legal-toc h2{font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:12px;}
.legal-toc ol{list-style:none;counter-reset:toc;display:flex;flex-direction:column;gap:1px;}
.legal-toc li{counter-increment:toc;}
.legal-toc a{display:flex;gap:9px;padding:7px 9px;border-radius:8px;font-size:.88rem;color:var(--text);
  line-height:1.35;transition:background .18s,color .18s;}
.legal-toc a::before{content:counter(toc);color:var(--blue);font-weight:700;font-size:.78rem;min-width:16px;}
.legal-toc a:hover{background:#eaf4ff;color:var(--blue);}
.legal-content{max-width:780px;min-width:0;}
.legal-content .legal-meta{color:var(--muted);font-size:.9rem;margin-bottom:18px;}
.legal-intro{font-size:1.04rem;color:#33485c;background:#f5f8fc;border:1px solid var(--border);
  border-left:3px solid var(--blue);border-radius:12px;padding:18px 20px;margin-bottom:30px;line-height:1.65;}
.legal-content h2{font-size:1.32rem;margin:40px 0 12px;color:var(--navy);
  scroll-margin-top:calc(var(--header-h) + 16px);}
.legal-content h2:first-of-type{margin-top:6px;}
.legal-content h2 .num{color:var(--blue);margin-right:10px;}
.legal-content h3{font-size:1.02rem;margin:22px 0 8px;color:var(--navy);}
.legal-content p{color:#3a4b5c;line-height:1.72;margin-bottom:14px;}
.legal-content ul{margin:0 0 16px;padding:0;list-style:none;display:flex;flex-direction:column;gap:9px;}
.legal-content ul li{position:relative;padding-left:24px;color:#3a4b5c;line-height:1.6;}
.legal-content ul li::before{content:"";position:absolute;left:5px;top:9px;width:7px;height:7px;
  border-radius:50%;background:var(--blue);}
.legal-content a{color:var(--blue-dark);text-decoration:underline;text-underline-offset:2px;}
.legal-callout{background:#fff;border:1px solid var(--border);border-left:3px solid var(--cyan);
  border-radius:12px;padding:16px 20px;margin:22px 0;box-shadow:var(--shadow-sm);}
.legal-callout p{margin-bottom:0;}
.legal-callout strong{color:var(--navy);}
.legal-contact-card{background:var(--navy);color:#e6eef6;border-radius:var(--radius);padding:24px 26px;margin-top:14px;}
.legal-contact-card h3{color:#fff;margin:0 0 10px;}
.legal-contact-card p{color:#bcd0e4;margin-bottom:6px;}
.legal-contact-card a{color:#fff;}
.legal-updated{margin-top:42px;padding-top:18px;border-top:1px solid var(--border);color:var(--muted);font-size:.88rem;}
@media (max-width:992px){
  .legal-layout{grid-template-columns:1fr;gap:22px;}
  .legal-toc{position:static;}
}
/* ==================== end legal pages ====================== */
