/* ═══════════════════════════════════════════════════════
   HOME SERVICE — Public Stylesheet
   Dark Navy · Neon Blue · Glassmorphism · Futuristic
═══════════════════════════════════════════════════════ */

/* ── FONTS ─── */
/* Exo 2 for headings (futuristic, Cyrillic support)
   Inter for body text                                  */

/* ── CUSTOM PROPERTIES ─── */
:root {
  /* Palette */
  --bg-deep:   #060d1a;
  --bg-base:   #080f1e;
  --bg-card:   #0d1830;
  --accent:    #19b6ff;
  --accent2:   #3fe0ff;
  --accent-dim: rgba(25, 182, 255, .55);
  --accent-bg:  rgba(25, 182, 255, .08);
  --text:      #eaf2ff;
  --text-muted: rgba(200, 220, 255, .65);
  --line:      rgba(255, 255, 255, .08);
  --line2:     rgba(25, 182, 255, .20);
  --glass-bg:  rgba(255, 255, 255, .05);
  --glass-border: rgba(255, 255, 255, .10);
  --glow:      0 0 30px rgba(25, 182, 255, .30);
  --glow-sm:   0 0 16px rgba(25, 182, 255, .22);
  --shadow:    0 10px 40px rgba(0, 0, 0, .55);
  --shadow-sm: 0 4px 20px rgba(0, 0, 0, .45);

  /* Layout */
  --container: 1180px;
  --radius:    18px;
  --radius-xl: 22px;
  --radius-sm: 14px;

  /* Typography */
  --font-head: 'Exo 2', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --font-body: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

  /* Transitions */
  --t: 220ms cubic-bezier(.2,.8,.2,1);
}

/* ── RESET / BASE ─── */
* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  color: var(--text);
  font-family: var(--font-body);
  background: radial-gradient(1200px 700px at 20% 10%, rgba(25,182,255,.12), transparent 60%),
  radial-gradient(900px 550px at 85% 15%, rgba(63,224,255,.10), transparent 55%),
  radial-gradient(900px 700px at 55% 85%, rgba(25,182,255,.08), transparent 60%),
  linear-gradient(180deg, var(--bg-deep), var(--bg-base) 40%, #070c16);
  overflow-x: hidden;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; }
input, textarea, select { font: inherit; color: inherit; }
::selection { background: rgba(25,182,255,.25); }

.container {
  width: min(var(--container), calc(100% - 40px));
  margin: 0 auto;
}

/* ── UTIL ─── */
.muted { color: var(--text-muted); }
.small { font-size: 13px; }
.row { display:flex; justify-content:space-between; gap:14px; align-items:flex-end; flex-wrap:wrap; }
.t-right { text-align:right; }
.t-center { text-align:center; }
.mt { margin-top: 10px; }
.pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 12px;
  border-radius: 999px;
  border: 1px solid var(--line2);
  background: rgba(25,182,255,.08);
  color: rgba(234,242,255,.9);
  box-shadow: var(--glow-sm);
}
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border:0;
}

.glass {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  box-shadow: var(--shadow-sm);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.card {
  border-radius: var(--radius);
  padding: 18px;
}

.section {
  padding: 46px 0;
}
.section.tight { padding: 28px 0; }

.link{
  background:transparent;
  border:0;
  padding:0;
  color: rgba(234,242,255,.85);
  cursor:pointer;
  text-decoration: underline;
}
.link.danger{ color: rgba(255,120,120,.92); }

.badge{
  display:inline-flex;
  align-items:center;
  padding: 4px 10px;
  border-radius:999px;
  font-size:12px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
}
.badge-ok{ background: rgba(55,255,165,.10); border-color: rgba(55,255,165,.18); }
.badge-warn{ background: rgba(255,200,70,.10); border-color: rgba(255,200,70,.18); }
.badge-bad{ background: rgba(255,90,120,.10); border-color: rgba(255,90,120,.18); }
.badge-muted{ opacity:.8; }

/* ── AMBIENT BACKGROUND (orbs/particles) ─── */
.bg-ambient{
  position: fixed;
  inset: 0;
  width: 100vw;
  height: 100vh;
  pointer-events: none;
  z-index: -1;
  overflow: hidden;
  clip-path: inset(0);
}
.bg-orb {
  position: absolute;
  width: 420px; height: 420px;
  border-radius: 50%;
  filter: blur(60px);
  opacity: .35;
  mix-blend-mode: screen;
}
.bg-orb--1 { left: -120px; top: -120px; background: rgba(25,182,255,.55); }
.bg-orb--2 { right: -160px; top: 40px; background: rgba(63,224,255,.45); }
.bg-orb--3 { left: 40%; bottom: -200px; background: rgba(25,182,255,.35); }

/* Subtle "star" particles */
.bg-ambient::after{
  content:"";
  position:absolute; inset:0;
  background-image:
          radial-gradient(circle at 20% 30%, rgba(255,255,255,.10) 0 1px, transparent 2px),
          radial-gradient(circle at 80% 20%, rgba(255,255,255,.08) 0 1px, transparent 2px),
          radial-gradient(circle at 60% 65%, rgba(255,255,255,.06) 0 1px, transparent 2px),
          radial-gradient(circle at 35% 75%, rgba(255,255,255,.05) 0 1px, transparent 2px);
  background-size: 900px 900px;
  opacity: .55;
}

/* ── HEADER ─── */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  padding: 10px 0;
  background: linear-gradient(135deg, rgba(6,12,22,.96), rgba(7,14,26,.90));
  border-bottom: 1px solid rgba(255,255,255,.05);
  box-shadow: 0 8px 18px rgba(0,0,0,.35);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.header-inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 18px;
  min-width: 0;
}
.header-inner > *{ min-width: 0; }

.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  white-space: nowrap;
  min-width: 0;
}
.brand-logo {
  height: 46px;
  width: auto;
  filter: drop-shadow(0 0 12px rgba(25,182,255,.25));
}
.brand-name{
  font-family: var(--font-head);
  font-weight: 900;
  letter-spacing: .6px;
  line-height: 1.05;
  font-size: 17px;
}
.brand-accent{ color: var(--accent); text-shadow: 0 0 16px rgba(25,182,255,.30); }

.site-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  padding: 0;
  border-radius: 0;
  border: 0;
  background: none;
  box-shadow: none;
}
.nav-link{
  position: relative;
  font-family: var(--font-head);
  font-weight: 700;
  font-size: 15px;
  color: rgba(234,242,255,.85);
  padding: 6px 0;
  transition: color var(--t);
}
.nav-link:hover { color: var(--text); }
.nav-link.is-active{
  color: var(--text);
  text-shadow: 0 0 14px rgba(25,182,255,.25);
}
.nav-link.is-active::after{
  content:"";
  position:absolute;
  left: 8px; right: 8px; bottom: -8px;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(25,182,255,.9), transparent);
  filter: blur(.2px);
}

.header-right{
  display:flex;
  align-items:center;
  justify-content: flex-end;
  gap: 10px;
  flex-shrink: 0;
}

/* Quick contact pill */
.quick-contact{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width: 44px;
  height: 44px;
  flex-shrink: 0;
  min-width: 44px;
  padding: 0;
  border-radius: 14px;
  border: 1px solid rgba(63,224,255,.55);
  background: linear-gradient(135deg, #3fd4ff, #1aa0ff);
  color: #012038;
  box-shadow: 0 10px 22px rgba(26,160,255,.25);
  text-decoration: none;
  transition: transform var(--t), box-shadow var(--t), border-color var(--t);
}
.quick-contact .qc-icon{
  opacity:.98;
  width: 20px;
  height: 20px;
}
.quick-contact:hover{
  transform: translateY(-1px);
  border-color: rgba(25,182,255,.65);
  box-shadow: 0 10px 26px rgba(26,160,255,.32);
}

/* Cart button */
.cart-btn{
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px; height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  box-shadow: var(--shadow-sm);
  transition: transform var(--t), border-color var(--t), background var(--t);
}
.cart-btn:hover{
  transform: translateY(-1px);
  border-color: rgba(25,182,255,.35);
  background: rgba(25,182,255,.08);
}
.cart-badge{
  position:absolute;
  top: -6px; right: -6px;
  min-width: 18px;
  height: 18px;
  padding: 0 6px;
  border-radius: 999px;
  background: rgba(25,182,255,.95);
  color: #001122;
  font-size: 11px;
  font-weight: 900;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow: 0 0 18px rgba(25,182,255,.35);
}

/* Burger */
.nav-burger{
  display:none;
  width: 44px; height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  box-shadow: var(--shadow-sm);
  cursor:pointer;
  transition: transform var(--t), border-color var(--t), background var(--t);
}
.nav-burger:hover{
  transform: translateY(-1px);
  border-color: rgba(25,182,255,.35);
  background: rgba(25,182,255,.08);
}
.nav-burger span{
  display:block;
  width: 18px;
  height: 2px;
  background: rgba(234,242,255,.88);
  margin: 4px auto;
  border-radius: 2px;
  transition: transform var(--t), opacity var(--t);
}

/* Mobile nav open state controlled by JS (body.nav-open) */
body.nav-open .nav-burger span:nth-child(1){ transform: translateY(6px) rotate(45deg); }
body.nav-open .nav-burger span:nth-child(2){ opacity: 0; }
body.nav-open .nav-burger span:nth-child(3){ transform: translateY(-6px) rotate(-45deg); }

/* Mobile nav panel */
@media (max-width: 980px){
  .header-inner{
    grid-template-columns: 1fr auto auto;
    gap: 12px;
  }
  .site-header{
    background: linear-gradient(135deg, #0a1324, #0c182d);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }
  .brand-logo{ height: 40px; }
  .brand-name{ font-size: 15px; }
  .site-nav{
    position: fixed;
    right: 12px;
    left: auto;
    transform: translateY(-8px);
    top: 64px;
    width: fit-content;
    min-width: 0;
    height: 0;
    padding: 0;
    margin: 0;
    max-width: calc(100vw - 32px);
    max-height: calc(100vh - 96px);
    overflow-y: auto;
    flex-direction: column;
    gap: 8px;
    border-radius: 18px;
    background: rgba(6,13,26,.92);
    border: 1px solid rgba(255,255,255,.10);
    box-shadow: 0 18px 36px rgba(0,0,0,.55);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--t), transform var(--t);
  }
  body.nav-open .site-nav{
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
    width: fit-content;
    min-width: 0;
    max-width: calc(100vw - 32px);
    height: auto;
    padding: 10px 12px;
    overflow: visible;
  }
  .nav-link{ width: 100%; text-align:center; padding: 10px; border-radius: 14px; }
  .nav-link:hover{ background: rgba(255,255,255,.04); }
  .nav-link.is-active::after{ display:none; }
  .nav-burger{ display:inline-flex; flex-direction: column; justify-content: center; }
  .header-right{ gap: 8px; }
  .quick-contact{
    display:inline-flex;
    width: 42px;
    height: 42px;
    border-radius: 13px;
    min-width: 42px;
  }
}

/* Mobile banner strip (offers) */
.mobile-banner-strip{
  display: none;
}
.mb-slide{
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
  flex: 0 0 auto;
  min-width: 170px;
  color: rgba(234,242,255,.9);
}
.mb-slide img{
  width: 64px;
  height: 44px;
  object-fit: cover;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.08);
  flex-shrink: 0;
}
.mb-label{
  font-family: var(--font-head);
  font-weight: 800;
  font-size: 13px;
  line-height: 1.2;
}
@media (max-width: 980px){
  .mobile-banner-strip{
    display: flex;
    gap: 10px;
    overflow-x: auto;
    padding: 10px 14px 12px;
    width: 100%;
    -webkit-overflow-scrolling: touch;
    mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
    -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
  }
  .mobile-banner-strip::-webkit-scrollbar{ display: none; }
  .mobile-banner-strip{ scrollbar-width: none; }
}

/* ── FLASH MESSAGES ─── */
.flash-wrap{ margin-top: 14px; }
.flash{
  border-radius: 16px;
  padding: 12px 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  box-shadow: var(--shadow-sm);
}
.flash-success{ border-color: rgba(25,182,255,.35); background: rgba(25,182,255,.10); }
.flash-error{ border-color: rgba(255,90,90,.35); background: rgba(255,90,90,.10); }
.flash-info{ border-color: rgba(255,255,255,.12); }

/* ── BUTTONS ─── */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  padding: 10px 16px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: var(--text);
  font-family: var(--font-head);
  font-weight: 800;
  letter-spacing: .2px;
  cursor:pointer;
  transition: transform var(--t), border-color var(--t), background var(--t), box-shadow var(--t);
  user-select:none;
}
.btn:hover{
  transform: translateY(-1px);
  border-color: rgba(25,182,255,.30);
  background: rgba(25,182,255,.08);
  box-shadow: var(--glow-sm);
}
.btn:active{ transform: translateY(0); }

.btn-primary{
  border-color: rgba(25,182,255,.45);
  background: linear-gradient(180deg, rgba(25,182,255,.95), rgba(25,182,255,.70));
  color: #00101f;
  box-shadow: 0 10px 30px rgba(25,182,255,.18), 0 0 22px rgba(25,182,255,.20);
}
.btn-primary:hover{
  background: linear-gradient(180deg, rgba(63,224,255,.95), rgba(25,182,255,.72));
  border-color: rgba(63,224,255,.55);
  box-shadow: 0 12px 34px rgba(25,182,255,.22), 0 0 30px rgba(63,224,255,.18);
}

.btn-outline{
  border-color: rgba(255,255,255,.16);
  background: rgba(255,255,255,.03);
  color: rgba(234,242,255,.92);
}
.btn-outline:hover{
  border-color: rgba(25,182,255,.40);
  background: rgba(25,182,255,.06);
}

.btn-lg{ padding: 12px 18px; border-radius: 16px; }

/* ── HERO ─── */
.hero-section{
  position: relative;
  padding: 60px 0 42px;
}
.hero.hero-bg{
  position: relative;
  min-height: 520px;
  padding-top: 54px;
  padding-bottom: 70px;
}
.hero.hero-bg::before{
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(5,10,20,0.78) 0%, rgba(5,10,20,0.55) 45%, rgba(5,10,20,0.25) 100%),
    radial-gradient(700px 380px at 25% 20%, rgba(25,182,255,0.16), transparent 60%);
  background-repeat: no-repeat, no-repeat;
  background-size: cover, cover;
  background-position: 0 0, 0 0;
  z-index: 0;
}
.hero.hero-bg .container{
  position: relative;
  z-index: 1;
}
.hero.hero-bg .hero-line{
  z-index: 1;
}
.hero-inner{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 36px;
  align-items: center;
}
.hero.hero-bg .hero-inner{
  grid-template-columns: 1fr;
}

.home-flow-bg{
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(5,10,20,0.78) 0%, rgba(5,10,20,0.55) 45%, rgba(5,10,20,0.25) 100%),
    radial-gradient(900px 520px at 25% 12%, rgba(25,182,255,0.16), transparent 60%),
    url('../img/hero-img.png');
  background-repeat: no-repeat, no-repeat, no-repeat;
  background-size: cover, cover, 110% auto;
  background-position: center top;
  z-index: 0;
}
.home-flow-bg::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background: radial-gradient(900px 520px at 70% 35%, rgba(63,224,255,.14), transparent 60%);
  mix-blend-mode: screen;
  opacity:.9;
  z-index:0;
}
.home-flow-bg > *{
  position: relative;
  z-index: 1;
}

.hero-copy{
  max-width: 640px;
}
.hero-kicker{
  display:inline-block;
  font-size: 14px;
  color: rgba(200,220,255,.75);
  letter-spacing: .3px;
  margin-bottom: 12px;
}
.hero-h1{
  font-family: var(--font-head);
  font-weight: 900;
  line-height: 1.08;
  margin: 0 0 18px;
  font-size: clamp(34px, 3.4vw, 54px);
  text-shadow: 0 0 30px rgba(25,182,255,.12);
}
.hero-actions{
  display:flex;
  gap: 14px;
  flex-wrap: wrap;
}

.hero-visual-wrap{ display:flex; justify-content: flex-end; }
.hero-img-frame{
  position: relative;
  width: min(520px, 100%);
  min-height: 320px;
  aspect-ratio: 16 / 10;
  border-radius: var(--radius-xl);
  border: 1px solid rgba(255,255,255,.10);
  background: radial-gradient(500px 240px at 70% 20%, rgba(25,182,255,.14), transparent 60%),
  rgba(255,255,255,.04);
  box-shadow: var(--shadow);
  overflow: hidden;
  padding: 0;
}
.hero-img-frame::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  background:
    radial-gradient(520px 260px at 75% 18%, rgba(25,182,255,.18), transparent 62%),
    linear-gradient(180deg, rgba(5,10,20,0.20), rgba(5,10,20,0.65));
}
.hero-img{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  border-radius: inherit;
  opacity: 1;
  filter: none;
}

.hfg-item{
  border-radius: 18px;
  padding: 14px 12px;
  text-align:center;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(10,18,32,0.40);
}
.hfg-icon{
  width: 44px; height: 44px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin: 0 auto 10px;
  color: rgba(25,182,255,.9);
  filter: drop-shadow(0 0 12px rgba(25,182,255,.2));
}
.hfg-icon svg{ width: 40px; height: 40px; }
.hfg-label{
  font-family: var(--font-head);
  font-weight: 800;
  color: rgba(234,242,255,.9);
  font-size: 13px;
}

/* Decorative glow lines like screenshot */
.hero-line{
  position:absolute;
  left: 0; right: 0;
  height: 2px;
  opacity: .55;
  background: linear-gradient(90deg, transparent, rgba(25,182,255,.55), transparent);
  filter: blur(.2px);
}
.hero-line--1{ bottom: 14px; }
.hero-line--2{ bottom: 0; opacity: .35; }

@media (max-width: 980px){
  .hero-inner{
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .hero-visual-wrap{ justify-content: flex-start; }
  .hero-section{ padding: 0 0 26px; }
}
@media (max-width: 900px){
  .hero.hero-bg{
    min-height: 440px;
  }
  .hero.hero-bg::before{
    background-position: 0 0, 0 0, center top;
  }
}
@media (max-width: 720px){
  .hero-section{ padding: 0 0 20px; }
  .hero.hero-bg{
    min-height: 410px;
    padding-top: 30px;
    padding-bottom: 44px;
  }
  .hero.hero-bg::before{
    inset: 0;
    background-size: cover, cover, 118% auto;
    background-position: 0 0, 0 0, center top;
  }
  .hero-inner{ gap: 14px; }
  .hero-kicker{
    font-size: 12px;
    margin-bottom: 8px;
    letter-spacing: .4px;
  }
  .hero-h1{
    font-size: clamp(26px, 7vw, 34px);
    line-height: 1.18;
    margin: 0 0 14px;
  }
  .hero-actions{
    gap: 10px;
  }
  .hero-actions .btn{
    padding: 11px 14px;
    border-radius: 14px;
  }
}
@media (max-width: 520px){
  .hero.hero-bg{
    min-height: 360px;
    padding-top: 26px;
    padding-bottom: 38px;
  }
  .hero.hero-bg::before{
    inset: 0;
    background-size: cover, cover, 112% auto;
    background-position: 0 0, 0 0, center top;
  }
  .hero-actions{
    flex-direction: column;
    align-items: flex-start;
    width: 100%;
  }
  .hero-actions .btn{
    width: 100%;
    justify-content: center;
  }
}
@media (min-width: 981px){
  .hero.hero-bg::before{
    bottom: 0;
  }
  .packages-section{
    position: relative;
    z-index: 1;
  }
}
.packages-section,
.tiles-section,
.cta-section,
.tiles-section .tiles-heading,
.site-footer{
  position: relative;
  z-index: 1;
}

/* ── TILES (Products categories) ─── */
.tiles-section{ padding-top: 26px; }
.tiles-header{ margin-bottom: 14px; }
.tiles-heading{
  font-family: var(--font-head);
  font-weight: 900;
  margin: 0;
  font-size: 20px;
  letter-spacing: .2px;
}

.tiles-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.tile-card{
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  box-shadow: var(--shadow-sm);
  transition: transform var(--t), border-color var(--t), box-shadow var(--t), background var(--t);
  cursor: pointer;
}
.tile-card:hover{
  transform: translateY(-3px);
  border-color: rgba(25,182,255,.30);
  box-shadow: 0 16px 40px rgba(0,0,0,.55), 0 0 30px rgba(25,182,255,.12);
  background: rgba(25,182,255,.05);
}
.tile-card.is-expanded{
  grid-column: 1 / -1;
  box-shadow: 0 16px 46px rgba(0,0,0,.55), 0 0 32px rgba(25,182,255,.16);
  border-color: rgba(25,182,255,.35);
}
.tile-img-area{
  height: 110px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: radial-gradient(220px 120px at 50% 35%, rgba(25,182,255,.18), transparent 60%);
}
.tile-icon{
  width: 66px; height: 66px;
  border-radius: 18px;
  display:flex;
  align-items:center;
  justify-content:center;
  color: rgba(25,182,255,.95);
  filter: drop-shadow(0 0 18px rgba(25,182,255,.18));
}
.tile-icon svg{ width: 56px; height: 56px; }
.tile-photo{
  width: 86px;
  height: 86px;
  object-fit: cover;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 12px 26px rgba(0,0,0,0.35), 0 0 18px rgba(25,182,255,0.12);
}

.tile-footer{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  padding: 14px 14px 16px;
  border-top: 1px solid rgba(255,255,255,.06);
}
.tile-name{
  font-family: var(--font-head);
  font-weight: 900;
  font-size: 14px;
  color: rgba(234,242,255,.92);
}
.tile-arrow{
  font-size: 22px;
  line-height: 1;
  color: rgba(200,220,255,.75);
  transform: translateY(-1px);
}

/* Slight different tint for special tiles */
.tile-card--special .tile-icon{ color: rgba(63,224,255,.95); }
.tile-card--offers .tile-icon{ color: rgba(25,182,255,.95); }

.tile-close{
  position: absolute;
  top: 10px; right: 10px;
  width: 34px; height: 34px;
  display:none;
  align-items:center;
  justify-content:center;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(6,13,26,.65);
  color: rgba(234,242,255,.86);
  cursor: pointer;
  transition: background var(--t), border-color var(--t), transform var(--t);
  z-index: 2;
}
.tile-card.is-expanded .tile-close{ display:flex; }
.tile-close:hover{
  background: rgba(25,182,255,.14);
  border-color: rgba(25,182,255,.38);
  transform: translateY(-1px);
}

.tile-expanded{
  display:none;
  padding: 0 14px 14px;
}
.tile-card.is-expanded .tile-expanded{
  display:block;
}
.tile-expanded__inner{
  margin-top: 8px;
  border-radius: var(--radius);
  border: 1px dashed rgba(25,182,255,.35);
  padding: 14px;
  background: rgba(255,255,255,.03);
}
.tile-expanded__top{
  display:flex;
  align-items:center;
  justify-content: flex-end;
  gap: 10px;
  margin-bottom: 8px;
}
.tile-expanded__viewall{
  display:inline-flex;
  align-items:center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 10px;
  border: 1px solid rgba(25,182,255,.25);
  color: rgba(234,242,255,.88);
  background: rgba(25,182,255,.08);
  font-family: var(--font-head);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: .2px;
  transition: border-color var(--t), background var(--t), transform var(--t);
}
.tile-expanded__viewall:hover{
  border-color: rgba(25,182,255,.45);
  background: rgba(25,182,255,.12);
  transform: translateY(-1px);
}
.tile-expanded__content{
  position: relative;
}
.tile-expanded__loading{
  font-family: var(--font-head);
  font-weight: 700;
  color: rgba(234,242,255,.82);
  letter-spacing: .1px;
}
.tile-expanded__error{
  padding: 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,90,90,.35);
  background: rgba(255,90,90,.06);
  color: rgba(255,210,210,.9);
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
}
.tile-expanded__error button{
  padding: 6px 10px;
  border-radius: 10px;
  border: 1px solid rgba(255,210,210,.5);
  background: rgba(255,255,255,.08);
  color: rgba(255,210,210,.95);
  cursor:pointer;
}

@media (max-width: 980px){
  .tiles-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .tile-card.is-expanded{ grid-column: 1 / -1; }
}
@media (max-width: 560px){
  .tiles-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .tile-img-area{ height: 90px; }
}
@media (max-width: 340px){
  .tiles-grid{ grid-template-columns: 1fr; }
}
@media (max-width: 900px){
  .tiles-grid{ gap: 12px; }
  .tile-card{ border-radius: 16px; }
  .tile-img-area{ height: 92px; }
  .tile-photo{ width: 68px; height: 68px; border-radius: 14px; }
  .tile-icon{ width: 54px; height: 54px; }
  .tile-icon svg{ width: 40px; height: 40px; }
  .tile-footer{ padding: 9px 10px; }
  .tile-name{ font-size: 13px; }
  .tile-arrow{ font-size: 18px; }
  .tile-expanded__inner{ padding: 12px; }
  .tile-expanded__content{ max-height: 320px; }
}
@media (max-width: 640px){
  .tile-expanded__content{ max-height: 300px; }
  .tile-card.is-expanded .tile-close{
    display:flex;
    width: 32px; height: 32px;
    top: 8px; right: 8px;
  }
}
@media (max-width: 520px){
  .tile-img-area{ height: 82px; }
  .tile-footer{ padding: 9px 10px; }
  .tile-name{ font-size: 12.5px; }
}

.embedded-grid{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 10px;
}
.embedded-card{
  display:flex;
  flex-direction: column;
  gap: 10px;
  padding: 10px 10px;
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.02);
  transition: transform var(--t), border-color var(--t), background var(--t), box-shadow var(--t);
  transform: translateY(0) scale(1);
  cursor: pointer;
}
.embedded-card:hover{
  transform: none;
  border-color: rgba(25,182,255,.30);
  background: rgba(25,182,255,.06);
  box-shadow: 0 12px 24px rgba(0,0,0,.35);
}
.embedded-thumb{
  width: 70px; height: 70px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.embedded-thumb img{ width: 100%; height: 100%; object-fit: cover; }
.embedded-body{ flex:1; min-width: 0; }
.embedded-name{
  font-family: var(--font-head);
  font-weight: 800;
  font-size: 13px;
  color: rgba(234,242,255,.9);
  margin-bottom: 6px;
}
.embedded-meta{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  font-size: 12px;
}
.embedded-meta{
  flex-wrap: wrap;
  row-gap: 6px;
}
.embedded-meta .price{
  flex: 1 1 auto;
  min-width: 0;
}
.embedded-meta .badge{
  flex: 0 0 auto;
  margin-left: auto;
  white-space: nowrap;
  width: auto;
  height: auto;
  min-width: 0;
  padding: 4px 10px;
  border-radius: 999px;
  line-height: 1.2;
}
.embedded-main{
  display:flex;
  align-items:flex-start;
  gap: 10px;
}
.embedded-cart{
  display:flex;
  justify-content: flex-end;
}
.embedded-cart .btn{
  padding: 8px 12px;
  border-radius: 12px;
  font-size: 12px;
}
.embedded-cart .btn-disabled{
  opacity: .6;
  cursor: not-allowed;
}
.embedded-empty{
  padding: 12px;
  border-radius: 12px;
  border: 1px dashed rgba(255,255,255,.16);
  color: rgba(234,242,255,.72);
}

.tile-expanded__content{
  position: relative;
  max-height: 460px;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  padding-right: 6px;
}
@media (max-width: 640px){
  .tile-expanded__content{ max-height: 300px; }
  .tile-close{
    width: 32px; height: 32px;
    top: 8px; right: 8px;
  }
  .embedded-cart .btn{ width: 100%; justify-content: center; }
}

@media (hover: none){
  .embedded-card:hover{
    transform: none;
    box-shadow: 0 12px 24px rgba(0,0,0,.25);
  }
}

/* ── Modal ─────────────────────────────────────────── */
body.modal-open{ overflow: hidden; }
.modal{
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 160;
}
.modal.is-open{ display:flex; }
.modal__backdrop{
  position: absolute;
  inset: 0;
  background: rgba(6,13,26,.78);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  opacity: 0;
  transition: opacity var(--t);
}
.modal.is-open .modal__backdrop{ opacity: 1; }
.modal__dialog{
  position: relative;
  z-index: 1;
  width: min(640px, calc(100% - 32px));
  padding: 18px;
  border-radius: var(--radius-xl);
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(12,18,32,.92);
  box-shadow: 0 20px 60px rgba(0,0,0,.65), 0 0 30px rgba(25,182,255,.16);
  transform: translateY(10px) scale(.98);
  opacity: 0;
  transition: transform var(--t), opacity var(--t);
}
.modal.is-open .modal__dialog{
  transform: translateY(0) scale(1);
  opacity: 1;
}
.modal__close{
  position: absolute;
  top: 12px; right: 12px;
  width: 36px; height: 36px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
  color: rgba(234,242,255,.92);
  cursor: pointer;
  transition: background var(--t), border-color var(--t), transform var(--t);
}
.modal__close::before{
  content: "\00D7";
  font-weight: 800;
  font-size: 20px;
  line-height: 1;
}
.modal__close:hover{
  background: rgba(25,182,255,.12);
  border-color: rgba(25,182,255,.45);
  transform: translateY(-1px);
}
.modal__body{ margin-top: 10px; }
.modal__loading,
.modal__error{
  padding: 12px;
  border-radius: 12px;
  border: 1px dashed rgba(255,255,255,.16);
  color: rgba(234,242,255,.8);
}
.modal__error{ border-color: rgba(255,90,90,.35); color: rgba(255,210,210,.9); }

.modal-product{
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 16px;
}
.modal-product__media{
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height: 160px;
}
.modal-product__media img{ width: 100%; height: 100%; object-fit: cover; display:block; }
.modal-product__body{ min-width: 0; }
.modal-product__name{
  font-family: var(--font-head);
  font-weight: 900;
  font-size: 18px;
  margin: 0 0 6px;
}
.modal-product__price{
  font-family: var(--font-head);
  font-weight: 800;
  color: rgba(25,182,255,.92);
  margin-bottom: 10px;
}
.modal-product__desc{
  margin: 0 0 12px;
  color: rgba(234,242,255,.78);
  line-height: 1.5;
}
.modal-product__actions{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}

@media (max-width: 640px){
  .modal-product{
    grid-template-columns: 1fr;
  }
  .modal__dialog{ width: calc(100% - 26px); }
}

/* ── CTA SECTION ─── */
.cta-section{ padding-top: 18px; padding-bottom: 48px; }
.cta-box{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 16px;
  padding: 22px 22px;
  border-radius: var(--radius-xl);
  border: 1px solid rgba(255,255,255,.10);
  background: radial-gradient(520px 200px at 50% 30%, rgba(25,182,255,.12), transparent 60%),
  rgba(255,255,255,.04);
  box-shadow: var(--shadow-sm);
}
.cta-text h2{
  margin: 0 0 6px;
  font-family: var(--font-head);
  font-weight: 900;
  letter-spacing: .2px;
}
.cta-text p{ margin: 0; }

@media (max-width: 760px){
  .cta-box{ flex-direction: column; align-items: flex-start; }
}

/* ── SIDE BANNERS ─── */
.side-banner{
  position: fixed;
  top: 120px;
  width: 140px;
  z-index: 40;
  display:none;
}
.side-banner--left{ left: 14px; }
.side-banner--right{ right: 14px; }

.side-banner__inner{
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  box-shadow: var(--shadow-sm);
  overflow:hidden;
  padding: 10px;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: transform var(--t), border-color var(--t);
}
.side-banner:hover .side-banner__inner{
  transform: translateY(-3px);
  border-color: rgba(25,182,255,.30);
}
.side-banner img{
  width: 100%;
  height: 120px;
  object-fit: cover;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
}
.sb-img-err img{ display:none; }
.side-banner__label{
  margin-top: 10px;
  font-family: var(--font-head);
  font-weight: 900;
  font-size: 13px;
}
.side-banner__cta{
  margin-top: 6px;
  font-size: 12px;
  color: rgba(200,220,255,.75);
}

@media (min-width: 1280px){
  .side-banner{ display:block; }
}

/* ── PAGE SECTIONS / HEADERS ─── */
.section-head{
  margin-bottom: 18px;
}
.section-head h1{
  font-family: var(--font-head);
  font-weight: 900;
  margin: 0 0 6px;
  letter-spacing: .2px;
}
.section-head p{ margin: 0; }

/* ── FORMS ─── */
.form .field{ margin-bottom: 14px; }
.form label{
  display:block;
  font-family: var(--font-head);
  font-weight: 800;
  color: rgba(234,242,255,.90);
  margin-bottom: 8px;
  font-size: 13px;
}
.form input, .form textarea, .form select{
  width: 100%;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  outline: none;
  transition: border-color var(--t), box-shadow var(--t), background var(--t);
}
.form input:focus, .form textarea:focus, .form select:focus{
  border-color: rgba(25,182,255,.35);
  box-shadow: 0 0 0 3px rgba(25,182,255,.10);
  background: rgba(25,182,255,.05);
}
.err{
  margin-top: 6px;
  color: rgba(255,120,120,.95);
  font-size: 12px;
}

#hsToast{
  position: fixed;
  top: 16px;
  left: 50%;
  transform: translate(-50%, -8px);
  opacity: 0;
  pointer-events: none;
  padding: 10px 14px;
  border-radius: 14px;
  border: 1px solid rgba(25,182,255,.35);
  background: rgba(12,18,32,.92);
  color: rgba(234,242,255,.95);
  box-shadow: var(--shadow-sm);
  transition: opacity 200ms ease, transform 200ms ease;
  z-index: 180;
}
#hsToast.is-show{
  opacity: 1;
  transform: translate(-50%, 0);
}
#hsToast.is-error{
  border-color: rgba(255,90,90,.55);
  box-shadow: 0 0 18px rgba(255,90,90,.25);
}

.catalog-controls{
  display:flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: flex-end;
  margin-top: 10px;
  margin-bottom: 10px;
}
.catalog-controls .field{ margin: 0; }
.catalog-controls .field.grow{ flex:1; min-width: 240px; }
.catalog-controls select option{
  background: #0b1220;
  color: rgba(234,242,255,.92);
}
.catalog-controls input::placeholder{
  color: rgba(200,220,255,.45);
}
.services-grid{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}
@media (max-width: 1100px){
  .services-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px){
  .services-grid{ grid-template-columns: 1fr; }
}
.service-card{
  padding: 18px;
  overflow: hidden;
}
.service-ic{
  width: 72px;
  height: 72px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 0 0 1px rgba(25,182,255,.08);
  margin-bottom: 12px;
}
.service-ic svg{
  width: 42px !important;
  height: 42px !important;
  max-width: 42px !important;
  max-height: 42px !important;
  display: block;
}
.service-ic svg *{ vector-effect: non-scaling-stroke; }
.service-card h3{ margin: 6px 0 8px; }
.service-card p{ margin: 0; color: rgba(234,242,255,.78); line-height: 1.45; }
.services-actions{ margin-top: 28px; }

/* OFFERS PAGE */
.offers-hero { padding-bottom: 10px; }
.offers-title { margin: 6px 0 6px; }
.offers-sub { margin: 0; }

.offers-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  align-items: start;
}
@media (max-width: 860px){
  .offers-grid{ grid-template-columns: 1fr; }
}

.offer-card{
  display: flex;
  flex-direction: row;
  align-items: stretch;
  overflow: hidden;
  border-radius: 18px;
}

.offer-img-wrap{
  position: relative;
  flex: 0 0 210px;
  width: 210px;
  height: 100%;
  overflow: hidden;
  border-right: 1px solid rgba(255,255,255,.08);
  border-bottom: 0;
  background: rgba(255,255,255,.03);
  display: flex;
  align-items: center;
  justify-content: center;
}
img.offer-img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  transform: none;
}
.offer-img-ph{
  height: 100%;
  display:flex;
  align-items:center;
  justify-content:center;
  color: rgba(234,242,255,.75);
}

.offer-badge{
  position:absolute;
  left: 12px;
  bottom: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  font-weight: 800;
  font-size: 12px;
  background: rgba(0,0,0,.35);
  border: 1px solid rgba(255,255,255,.10);
  backdrop-filter: blur(10px);
}

.offer-body{ padding: 14px 16px 16px; }
.offer-body{ flex: 1; display: flex; flex-direction: column; }
.offer-title{ margin: 0 0 6px; font-size: 18px; }
.offer-desc{ margin: 0 0 10px; }
.offer-price{ margin: 0 0 10px; font-weight: 800; }

.offer-list{
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 6px;
}
.offer-list li{
  display:flex;
  gap: 8px;
  align-items:flex-start;
  color: rgba(234,242,255,.88);
}
.offer-check{
  width: 18px;
  height: 18px;
  border-radius: 6px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background: rgba(25,182,255,.14);
  border: 1px solid rgba(25,182,255,.20);
  flex: 0 0 auto;
}

.offer-card--active{
  box-shadow: 0 0 0 1px rgba(25,182,255,.25), 0 0 30px rgba(25,182,255,.10);
}

@media (max-width: 780px){
  .offer-card{
    flex-direction: column;
  }
  .offer-img-wrap{
    width: 100%;
    flex: 0 0 180px;
    border-right: 0;
    border-bottom: 1px solid rgba(255,255,255,.08);
  }
}

.section-cta .cta-box{
  display:flex;
  gap:16px;
  align-items:center;
  justify-content:space-between;
}
@media (max-width: 860px){
  .section-cta .cta-box{ flex-direction:column; align-items:flex-start; }
}
.section-cta .cta-acts{ margin-top: 6px; }
.pager{
  display:flex;
  justify-content:flex-end;
  gap:8px;
  margin-top: 14px;
  flex-wrap: wrap;
}
.pager .page{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width: 40px;
  height: 40px;
  padding: 0 12px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  color: rgba(234,242,255,.90);
  font-weight: 700;
  transition: border-color var(--t), box-shadow var(--t), background var(--t), color var(--t);
}
.pager .page:hover{
  border-color: rgba(25,182,255,.45);
  box-shadow: var(--glow-sm);
  background: rgba(25,182,255,.08);
}
.pager .page.is-active{
  border-color: rgba(25,182,255,.55);
  background: rgba(25,182,255,.12);
  color: #eaf6ff;
  box-shadow: var(--glow-sm);
}
.pager .page.is-nav{ min-width: 42px; }
.pager .page.is-disabled{
  opacity: .4;
  pointer-events: none;
  box-shadow: none;
}
.pager .page.is-ellipsis{
  border: none;
  background: transparent;
  min-width: 24px;
  cursor: default;
  color: rgba(234,242,255,.65);
  box-shadow: none;
}

/* ── CONTACT GRID ─── */
.contact-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.contact-line{ margin: 10px 0; color: rgba(234,242,255,.88); }
.map-ph{
  margin-top: 14px;
  border-radius: 16px;
  border: 1px dashed rgba(255,255,255,.12);
  padding: 14px;
  background: rgba(255,255,255,.02);
}
.contact-grid .card h3{
  margin-top: 18px;
}
.faq{
  margin-top: 12px;
  display: grid;
  gap: 10px;
}
.faq-item{
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.03);
  border-radius: 14px;
  overflow: hidden;
}
.faq-item summary{
  list-style: none;
  cursor: pointer;
  padding: 12px 14px;
  font-weight: 700;
  color: rgba(255,255,255,0.92);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
/* FAQ arrow - safe (no unicode) */
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::marker{ content:""; }

.faq-item summary::after{
  content: "";
  display: inline-block;
  width: 10px;
  height: 10px;
  opacity: 0.75;
  border-right: 2px solid rgba(234,242,255,0.55);
  border-bottom: 2px solid rgba(234,242,255,0.55);
  transform: rotate(45deg);               /* down */
  transition: transform 180ms ease, opacity 180ms ease;
  flex: 0 0 auto;
}

.faq-item[open] summary::after{
  transform: rotate(-135deg);             /* up */
}
.faq-body{
  padding: 0 14px 12px 14px;
  color: rgba(255,255,255,0.72);
  line-height: 1.45;
}
/* CONTACT - left split */
.contact-grid .card.glass .contact-left-split{
  height: 100%;
  display: flex;
  flex-direction: column;
}
.contact-grid .card.glass .contact-left-top{
  flex: 1;
}
.contact-grid .card.glass .contact-left-bottom{
  flex: 1;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,0.10);
}
.contact-grid .card.glass .faq{
  margin-top: 12px;
  display: grid;
  gap: 10px;
}
.contact-grid .card.glass .faq-item{
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.03);
  border-radius: 14px;
  overflow: hidden;
}
.contact-grid .card.glass .faq-item summary{
  list-style: none;
  cursor: pointer;
  padding: 12px 14px;
  font-weight: 700;
  color: rgba(255,255,255,0.92);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.contact-grid .card.glass .faq-item summary::-webkit-details-marker{ display:none; }
.contact-grid .card.glass .faq-item summary::after{
  content: "";
  display: inline-block;
  width: 10px;
  height: 10px;
  opacity: 0.75;
  border-right: 2px solid rgba(234,242,255,0.55);
  border-bottom: 2px solid rgba(234,242,255,0.55);
  transform: rotate(45deg);               /* down */
  transition: transform 180ms ease, opacity 180ms ease;
  flex: 0 0 auto;
}
.contact-grid .card.glass .faq-item[open] summary::after{
  transform: rotate(-135deg);             /* up */
}
.contact-grid .card.glass .faq-body{
  padding: 0 14px 12px 14px;
  color: rgba(255,255,255,0.72);
  line-height: 1.45;
}
@media (max-width: 860px){
  .contact-grid .card.glass .contact-left-bottom{
    margin-top: 14px;
    padding-top: 14px;
  }
}
@media (max-width: 980px){
  .contact-grid{ grid-template-columns: 1fr; }
}

/* About page layout */
.about-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.about-gallery{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
}
.about-photo-ph{
  border: 1px dashed rgba(255,255,255,.12);
  border-radius: 16px;
  background: rgba(255,255,255,.02);
  padding: 14px;
  aspect-ratio: 16/10;
  display:flex;
  align-items:center;
  justify-content:center;
  color: rgba(234,242,255,.70);
  text-align:center;
}
@media (max-width: 880px){
  .about-grid{ grid-template-columns: 1fr; }
}

.about-page{
  position: relative;
  overflow: hidden;
}
.about-hero{
  padding-top: 28px;
}
.about-hero__grid{
  display:grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, .9fr);
  gap: 26px;
  align-items: center;
}
.about-badge{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid rgba(63,224,255,.25);
  background: rgba(25,182,255,.10);
  color: var(--text);
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: 12px;
}
.about-hero__copy h1{
  margin: 12px 0 10px;
  font-size: clamp(28px, 2.7vw, 38px);
}
.about-hero__bullets{
  margin: 10px 0 14px;
  padding: 0;
  list-style: none;
  display:grid;
  gap: 8px;
}
.about-hero__bullets li{
  padding-left: 14px;
  position: relative;
}
.about-hero__bullets li::before{
  content:"";
  position:absolute;
  left:0;
  top: 10px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 8px rgba(63,224,255,.55);
}
.about-hero__actions{
  display:flex;
  flex-wrap:wrap;
  gap: 12px;
  margin-top: 10px;
}
.about-hero__visual{
  min-height: 320px;
}
.about-visual{
  position: relative;
  overflow: hidden;
  padding: 18px;
  background: radial-gradient(120% 120% at 20% 20%, rgba(63,224,255,.15), transparent), linear-gradient(135deg, rgba(12,22,45,.92), rgba(6,12,24,.94));
  border: 1px solid rgba(63,224,255,.18);
  box-shadow: 0 18px 50px rgba(0,0,0,.35), 0 0 20px rgba(63,224,255,.18);
}
.about-visual::before, .about-visual::after{
  content:"";
  position:absolute;
  inset: 0;
  background: linear-gradient(120deg, rgba(63,224,255,.12), transparent 55%);
  mix-blend-mode: screen;
  opacity:.5;
  pointer-events:none;
}
.about-visual::after{
  background: radial-gradient(60% 60% at 80% 20%, rgba(90,160,255,.28), transparent 60%);
  opacity:.65;
}
.about-visual__badge, .about-visual__chip{
  display:inline-flex;
  align-items:center;
  padding: 6px 10px;
  border-radius: 12px;
  background: rgba(63,224,255,.14);
  border: 1px solid rgba(63,224,255,.35);
  font-size: 12px;
  letter-spacing: .04em;
}
.about-visual__title{
  margin: 10px 0 6px;
  font-size: 16px;
  font-weight: 700;
}
.about-visual__tags{
  margin: 10px 0 14px;
  padding: 0;
  list-style: none;
  display:flex;
  flex-wrap:wrap;
  gap: 8px;
}
.about-visual__tags li{
  padding: 6px 10px;
  border-radius: 10px;
  border: 1px solid rgba(90,200,255,.30);
  background: rgba(255,255,255,.03);
  font-size: 12px;
}
.about-visual__meter{
  margin-bottom: 10px;
}
.meter-bar{
  position: relative;
  width: 100%;
  height: 6px;
  border-radius: 12px;
  background: rgba(255,255,255,.08);
  overflow: hidden;
}
.meter-bar span{
  display:block;
  height: 100%;
  background: linear-gradient(90deg, var(--accent), #5aa2ff);
  box-shadow: 0 0 10px rgba(63,224,255,.65);
}
.about-visual__blips{
  display:flex;
  flex-wrap:wrap;
  gap: 8px;
  font-size: 12px;
  color: rgba(234,242,255,.9);
}
.about-visual__stat{
  display:flex;
  align-items:flex-end;
  gap: 6px;
  margin: 12px 0 6px;
}
.about-visual__num{
  font-size: 28px;
  font-weight: 800;
  color: var(--accent2);
  text-shadow: 0 0 12px rgba(63,224,255,.35);
}
.about-visual__label{
  font-size: 12px;
  color: rgba(234,242,255,.75);
}
.about-visual__note{
  font-size: 13px;
  color: rgba(234,242,255,.8);
  margin-top: 6px;
}
.about-visual__timeline{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin: 12px 0;
}
.about-visual__timeline div{
  padding: 10px 8px;
  border-radius: 12px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(63,224,255,.24);
  text-align:center;
  font-size: 12px;
}
.about-visual--accent{
  background: radial-gradient(120% 120% at 30% 30%, rgba(83,255,210,.14), transparent), linear-gradient(135deg, rgba(10,36,32,.95), rgba(8,18,28,.95));
}
.about-visual__grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.about-row{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
  align-items:center;
  margin-bottom: 26px;
}
.about-row.is-reverse .about-row__text{ order:2; }
.about-row.is-reverse .about-row__visual{ order:1; }
.about-row__text h3{
  margin: 6px 0 10px;
  font-size: 22px;
}
.about-bullets{
  list-style: none;
  padding: 0;
  margin: 10px 0 0;
  display:grid;
  gap: 8px;
}
.about-bullets li{
  padding-left: 14px;
  position: relative;
  color: rgba(234,242,255,.92);
}
.about-bullets li::before{
  content:"";
  position:absolute;
  left:0; top: 10px;
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 10px rgba(63,224,255,.5);
}
.about-eyebrow{
  color: var(--accent2);
  letter-spacing: .08em;
  font-size: 12px;
  text-transform: uppercase;
}
.about-strip{
  padding-top: 10px;
}
.about-strip__grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 12px;
}
.about-chip{
  padding: 14px;
}
.about-chip__title{
  font-weight: 700;
  margin-bottom: 6px;
}
.about-process__grid{
  position: relative;
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 12px;
}
.about-process__grid::before{
  content:"";
  position:absolute;
  left: 10px;
  right: 10px;
  top: 32px;
  height: 1px;
  background: linear-gradient(90deg, rgba(63,224,255,.35), rgba(63,224,255,.05));
  pointer-events:none;
}
.about-step{
  position: relative;
  padding: 14px;
  display:grid;
  gap: 6px;
}
.about-step__num{
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(63,224,255,.18);
  border: 1px solid rgba(63,224,255,.4);
  font-weight: 800;
  color: var(--text);
  box-shadow: 0 0 12px rgba(63,224,255,.45);
}
.about-step__title{
  font-weight: 700;
}
.about-showcase__grid{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}
.about-showcase{
  position: relative;
  padding: 12px;
  border-radius: 16px;
  background: linear-gradient(160deg, rgba(25,182,255,.14), rgba(6,12,24,.88));
  border: 1px solid rgba(63,224,255,.30);
  overflow: hidden;
  display: flex;
}
.about-showcase__img{
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  width: 100%;
  aspect-ratio: 4 / 3;
  height: auto;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 0;
  background: none;
}
.about-showcase__img img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 14px;
}
.about-showcase__tag{
  position:absolute;
  top: 12px;
  left: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(0,0,0,.45);
  border: 1px solid rgba(63,224,255,.35);
  font-size: 12px;
}
.about-showcase figcaption{
  margin-top: 10px;
  font-size: 13px;
}
.about-cta__card{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 14px;
  padding: 18px;
}
.about-cta__actions{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}
@media (max-width: 980px){
  .about-hero__grid{ grid-template-columns: 1fr; }
  .about-row{ grid-template-columns: 1fr; }
  .about-row.is-reverse .about-row__text,
  .about-row.is-reverse .about-row__visual{ order: unset; }
  .about-process__grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .about-process__grid::before{ display: none; }
}
@media (max-width: 720px){
  .about-showcase__grid{ grid-template-columns: 1fr; }
}
@media (max-width: 640px){
  .about-hero{ padding-top: 18px; }
  .about-hero__actions{ width: 100%; }
  .about-process__grid{ grid-template-columns: 1fr; }
  .about-visual__grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .about-cta__card{ flex-direction: column; align-items:flex-start; }
}
/* ── PRODUCTS LIST ─── */
.products-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-top: 6px;
}
.product-card{
  border-radius: var(--radius-xl);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  overflow:hidden;
  box-shadow: var(--shadow-sm);
  transition: transform var(--t), border-color var(--t), background var(--t);
}
.product-card:hover{
  transform: translateY(-3px);
  border-color: rgba(25,182,255,.30);
  background: rgba(25,182,255,.05);
}
.product-top{ display:block; }
.product-thumb{
  width: 100%;
  height: 170px;
  object-fit: cover;
  background: rgba(255,255,255,.02);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
img.product-thumb{
  display:block;
  width: 100%;
  height: 170px;
  object-fit: cover;
}
.product-body{ padding: 14px; }
.product-name{
  font-family: var(--font-head);
  font-weight: 900;
  margin: 0 0 8px;
  font-size: 14px;
}
.product-meta{
  font-size: 13px;
  color: rgba(200,220,255,.70);
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 8px;
}
.product-price{
  margin-top: 10px;
  font-family: var(--font-head);
  font-weight: 900;
  color: rgba(234,242,255,.95);
}
.product-card .add-row{ padding: 0 14px 14px; }
.btn-small{ padding: 8px 12px; border-radius: 12px; font-size: 12px; }
.thumb-ph{
  width: 54px;
  height: 54px;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity: .9;
}
.thumb-ph svg{ width: 100%; height: 100%; }
.thumb-ph.small,
.thumb-ph.sm{
  width: 42px;
  height: 42px;
}

.cart-layout{ display:grid; grid-template-columns: 1fr 340px; gap: 18px; align-items:start; }
@media (max-width: 900px){ .cart-layout{ grid-template-columns: 1fr; } }

.cart-table{
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  box-shadow: var(--shadow);
  overflow:hidden;
}
.cart-head, .cart-row{
  display:grid;
  grid-template-columns: 1fr 120px 90px 120px 70px;
  gap: 12px;
  align-items:center;
}
.cart-head{
  padding: 12px 14px;
  color: var(--text-muted);
  font-size: 12px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.cart-row{
  padding: 14px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.cart-row:last-child{ border-bottom: none; }
.cart-prod{
  display:flex;
  align-items:center;
  gap: 12px;
  min-width:0;
}
.cart-thumb{
  width: 56px;
  height: 56px;
  border-radius: 16px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
  display:flex;
  align-items:center;
  justify-content:center;
  flex: 0 0 auto;
}
.cart-thumb img{ width:100%; height:100%; object-fit:cover; display:block; }
.cart-thumb .thumb-ph{ width: 42px; height: 42px; opacity:.9; }
.cart-thumb .thumb-ph svg{ width:100%; height:100%; }
.cart-name{
  display:block;
  font-weight: 900;
  color: rgba(234,242,255,.92);
  text-decoration:none;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width: 320px;
}
.cart-actions{
  padding: 12px 14px;
  display:flex;
  justify-content:flex-end;
}
.cart-summary .sum-card{
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  padding: 16px;
  box-shadow: var(--shadow);
}
.sum-row{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  margin-bottom: 10px;
}
.cart-summary .btn{ width: 100%; justify-content:center; }
.empty{
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  padding: 16px;
}
@media (max-width: 720px){
  .cart-head{ display:none; }
  .cart-row{ grid-template-columns: 1fr 120px; }
  .cart-name{ max-width: 220px; }
}

.cart-table .qty{
  width: 78px;
  height: 34px;
  padding: 6px 10px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: rgba(234,242,255,.92);
  outline: none;
  text-align: center;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}
.cart-table .qty:focus{
  border-color: rgba(40,160,255,.45);
  box-shadow: 0 0 0 3px rgba(40,160,255,.18);
}
.cart-table .qty::-webkit-outer-spin-button,
.cart-table .qty::-webkit-inner-spin-button{
  -webkit-appearance: none;
  margin: 0;
}
.cart-table .qty{
  -moz-appearance: textfield;
}
@media (max-width: 1100px){
  .products-grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 820px){
  .products-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 520px){
  .products-grid{ grid-template-columns: 1fr; }
}

/* ── PRODUCT DETAIL ─── */
.breadcrumbs{
  display:inline-flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  margin:0 0 18px;
  border-radius: var(--radius);
  background: var(--glass-bg);
  border:1px solid var(--glass-border);
  box-shadow: var(--shadow-sm);
  color: var(--text-muted);
  overflow-wrap: anywhere;
  width:fit-content;
  max-width:100%;
}
.breadcrumbs a{
  color: var(--text-muted);
  font-weight:700;
  transition: color var(--t);
}
.breadcrumbs a:hover{ color: var(--accent); }
.breadcrumbs span{ color: var(--text-muted); }
.breadcrumbs span:last-child{
  color: var(--text);
  font-weight:800;
}
.product-detail{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 18px;
}
.gallery{
  border-radius: var(--radius-xl);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  padding: 14px;
  box-shadow: var(--shadow-sm);
}
.gallery-main img{
  width:100%;
  height: 340px;
  object-fit: cover;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
}
.gallery-thumbs{
  margin-top: 10px;
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}
.gallery-thumbs img{
  width: 78px;
  height: 64px;
  object-fit: cover;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  opacity: .8;
  transition: opacity var(--t), transform var(--t), border-color var(--t);
}
.gallery-thumbs img:hover{
  opacity: 1;
  transform: translateY(-2px);
  border-color: rgba(25,182,255,.30);
}
.product-panel{
  border-radius: var(--radius-xl);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  padding: 18px;
  box-shadow: var(--shadow-sm);
}
.product-panel h1{
  font-family: var(--font-head);
  font-weight: 900;
  margin: 0 0 10px;
}
.product-panel .desc{
  color: rgba(200,220,255,.72);
  line-height: 1.55;
  font-size: 14px;
}
.buy-box{
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,.08);
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.qty-row{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.buy-box input[type="number"]{
  width: 96px;
  height: 36px;
  padding: 6px 10px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: rgba(234,242,255,.92);
  outline: none;
  text-align: center;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}
.buy-box input[type="number"]:focus{
  border-color: rgba(40,160,255,.45);
  box-shadow: 0 0 0 3px rgba(40,160,255,.18);
}
.buy-box input[type="number"]::-webkit-outer-spin-button,
.buy-box input[type="number"]::-webkit-inner-spin-button{
  -webkit-appearance: none;
  margin: 0;
}
.buy-box input[type="number"]{
  -moz-appearance: textfield;
}
.thumb-btn{
  border: 0;
  background: transparent;
  padding: 0;
  cursor: pointer;
  border-radius: 14px;
}
.thumb-btn:focus-visible{
  outline: 2px solid rgba(40,160,255,.55);
  outline-offset: 3px;
}
@media (max-width: 980px){
  .product-detail{ grid-template-columns: 1fr; }
  .gallery-main img{ height: 260px; }
}

/* ── CHECKOUT REVIEW ─── */
.review{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.rev-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding:10px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.rev-row:last-child{border-bottom:0}
.rev-left{max-width:70%}
.rev-name{font-weight:800; line-height:1.4}
.review .muted.small{line-height:1.5}
.rev-right{font-weight:800; white-space:nowrap}
.rev-total{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 0 6px;
  font-size:16px;
  border-top:1px solid rgba(255,255,255,.10);
}
.rev-total b{font-size:18px}
.review .pill{
  align-self:flex-start;
  margin-top:4px;
}
.checkout-grid .card .btn{
  margin-top:14px;
}
@media (max-width: 720px){
  .rev-left{max-width:100%}
  .rev-row{flex-direction:column; align-items:flex-start;}
  .rev-right{white-space:normal;}
}

/* ── CART / TABLE ─── */
.table{
  width:100%;
  border-collapse: collapse;
  border-radius: 18px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  box-shadow: var(--shadow-sm);
}
.table th, .table td{
  padding: 12px 12px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  text-align:left;
  font-size: 14px;
}
.table th{
  font-family: var(--font-head);
  font-weight: 900;
  color: rgba(234,242,255,.92);
  background: rgba(255,255,255,.03);
}
.table tr:last-child td{ border-bottom: 0; }
.table .qty{
  width: 70px;
  padding: 10px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
}
.table .row-actions{ display:flex; gap: 10px; align-items:center; flex-wrap:wrap; }

/* ── FOOTER ─── */
.site-footer{
  padding: 34px 0 24px;
  border-top: 1px solid rgba(255,255,255,.06);
  background: rgba(0,0,0,.12);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.3fr 1fr 1.1fr 1fr;
  gap: 18px;
  align-items: start;
}
.footer-brand{
  display:flex;
  gap: 12px;
  align-items:center;
}
.footer-logo{
  height: 44px;
  width: auto;
}
.footer-brand-name{
  font-family: var(--font-head);
  font-weight: 900;
  letter-spacing: .3px;
}
.footer-h{
  font-family: var(--font-head);
  font-weight: 900;
  margin-bottom: 10px;
}
.site-footer a{
  display:block;
  padding: 6px 0;
  color: rgba(200,220,255,.75);
}
.site-footer a:hover{ color: rgba(234,242,255,.95); }
.footer-contact-row{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 6px 0;
  color: rgba(200,220,255,.80);
}
.footer-social{
  display:flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 8px;
}
.site-footer .social-link{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  color: rgba(200,220,255,.75);
  transition: color 160ms ease, transform 160ms ease;
}
.site-footer .social-link:hover{
  color: rgba(234,242,255,.95);
  transform: translateX(2px);
}
.social-text{
  font-size: 14px;
  color: rgba(220,230,245,.85);
}
.footer-bottom{
  margin-top: 18px;
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 12px;
  color: rgba(200,220,255,.55);
  font-size: 12px;
}
@media (max-width: 980px){
  .footer-grid{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px){
  .footer-grid{ grid-template-columns: 1fr; }
  .footer-bottom{ flex-direction: column; align-items:flex-start; }
}

/* ── ANIMATIONS (scroll fade) ─── */
[data-animate]{
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 420ms ease, transform 420ms ease;
}
.is-visible[data-animate]{
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce){
  *{ scroll-behavior: auto !important; }
  [data-animate]{ transition: none; opacity: 1; transform: none; }
  .btn, .tile-card, .product-card, .cart-btn, .nav-burger{ transition: none; }
}
@media (max-width: 720px){
  .section{ padding: 34px 0; }
  .section.tight{ padding: 22px 0; }
  .packages-section{ padding-top: 16px; }
  .tiles-section{ padding-top: 18px; }
  .tiles-header{ margin-bottom: 10px; }
  .cta-section{ padding-top: 26px; padding-bottom: 40px; }
}

/* ── RESPONSIVE TYPO + SPACING ─── */
@media (max-width: 560px){
  .container{ width: calc(100% - 24px); }
  .section{ padding: 30px 0; }
  h1 { font-size: 28px; }
}

/* ── ADMIN STYLES (unchanged) ─── */
.admin-body {
  font-family: 'Exo 2', 'Inter', system-ui, sans-serif;
  background: var(--bg-base); color: var(--text);
}
.admin-login {
  display: flex; align-items: center; justify-content: center;
  min-height: 100vh;
}
.login-card {
  width: min(400px, 92vw);
  padding: 32px; border-radius: var(--radius-xl);
  border: 1px solid var(--glass-border);
  background: var(--glass-bg);
  box-shadow: var(--shadow);
}

/* HOME - Packages section */
.packages-section{ padding-top: 10px; }

.packages-head{
display:flex;
align-items: baseline;
justify-content: space-between;
gap: 12px;
margin-bottom: 14px;
}
.pkg-dots{
display:flex;
align-items:center;
gap: 8px;
}
.pkg-dot{
width: 10px;
height: 10px;
border-radius: 50%;
border: 1px solid rgba(90, 200, 255, .45);
background: rgba(120, 200, 255, .20);
box-shadow: 0 0 0 1px rgba(0, 180, 255, .12), 0 0 8px rgba(0, 200, 255, .32);
padding: 0;
cursor: pointer;
opacity: .6;
transition: transform .2s ease, box-shadow .2s ease, background .2s ease, opacity .2s ease;
appearance: none;
}
.pkg-dot.is-active{
background: linear-gradient(145deg, rgba(0, 210, 255, .95), rgba(90, 160, 255, .95));
box-shadow: 0 0 0 1px rgba(0, 210, 255, .4), 0 0 10px rgba(0, 210, 255, .75);
opacity: 1;
transform: scale(1.1);
}

.packages-title{
font-family: var(--font-head);
font-weight: 900;
margin: 0;
}

.packages-grid{
display:grid;
grid-template-columns: repeat(3, 1fr);
gap: 18px;
}

.package-card{
display:block;
color: inherit;
overflow:hidden;
border-radius: 18px;
border: 1px solid rgba(255,255,255,.10);
background: rgba(255,255,255,.04);
box-shadow: var(--shadow-sm);
transition: transform var(--t), border-color var(--t);
}

.package-card:hover{
transform: translateY(-3px);
border-color: rgba(25,182,255,.30);
}

.package-media{
height: 160px;
background: rgba(255,255,255,.03);
border-bottom: 1px solid rgba(255,255,255,.08);
}

.package-media img{
width:100%;
height:100%;
object-fit: cover;
display:block;
}

.package-body{ padding: 14px; }

.package-name{
font-family: var(--font-head);
font-weight: 900;
font-size: 16px;
}

.package-text{ margin-top: 6px; font-size: 13px; }

.package-bullets{
margin: 10px 0 0;
padding-left: 18px;
font-size: 12px;
color: rgba(200,220,255,.80);
}

.package-bullets li{ margin: 4px 0; }

.package-cta{
margin-top: 12px;
display:flex;
align-items:center;
justify-content: space-between;
font-size: 12px;
color: rgba(200,220,255,.75);
}

/* Mobile packages visibility */
@media (max-width: 980px){
  .packages-section{ display:block !important; padding-top: 18px; }
  .packages-head{ margin-bottom: 12px; }
}

@media (max-width: 1100px){
.packages-grid{ grid-template-columns: 1fr; }
.package-media{ height: 140px; }
}

/* Packages carousel */
.pkg-track{
  display:flex;
  gap:14px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  padding: 10px 6px;
}
.pkg-item{
  flex: 0 0 auto;
  width: 240px;
  aspect-ratio: 2 / 3;
  border-radius: 22px;
  overflow:hidden;
  scroll-snap-align:center;
}
.pkg-photo{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.pkg-ph{
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:.9;
}
.pkg-ph svg{ width:64px; height:64px; }
.pkg-carousel{ position:relative; perspective: 1200px; }
.pkg-carousel.is-ready .pkg-track{
  position:relative;
  height: 460px;
  overflow: visible;
}
.pkg-carousel.is-ready .pkg-item{
  position:absolute;
  top: 10px;
  left: 50%;
  transform-style: preserve-3d;
  transition: transform .35s ease, opacity .35s ease, filter .35s ease;
}
.pkg-nav{
  position:absolute;
  top: 50%;
  transform: translateY(-50%);
  width:44px;
  height:44px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: rgba(234,242,255,.92);
  cursor:pointer;
  z-index: 8;
}
.pkg-prev{ left: 6px; }
.pkg-next{ right: 6px; }

@media (max-width: 900px){
  .pkg-item{ width: 200px; }
  .pkg-carousel.is-ready .pkg-track{ height: 360px; }
}
@media (max-width: 720px){
  .pkg-item{ width: 170px; }
  .pkg-carousel.is-ready .pkg-track{ height: 300px; }
  .pkg-nav{ width: 40px; height: 40px; top: calc(50% + 4px); }
}
@media (max-width: 520px){
  .pkg-item{ width: 150px; }
  .pkg-carousel.is-ready .pkg-track{ height: 260px; }
  .pkg-carousel{ perspective: 900px; }
}

/* Mobile-friendly packages carousel */
@media (max-width: 768px){
  .pkg-carousel.is-mobile .pkg-track{
    position: static;
    height: auto;
    overflow-x: auto;
    overflow-y: visible;
    scroll-snap-type: x mandatory;
    padding: 14px 22px 10px;
  }
  .pkg-carousel.is-mobile .pkg-track::-webkit-scrollbar{ display: none; }
  .pkg-carousel.is-mobile .pkg-track{ scrollbar-width: none; }
  .pkg-carousel.is-mobile .pkg-item{
    position: relative;
    top: auto; left: auto;
    transform: none !important;
    opacity: 1 !important;
    filter: none !important;
    pointer-events: auto;
    flex: 0 0 auto;
    width: min(75vw, 300px);
    aspect-ratio: 2 / 3;
    scroll-snap-align: center;
    margin-right: 10px;
  }
  .pkg-carousel.is-mobile .pkg-photo,
  .pkg-carousel.is-mobile .pkg-ph{
    border-radius: inherit;
  }
  .pkg-carousel.is-mobile .pkg-nav{
    top: 8px;
    transform: none;
    width: 42px;
    height: 42px;
    box-shadow: 0 6px 20px rgba(0,0,0,.45), 0 0 14px rgba(25,182,255,.25);
    border: 1px solid rgba(63,224,255,.4);
    background: linear-gradient(145deg, rgba(12,20,36,.9), rgba(10,16,30,.92));
    color: rgba(234,242,255,.92);
    z-index: 2;
    display: none;
  }
  .pkg-carousel.is-mobile .pkg-prev{ left: 6px; }
  .pkg-carousel.is-mobile .pkg-next{ right: 6px; }
  .pkg-carousel.is-mobile{ perspective: none; }
}

/* ── THANK YOU ─────────────────────────────────────────────── */
.thank{
  max-width: 980px;
  margin: 0 auto;
}

.thank-head{
  display:flex;
  align-items:center;
  gap: 12px;
  margin-bottom: 6px;
}

.thank-head h1{
  margin: 0;
}

.thank-ic{
  width: 22px;
  height: 22px;
  border-radius: 6px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex: 0 0 auto;
  font-weight: 900;
  font-size: 14px;
  line-height: 1;
  background: rgba(55,255,165,.10);
  border: 1px solid rgba(55,255,165,.20);
  color: rgba(55,255,165,.95);
  box-shadow: 0 0 0 1px rgba(55,255,165,.08);
}

.thank-card{
  width: min(760px, 100%);
  margin-top: 12px;
}

.thank-card .thank-kv{
  justify-content:flex-start;
  align-items:baseline;
}
.thank-card .thank-kv > div:first-child{
  min-width: 170px;
}

.thank-actions{
  margin-top: 14px;
}
.thank-actions + .muted.small{
  margin-top: 10px;
}

@media (max-width: 560px){
  .thank-card{ width: 100%; }
  .thank-card .thank-kv > div:first-child{ min-width: 0; }
}
.tile-card.tile-has-photo .tile-img-area{
  height: 120px;
  background: none;
  padding: 0;
  overflow: hidden;
}
.tile-card.tile-has-photo .tile-photo{
  width: 100%;
  height: 100%;
  display: block;
  border-radius: 0;
  border: 0;
  box-shadow: none;
  object-fit: cover;
  object-position: center;
}
