:root{
  --bg:#050505;
  --bg-2:#0a0a0a;
  --surface:#0d0d0d;
  --surface-2:#111111;
  --surface-3:#151515;

  --text:#f3f3f3;
  --muted:#8d8d8d;
  --muted-2:#6f6f6f;

  --line:rgba(255,255,255,.08);
  --line-soft:rgba(255,255,255,.05);

  --primary:#ff8a3d;
  --primary-2:#ff9f5a;
  --primary-soft:rgba(255,138,61,.14);
  --primary-glow:rgba(255,138,61,.22);

  --radius:24px;
  --radius-sm:16px;

  --shadow:0 18px 50px rgba(0,0,0,.38);
  --shadow-soft:0 10px 30px rgba(0,0,0,.24);
}

*{box-sizing:border-box}

html{
  scroll-behavior:smooth;
}

body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at 20% 10%, rgba(255,138,61,.10), transparent 24%),
    radial-gradient(circle at 80% 18%, rgba(255,138,61,.06), transparent 20%),
    radial-gradient(circle at 50% 85%, rgba(255,120,40,.05), transparent 24%),
    linear-gradient(180deg, #020202 0%, #070707 100%);
  background-size:120% 120%, 120% 120%, 140% 140%, 100% 100%;
  background-position:20% 10%, 80% 18%, 50% 85%, 0 0;
  animation:bgFloat 20s ease-in-out infinite;
  min-height:100vh;
  position:relative;
  overflow-x:hidden;
}

@keyframes bgFloat{
  0%{
    background-position:20% 10%, 80% 18%, 50% 85%, 0 0;
  }
  25%{
    background-position:24% 12%, 76% 22%, 52% 80%, 0 0;
  }
  50%{
    background-position:18% 16%, 82% 16%, 48% 88%, 0 0;
  }
  75%{
    background-position:22% 8%, 78% 20%, 54% 82%, 0 0;
  }
  100%{
    background-position:20% 10%, 80% 18%, 50% 85%, 0 0;
  }
}

/* animated grid */
body::before{
  content:"";
  position:fixed;
  inset:-10%;
  pointer-events:none;
  z-index:0;
  opacity:.18;
  background:
    linear-gradient(rgba(255,138,61,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,138,61,.05) 1px, transparent 1px),
    radial-gradient(circle at 15% 20%, rgba(255,138,61,.10), transparent 18%),
    radial-gradient(circle at 85% 25%, rgba(255,150,80,.06), transparent 16%),
    radial-gradient(circle at 50% 85%, rgba(255,138,61,.05), transparent 20%);
  background-size:64px 64px, 64px 64px, 160% 160%, 160% 160%, 180% 180%;
  background-position:0 0, 0 0, 10% 20%, 90% 20%, 50% 80%;
  mask-image:linear-gradient(180deg, transparent 0%, rgba(0,0,0,.75) 16%, rgba(0,0,0,.85) 84%, transparent 100%);
  animation:gridMove 24s linear infinite, bgGlowMove 26s ease-in-out infinite;
  will-change:transform, background-position;
}

@keyframes gridMove{
  0%{
    background-position:0 0, 0 0, 10% 20%, 90% 20%, 50% 80%;
  }
  100%{
    background-position:64px 64px, 64px 64px, 10% 20%, 90% 20%, 50% 80%;
  }
}

@keyframes bgGlowMove{
  0%{
    transform:translate3d(0,0,0) scale(1);
  }
  50%{
    transform:translate3d(0,-8px,0) scale(1.03);
  }
  100%{
    transform:translate3d(0,0,0) scale(1);
  }
}

/* traffic routes */
body::after{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:0;
  opacity:.28;
  background:
    radial-gradient(circle at 12% 22%, rgba(255,138,61,.22) 0 2px, transparent 3px),
    radial-gradient(circle at 28% 60%, rgba(255,138,61,.14) 0 2px, transparent 3px),
    radial-gradient(circle at 46% 34%, rgba(255,138,61,.18) 0 2px, transparent 3px),
    radial-gradient(circle at 66% 72%, rgba(255,138,61,.15) 0 2px, transparent 3px),
    radial-gradient(circle at 84% 26%, rgba(255,138,61,.20) 0 2px, transparent 3px),
    linear-gradient(115deg, transparent 0 12%, rgba(255,138,61,.05) 12.2% 12.5%, transparent 12.8% 100%),
    linear-gradient(32deg, transparent 0 26%, rgba(255,138,61,.04) 26.2% 26.5%, transparent 26.8% 100%),
    linear-gradient(144deg, transparent 0 54%, rgba(255,138,61,.035) 54.2% 54.45%, transparent 54.7% 100%);
  animation:trafficPulse 8s ease-in-out infinite, trafficShift 20s linear infinite;
  mask-image:linear-gradient(180deg, transparent 0%, rgba(0,0,0,.7) 14%, rgba(0,0,0,.88) 86%, transparent 100%);
}

@keyframes trafficPulse{
  0%,100%{
    opacity:.18;
    filter:brightness(1);
  }
  50%{
    opacity:.33;
    filter:brightness(1.2);
  }
}

@keyframes trafficShift{
  0%{
    transform:translate3d(0,0,0);
  }
  50%{
    transform:translate3d(8px,-6px,0);
  }
  100%{
    transform:translate3d(0,0,0);
  }
}

.site-header,
main,
.site-footer{
  position:relative;
  z-index:1;
}

a{
  color:inherit;
  text-decoration:none;
}

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

.narrow{
  width:min(860px, calc(100% - 32px));
  margin:0 auto;
}

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  backdrop-filter:blur(14px);
  background:rgba(5,5,5,.78);
  border-bottom:1px solid var(--line-soft);
}

.header-row{
  min-height:78px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}

.brand{
  font-size:30px;
  font-weight:800;
  letter-spacing:-.03em;
  color:#f5f5f5;
}

.nav{
  display:flex;
  gap:24px;
}

.nav a{
  position:relative;
  color:#b0b0b0;
  font-weight:500;
  transition:color .2s ease;
}

.nav a:hover{
  color:#fff;
}

.nav a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-8px;
  width:0;
  height:2px;
  border-radius:2px;
  background:linear-gradient(90deg, #ff9a52, #ff7f30);
  transition:width .22s ease;
}

.nav a:hover::after{
  width:100%;
}

.header-actions{
  display:flex;
  gap:12px;
}

.btn{
  position:relative;
  overflow:hidden;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:0 18px;
  border-radius:16px;
  border:1px solid var(--line);
  font-weight:700;
  transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease,background .22s ease;
}

.btn:hover{
  transform:translateY(-1px);
}

.btn::after{
  content:"";
  position:absolute;
  inset:auto -40% 0 auto;
  width:120px;
  height:120px;
  background:radial-gradient(circle, rgba(255,255,255,.18), transparent 60%);
  transform:translate(50%,50%);
  opacity:0;
  transition:opacity .25s ease;
}

.btn:hover::after{
  opacity:1;
}

.btn-primary{
  color:#fff;
  border:1px solid rgba(255,138,61,.28);
  background:linear-gradient(180deg, #ff994f 0%, #ff8234 100%);
  box-shadow:0 10px 30px rgba(255,138,61,.18);
}

.btn-secondary{
  background:rgba(255,255,255,.02);
  border:1px solid rgba(255,255,255,.08);
}

.btn-ghost{
  background:rgba(255,255,255,.01);
  border:1px solid rgba(255,255,255,.07);
}

.btn-lg{
  min-height:56px;
  padding:0 24px;
}

.w-full{
  width:100%;
}

.hero{
  position:relative;
  overflow:hidden;
  padding:72px 0 34px;
}

.hero::before{
  content:"";
  position:absolute;
  inset:-10% -10% auto -10%;
  height:720px;
  pointer-events:none;
  background:
    radial-gradient(circle at 18% 22%, rgba(255,138,61,.14), transparent 22%),
    radial-gradient(circle at 78% 18%, rgba(255,160,90,.08), transparent 18%),
    radial-gradient(circle at 52% 60%, rgba(255,138,61,.06), transparent 24%);
  filter:blur(18px);
  animation:heroGlowFloat 14s ease-in-out infinite;
}

.hero::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(180deg, rgba(255,255,255,.015), transparent 24%),
    linear-gradient(90deg, rgba(255,138,61,.03), transparent 18%, transparent 82%, rgba(255,138,61,.03));
  mask-image:linear-gradient(180deg, rgba(0,0,0,.9), rgba(0,0,0,.2) 70%, transparent);
  opacity:.7;
}

@keyframes heroGlowFloat{
  0%{
    transform:translate3d(0,0,0) scale(1);
  }
  50%{
    transform:translate3d(0,-12px,0) scale(1.03);
  }
  100%{
    transform:translate3d(0,0,0) scale(1);
  }
}

.hero-grid{
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:28px;
  align-items:center;
}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(255,138,61,.08);
  border:1px solid rgba(255,138,61,.16);
  color:#ffb078;
  font-size:14px;
  margin-bottom:18px;
}

.hero h1{
  position:relative;
  margin:0 0 16px;
  font-size:clamp(40px, 7vw, 72px);
  line-height:.98;
  letter-spacing:-.05em;
  max-width:760px;
}

.hero h1::after{
  content:"";
  display:block;
  width:140px;
  height:4px;
  margin-top:18px;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(255,138,61,.95), rgba(255,180,110,.28));
  box-shadow:0 0 24px rgba(255,138,61,.22);
  animation:titleLinePulse 3.2s ease-in-out infinite;
}

@keyframes titleLinePulse{
  0%,100%{
    width:140px;
    opacity:.9;
  }
  50%{
    width:180px;
    opacity:1;
  }
}

.lead{
  margin:0;
  max-width:650px;
  font-size:19px;
  line-height:1.65;
  color:#9c9c9c;
}

.hero-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin:28px 0 18px;
}

.hero-bullets{
  display:flex;
  flex-wrap:wrap;
  gap:18px;
  color:#bdbdbd;
  font-size:15px;
}

.hero-bullets span::before{
  content:"•";
  color:var(--primary);
  margin-right:8px;
}

.hero-card{
  position:relative;
  min-height:470px;
  display:flex;
  align-items:center;
  justify-content:center;
  isolation:isolate;
}

.hero-card::before{
  content:"";
  position:absolute;
  inset:6% 4%;
  border-radius:34px;
  background:
    radial-gradient(circle at 25% 30%, rgba(255,138,61,.10), transparent 24%),
    radial-gradient(circle at 72% 38%, rgba(255,170,90,.07), transparent 20%),
    radial-gradient(circle at 55% 80%, rgba(255,138,61,.06), transparent 24%);
  filter:blur(18px);
}

.hero-card::after{
  content:"";
  position:absolute;
  inset:auto 10% 6% auto;
  width:160px;
  height:160px;
  border-radius:50%;
  pointer-events:none;
  background:radial-gradient(circle, rgba(255,138,61,.14), transparent 70%);
  filter:blur(8px);
  animation:orbFloat 8s ease-in-out infinite;
}

@keyframes orbFloat{
  0%,100%{
    transform:translate3d(0,0,0);
  }
  50%{
    transform:translate3d(-10px,-14px,0);
  }
}

.status-card{
  position:relative;
  z-index:1;
  width:min(520px, 100%);
  padding:28px;
  border-radius:32px;
  background:linear-gradient(180deg, rgba(18,18,18,.96), rgba(8,8,8,.98));
  border:1px solid rgba(255,138,61,.14);
  box-shadow:var(--shadow);
  overflow:hidden;
  transition:transform .35s ease,box-shadow .35s ease,border-color .3s ease;
}

.status-card::before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:inherit;
  pointer-events:none;
  background:
    radial-gradient(circle at 15% 20%, rgba(255,138,61,.18), transparent 24%),
    radial-gradient(circle at 85% 25%, rgba(255,170,90,.10), transparent 20%),
    linear-gradient(180deg, rgba(255,255,255,.03), transparent 32%);
  opacity:.85;
}

.status-card::after{
  content:"";
  position:absolute;
  top:-120%;
  left:-40%;
  width:70%;
  height:280%;
  pointer-events:none;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.08), transparent);
  transform:rotate(18deg);
  animation:heroSheen 7s ease-in-out infinite;
}

@keyframes heroSheen{
  0%,100%{
    left:-55%;
    opacity:0;
  }
  12%{
    opacity:0;
  }
  20%{
    left:110%;
    opacity:.5;
  }
  21%{
    opacity:0;
  }
}

.hero-card:hover .status-card{
  transform:translateY(-10px) scale(1.015);
  border-color:rgba(255,138,61,.24);
  box-shadow:
    0 28px 70px rgba(0,0,0,.46),
    0 0 0 1px rgba(255,138,61,.08) inset,
    0 0 60px rgba(255,138,61,.10);
}

.status-top{
  display:flex;
  align-items:center;
  gap:10px;
  color:#b5b5b5;
  font-size:14px;
  margin-bottom:18px;
}

.status-dot{
  width:10px;
  height:10px;
  border-radius:50%;
  background:var(--primary);
  box-shadow:0 0 18px rgba(255,138,61,.55);
}

.status-title{
  font-size:28px;
  font-weight:800;
  margin-bottom:12px;
}

.status-text{
  margin:0 0 16px;
  color:#9a9a9a;
  line-height:1.6;
}

.status-bar{
  position:relative;
  width:100%;
  height:10px;
  border-radius:999px;
  background:rgba(255,255,255,.06);
  overflow:hidden;
  margin:0 0 18px;
  border:1px solid rgba(255,255,255,.04);
}

.status-bar::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.08), transparent);
  transform:translateX(-100%);
  animation:statusBarSweep 3.6s ease-in-out infinite;
}

.status-bar-fill{
  position:relative;
  width:72%;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg, #ff9e57 0%, #ff8234 45%, #ffb36e 100%);
  background-size:200% 100%;
  box-shadow:0 0 20px rgba(255,138,61,.25);
  animation:pulseBar 2.8s ease-in-out infinite, barGradientMove 4.2s linear infinite;
}

.status-bar-fill::after{
  content:"";
  position:absolute;
  top:0;
  right:-18px;
  width:36px;
  height:100%;
  filter:blur(8px);
  background:rgba(255,190,120,.55);
}

@keyframes pulseBar{
  0%,100%{
    filter:brightness(1);
  }
  50%{
    filter:brightness(1.15);
  }
}

@keyframes statusBarSweep{
  0%{
    transform:translateX(-100%);
    opacity:0;
  }
  20%{
    opacity:.55;
  }
  60%{
    opacity:.25;
  }
  100%{
    transform:translateX(140%);
    opacity:0;
  }
}

@keyframes barGradientMove{
  0%{
    background-position:0% 50%;
  }
  100%{
    background-position:200% 50%;
  }
}

.status-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
}

.metric{
  padding:18px;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,.01));
  border:1px solid rgba(255,255,255,.06);
  transition:transform .22s ease,border-color .22s ease,background .22s ease,box-shadow .22s ease;
}

.metric:hover{
  transform:translateY(-3px);
  border-color:rgba(255,138,61,.18);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,138,61,.02));
  box-shadow:0 10px 24px rgba(0,0,0,.18);
}

.metric-value{
  font-size:28px;
  font-weight:800;
}

.metric-label{
  margin-top:6px;
  color:#8f8f8f;
}

.strip{
  padding:8px 0 18px;
}

.strip-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}

.section{
  padding:72px 0;
}

.section-dark{
  background:linear-gradient(180deg, rgba(255,255,255,.008), rgba(255,255,255,0));
}

.section-head{
  margin-bottom:28px;
}

.section-kicker{
  margin-bottom:12px;
  color:var(--primary);
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:12px;
  font-weight:700;
}

.section h2{
  margin:0 0 10px;
  font-size:clamp(32px, 4.5vw, 50px);
  line-height:1.03;
  letter-spacing:-.04em;
}

.section-head p{
  margin:0;
  max-width:720px;
  font-size:18px;
  color:#969696;
}

.strip-card,
.card,
.price-card,
.trial-card,
.app-card,
.cta-box,
.faq-item{
  background:linear-gradient(180deg, rgba(17,17,17,.94), rgba(10,10,10,.98));
  border:1px solid rgba(255,255,255,.06);
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
}

.interactive-card{
  transition:
    transform .28s ease,
    border-color .22s ease,
    box-shadow .22s ease,
    background .22s ease;
  will-change:transform;
}

.interactive-card:hover{
  border-color:rgba(255,138,61,.22);
  box-shadow:
    0 18px 40px rgba(0,0,0,.34),
    0 0 0 1px rgba(255,138,61,.06) inset;
}

.strip-card{
  padding:18px 20px;
}

.strip-card strong{
  display:block;
  font-size:17px;
}

.strip-card span{
  display:block;
  margin-top:6px;
  color:#8f8f8f;
}

.cards{
  display:grid;
  gap:18px;
}

.cards-3{
  grid-template-columns:repeat(3,1fr);
}

.card{
  padding:24px;
}

.card h3{
  margin:0 0 10px;
  font-size:21px;
}

.card p{
  margin:0;
  color:#979797;
  line-height:1.65;
}

.pricing-switch{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin:0 0 22px;
}

.plan-tab{
  min-height:42px;
  padding:0 16px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.02);
  color:#c6c6c6;
  cursor:pointer;
  font:inherit;
  font-weight:700;
  transition:.2s ease;
}

.plan-tab:hover{
  border-color:rgba(255,138,61,.18);
  color:#fff;
}

.plan-tab.active{
  background:rgba(255,138,61,.10);
  border-color:rgba(255,138,61,.24);
  color:#ffae75;
  box-shadow:0 0 0 1px rgba(255,138,61,.06) inset;
}

.pricing-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  align-items:stretch;
  overflow:visible;
}

.price-card,
.trial-card{
  position:relative;
  min-height:100%;
  display:flex;
  flex-direction:column;
  padding:24px;
  transform-origin:center bottom;
}

.price-card h3,
.trial-card h3{
  margin:0 0 10px;
  font-size:25px;
  min-height:60px;
}

.price{
  margin:0 0 14px;
  font-size:40px;
  font-weight:800;
  min-height:58px;
}

.price span{
  margin-left:6px;
  font-size:18px;
  font-weight:600;
  color:#8f8f8f;
}

.price-card ul{
  margin:0 0 18px;
  padding-left:18px;
  color:#9a9a9a;
  line-height:1.7;
  flex:1;
}

.price-card .btn,
.trial-card .btn{
  margin-top:auto;
}

.pricing-grid > .price-card,
.pricing-grid > .trial-card{
  z-index:1;
}

.pricing-grid > .price-card:hover,
.pricing-grid > .trial-card:hover{
  transform:translateY(-14px) scale(1.02);
  z-index:8;
}

.pricing-grid > .featured:hover{
  transform:translateY(-18px) scale(1.025);
}

.featured{
  position:relative;
  border-color:rgba(255,138,61,.32);
  box-shadow:
    0 16px 44px rgba(0,0,0,.34),
    0 0 0 1px rgba(255,138,61,.08) inset;
}

.featured::after{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:inherit;
  pointer-events:none;
  background:radial-gradient(circle at top, rgba(255,138,61,.14), transparent 45%);
  opacity:.7;
}

.badge{
  position:absolute;
  top:16px;
  right:16px;
  padding:8px 12px;
  border-radius:999px;
  font-size:12px;
  font-weight:800;
  background:rgba(255,138,61,.12);
  color:#ffac73;
  border:1px solid rgba(255,138,61,.18);
}

.payment-box{
  margin-top:20px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.06);
}

.payment-box h4{
  margin:0 0 12px;
}

.payment-list{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.payment-list span{
  padding:10px 12px;
  border-radius:12px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
  color:#d5d5d5;
}

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

.app-card{
  position:relative;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:22px;
}

.app-card::before{
  content:"";
  position:absolute;
  inset:auto auto -30px -30px;
  width:90px;
  height:90px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(255,138,61,.14), transparent 65%);
  opacity:0;
  transition:opacity .25s ease;
}

.app-card:hover::before{
  opacity:1;
}

.app-title{
  position:relative;
  z-index:1;
  font-size:20px;
  font-weight:700;
}

.app-desc{
  position:relative;
  z-index:1;
  color:#949494;
  line-height:1.5;
}

.faq-list{
  display:grid;
  gap:14px;
}

.faq-item{
  overflow:hidden;
  transition:border-color .2s ease, box-shadow .2s ease;
}

.faq-item[open]{
  border-color:rgba(255,138,61,.18);
  box-shadow:0 10px 26px rgba(0,0,0,.26);
}

.faq-item summary{
  cursor:pointer;
  list-style:none;
  padding:22px 24px;
  font-size:19px;
  font-weight:700;
}

.faq-item summary::-webkit-details-marker{
  display:none;
}

.faq-item p{
  margin:0;
  padding:0 24px 22px;
  color:#969696;
  line-height:1.65;
}

.cta-box{
  padding:30px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}

.cta-box h2{
  margin:0 0 10px;
  font-size:38px;
}

.cta-box p{
  margin:0;
  color:#979797;
}

.cta-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

.site-footer{
  padding:34px 0 20px;
  border-top:1px solid rgba(255,255,255,.05);
}

.footer-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr .8fr;
  gap:24px;
}

.footer-brand{
  font-size:28px;
  margin-bottom:10px;
}

.site-footer p{
  max-width:420px;
  color:#949494;
}

.site-footer h4{
  margin:0 0 12px;
}

.site-footer a{
  display:block;
  margin:8px 0;
  color:#939393;
}

.site-footer a:hover{
  color:#fff;
}

.footer-bottom{
  margin-top:24px;
  padding-top:18px;
  display:flex;
  justify-content:space-between;
  gap:12px;
  border-top:1px solid rgba(255,255,255,.05);
  color:#8e8e8e;
}

.reveal{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .6s ease, transform .6s ease;
}

.reveal.is-visible{
  opacity:1;
  transform:translateY(0);
}

main::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:0;
  opacity:.04;
  background:repeating-linear-gradient(
    180deg,
    rgba(255,255,255,.08) 0px,
    rgba(255,255,255,.08) 1px,
    transparent 2px,
    transparent 4px
  );
  mix-blend-mode:soft-light;
}

@media (max-width:1100px){
  .hero-grid,
  .pricing-grid,
  .footer-grid{
    grid-template-columns:1fr;
  }

  .cards-3,
  .strip-grid,
  .apps-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .cta-box{
    flex-direction:column;
    align-items:flex-start;
  }
}

@media (max-width:760px){
  .nav,
  .header-actions .btn-ghost{
    display:none;
  }

  .header-row{
    min-height:68px;
  }

  .hero{
    padding:42px 0 18px;
  }

  .lead{
    font-size:17px;
  }

  .cards-3,
  .strip-grid,
  .apps-grid{
    grid-template-columns:1fr;
  }

  .status-grid{
    grid-template-columns:1fr;
  }

  .hero-bullets{
    flex-direction:column;
    gap:10px;
  }

  .hero-actions,
  .cta-actions{
    width:100%;
  }

  .btn,
  .btn-lg{
    width:100%;
  }

  .footer-bottom{
    flex-direction:column;
  }

  .pricing-switch{
    display:grid;
    grid-template-columns:repeat(2,1fr);
  }

  .plan-tab{
    width:100%;
  }

  body{
    animation:bgFloat 24s ease-in-out infinite;
  }

  body::before{
    opacity:.12;
  }

  body::after{
    opacity:.18;
  }

  .hero-card:hover .status-card{
    transform:translateY(-4px) scale(1.005);
  }

  .pricing-grid > .price-card:hover,
  .pricing-grid > .trial-card:hover,
  .pricing-grid > .featured:hover{
    transform:translateY(-6px) scale(1.01);
  }

  .hero h1::after{
    width:110px;
  }
}

/* ===== Final polish ===== */
.nav a.is-active{
  color:#fff;
}

.nav a.is-active::after{
  width:100%;
}

.faq-item summary{
  transition:background .2s ease, color .2s ease;
}

.faq-item:hover summary{
  background:rgba(255,138,61,.03);
  color:#fff;
}

.cta-box .btn-primary{
  animation:ctaPulse 2.8s ease-in-out infinite;
}

@keyframes ctaPulse{
  0%,100%{
    box-shadow:0 10px 30px rgba(255,138,61,.18);
  }
  50%{
    box-shadow:0 14px 40px rgba(255,138,61,.28);
  }
}

.featured{
  overflow:hidden;
}

.featured::before{
  content:"";
  position:absolute;
  inset:auto -20% -55% auto;
  width:220px;
  height:220px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(255,138,61,.16), transparent 68%);
  animation:featuredOrb 5.5s ease-in-out infinite;
  pointer-events:none;
}

@keyframes featuredOrb{
  0%,100%{
    transform:translate3d(0,0,0) scale(1);
    opacity:.85;
  }
  50%{
    transform:translate3d(-12px,-10px,0) scale(1.08);
    opacity:1;
  }
}

/* ===== IP card ===== */
.ip-card.status-unsafe{
  border-color:rgba(255,138,61,.18);
}

.ip-card.status-safe{
  border-color:rgba(46, 204, 113, .28);
}

.ip-card.status-safe .status-dot{
  background:#2ecc71;
  box-shadow:0 0 18px rgba(46,204,113,.55);
}

.ip-card.status-safe .status-bar-fill{
  background:linear-gradient(90deg, #36d97d 0%, #22c55e 45%, #8df0b6 100%);
}

.ip-summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin:0 0 18px;
  padding:18px;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,.01));
  border:1px solid rgba(255,255,255,.06);
}

.ip-main{
  min-width:0;
}

.ip-label{
  color:#8f8f8f;
  font-size:13px;
  margin-bottom:8px;
}

.ip-value{
  font-size:26px;
  line-height:1.15;
  font-weight:800;
  word-break:break-word;
}

.ip-shield{
  width:56px;
  height:56px;
  flex:0 0 56px;
  border-radius:16px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:28px;
  font-weight:800;
  color:#1d1208;
  background:linear-gradient(180deg, #ffb070 0%, #ff8a3d 100%);
  box-shadow:0 10px 24px rgba(255,138,61,.18);
}

.status-safe .ip-shield{
  color:#07160d;
  background:linear-gradient(180deg, #7df0ab 0%, #2ecc71 100%);
  box-shadow:0 10px 24px rgba(46,204,113,.18);
}

#ip-isp{
  font-size:18px;
  line-height:1.25;
  word-break:break-word;
}

#ip-status{
  color:#ffad75;
}

.status-safe #ip-status{
  color:#7df0ab;
}

.ip-card-actions{
  margin-top:18px;
}

@media (max-width:760px){
  .ip-summary{
    align-items:flex-start;
  }

  .ip-value{
    font-size:22px;
  }

  .ip-shield{
    width:48px;
    height:48px;
    flex-basis:48px;
    font-size:24px;
  }
}

/* ===== Scroll white-edge fix ===== */
html{
  background:#020202 !important;
  min-height:100%;
  overflow-x:hidden;
}

body{
  background-color:#020202 !important;
  min-height:100%;
  overflow-x:hidden;
  overscroll-behavior-y:none;
}

.site-header,
main,
.site-footer{
  background:transparent;
}

body::before{
  inset:0 !important;
  opacity:.10 !important;
  mask-image:none !important;
  -webkit-mask-image:none !important;
}

body::after{
  inset:0 !important;
  opacity:.16 !important;
  mask-image:none !important;
  -webkit-mask-image:none !important;
}

main::before{
  display:none !important;
}

.hero::before,
.hero::after{
  pointer-events:none;
}

@media (max-width:760px){
  body::before{
    opacity:.07 !important;
  }

  body::after{
    opacity:.10 !important;
  }
}

/* ===== Trust bar ===== */
.trust-bar{
  padding:6px 0 10px;
}

.trust-bar-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
}

.trust-pill{
  min-height:52px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 16px;
  border-radius:999px;
  background:linear-gradient(180deg, rgba(17,17,17,.94), rgba(10,10,10,.98));
  border:1px solid rgba(255,255,255,.06);
  box-shadow:var(--shadow-soft);
  color:#d8d8d8;
  font-weight:700;
}

/* ===== Step cards ===== */
.step-card{
  position:relative;
}

.step-number{
  width:42px;
  height:42px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:16px;
  background:linear-gradient(180deg, #ff994f 0%, #ff8234 100%);
  color:#fff;
  font-weight:800;
  box-shadow:0 10px 26px rgba(255,138,61,.18);
}

/* ===== Services ===== */
.service-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}

.service-card{
  min-height:92px;
  display:flex;
  align-items:center;
  gap:14px;
  padding:20px 22px;
  border-radius:20px;
  background:linear-gradient(180deg, rgba(17,17,17,.94), rgba(10,10,10,.98));
  border:1px solid rgba(255,255,255,.06);
  box-shadow:var(--shadow-soft);
  font-size:20px;
  font-weight:700;
}

.service-icon{
  width:40px;
  height:40px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,138,61,.10);
  border:1px solid rgba(255,138,61,.16);
  color:#ffb078;
  font-weight:800;
}

/* ===== Locations ===== */
.location-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}

.location-card{
  min-height:96px;
  display:flex;
  align-items:center;
  gap:14px;
  padding:20px 22px;
  border-radius:20px;
  background:linear-gradient(180deg, rgba(17,17,17,.94), rgba(10,10,10,.98));
  border:1px solid rgba(255,255,255,.06);
  box-shadow:var(--shadow-soft);
}

.location-card span{
  font-size:28px;
}

.location-card strong{
  font-size:20px;
}

/* ===== Mobile sticky CTA ===== */
.mobile-sticky-cta{
  position:fixed;
  left:16px;
  right:16px;
  bottom:14px;
  z-index:60;
  display:none;
  padding-bottom:calc(env(safe-area-inset-bottom, 0px));
}

.mobile-sticky-cta .btn{
  width:100%;
  min-height:54px;
  box-shadow:0 18px 40px rgba(0,0,0,.34), 0 10px 30px rgba(255,138,61,.18);
}

/* ===== Footer polish ===== */
.site-footer{
  padding-bottom:28px;
}

.footer-grid h4{
  color:#f1f1f1;
}

.footer-grid a{
  transition:color .2s ease;
}

.footer-grid a:hover{
  color:#fff;
}

/* ===== Responsive additions ===== */
@media (max-width:1100px){
  .trust-bar-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .service-grid,
  .location-grid{
    grid-template-columns:repeat(2,1fr);
  }
}

@media (max-width:760px){
  .trust-bar-grid,
  .service-grid,
  .location-grid{
    grid-template-columns:1fr;
  }

  .mobile-sticky-cta{
    display:block;
  }

  body{
    padding-bottom:88px;
  }
}

/* ===== Emergency scroll restore ===== */
html,
body{
  overflow-y:auto !important;
  overflow-x:hidden !important;
  height:auto !important;
  min-height:100% !important;
  position:static !important;
}

body{
  touch-action:auto !important;
}

main,
.hero,
.section,
.site-footer{
  overflow:visible !important;
}

body::before,
body::after,
main::before,
.hero::before,
.hero::after{
  pointer-events:none !important;
}

.mobile-sticky-cta{
  display:none !important;
}

/* ===== Hard scroll fix ===== */
html,
body{
  overflow-y: auto !important;
  overflow-x: hidden !important;
  height: auto !important;
  min-height: 100% !important;
  overscroll-behavior: auto !important;
}

body{
  position: relative !important;
}

/* отключаем все декоративные fixed-слои, которые могли ловить колесо */
body::before,
body::after,
main::before,
.hero::before,
.hero::after{
  display: none !important;
  pointer-events: none !important;
}

/* отключаем sticky CTA полностью */
.mobile-sticky-cta{
  display: none !important;
  pointer-events: none !important;
}

/* хедер оставляем липким, но гарантируем что он не ломает скролл */
.site-header{
  pointer-events: auto !important;
}

/* на всякий случай убираем любые блокирующие контейнеры */
main,
.section,
.hero,
.site-footer{
  overflow: visible !important;
}

/* ===== Hard scroll fix ===== */
html,
body{
  overflow-y: auto !important;
  overflow-x: hidden !important;
  height: auto !important;
  min-height: 100% !important;
  overscroll-behavior: auto !important;
}

body{
  position: relative !important;
}

/* отключаем все декоративные fixed-слои, которые могли ловить колесо */
body::before,
body::after,
main::before,
.hero::before,
.hero::after{
  display: none !important;
  pointer-events: none !important;
}

/* отключаем sticky CTA полностью */
.mobile-sticky-cta{
  display: none !important;
  pointer-events: none !important;
}

/* хедер оставляем липким, но гарантируем что он не ломает скролл */
.site-header{
  pointer-events: auto !important;
}

/* на всякий случай убираем любые блокирующие контейнеры */
main,
.section,
.hero,
.site-footer{
  overflow: visible !important;
}

/* ===== v2 compact sales layout ===== */
.hero-compact{
  padding-bottom:22px !important;
}

.section-head-tight{
  margin-bottom:22px !important;
}

.section-head-tight p{
  max-width:620px;
}

.pricing-first{
  padding-top:52px !important;
}

.cta-final{
  padding-top:56px !important;
}

.service-card span:last-child{
  font-size:19px;
}

.hero-copy .lead{
  max-width:580px;
}

@media (max-width:760px){
  .hero-compact{
    padding-top:42px !important;
    padding-bottom:12px !important;
  }

  .pricing-first{
    padding-top:38px !important;
  }

  .cta-final{
    padding-top:38px !important;
  }
}

/* ===== Service cards: text slide animation ===== */
.service-card{
  position:relative;
  overflow:hidden;
}

.service-card .service-icon{
  position:relative;
  z-index:2;
  transition:
    transform .35s ease,
    background .25s ease,
    border-color .25s ease,
    box-shadow .25s ease;
}

.service-card span:last-child{
  position:relative;
  z-index:2;
  display:inline-block;
  transform:translateX(0);
  opacity:.92;
  transition:
    transform .38s cubic-bezier(.22,.61,.36,1),
    opacity .28s ease,
    color .24s ease;
}

.service-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(255,138,61,.00), rgba(255,138,61,.06), rgba(255,138,61,.00));
  transform:translateX(-120%);
  transition:transform .55s ease;
}

.service-card::after{
  content:"";
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:3px;
  border-radius:3px;
  background:linear-gradient(180deg, #ffb070, #ff8a3d);
  box-shadow:0 0 18px rgba(255,138,61,.18);
  transform:scaleY(.25);
  transform-origin:center;
  opacity:.35;
  transition:transform .35s ease, opacity .25s ease;
}

.service-card:hover::before{
  transform:translateX(120%);
}

.service-card:hover::after{
  transform:scaleY(1);
  opacity:1;
}

.service-card:hover .service-icon{
  transform:translateX(4px) scale(1.06);
  box-shadow:0 10px 24px rgba(255,138,61,.16);
}

.service-card:hover span:last-child{
  transform:translateX(10px);
  opacity:1;
  color:#fff;
}

/* optional reveal stagger look */
.service-grid .service-card:nth-child(1) span:last-child{ transition-delay:.00s; }
.service-grid .service-card:nth-child(2) span:last-child{ transition-delay:.02s; }
.service-grid .service-card:nth-child(3) span:last-child{ transition-delay:.04s; }
.service-grid .service-card:nth-child(4) span:last-child{ transition-delay:.06s; }
.service-grid .service-card:nth-child(5) span:last-child{ transition-delay:.08s; }
.service-grid .service-card:nth-child(6) span:last-child{ transition-delay:.10s; }

/* ===== App cards: flip animation ===== */
.app-flip{
  perspective:1200px;
  min-height:160px;
  padding:0 !important;
  overflow:visible;
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
}

.app-flip::before{
  display:none !important;
}

.app-flip-inner{
  position:relative;
  display:block;
  width:100%;
  min-height:160px;
  transform-style:preserve-3d;
  transition:transform .72s cubic-bezier(.2,.7,.2,1);
}

.app-face{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:8px;
  padding:22px;
  border-radius:24px;
  background:linear-gradient(180deg, rgba(17,17,17,.94), rgba(10,10,10,.98));
  border:1px solid rgba(255,255,255,.06);
  box-shadow:var(--shadow-soft);
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
  overflow:hidden;
}

.app-face::before{
  content:"";
  position:absolute;
  inset:auto auto -30px -30px;
  width:90px;
  height:90px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(255,138,61,.14), transparent 65%);
  opacity:.75;
}

.app-face-front .app-title,
.app-face-front .app-desc,
.app-face-back .app-back-title,
.app-face-back .app-back-desc,
.app-face-back .app-back-cta{
  position:relative;
  z-index:1;
}

.app-face-front{
  transform:rotateY(0deg);
}

.app-face-back{
  transform:rotateY(180deg);
  justify-content:space-between;
  background:
    linear-gradient(180deg, rgba(24,16,12,.98), rgba(11,8,7,.98));
  border:1px solid rgba(255,138,61,.18);
  box-shadow:
    0 18px 40px rgba(0,0,0,.34),
    0 0 0 1px rgba(255,138,61,.06) inset;
}

.app-back-title{
  font-size:20px;
  font-weight:800;
  color:#fff;
}

.app-back-desc{
  color:#d4b29a;
  line-height:1.5;
}

.app-back-cta{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-weight:700;
  color:#ffb078;
}

.app-back-cta::after{
  content:"→";
  transition:transform .22s ease;
}

.app-flip:hover .app-flip-inner,
.app-flip.is-flipped .app-flip-inner,
.app-flip:focus-visible .app-flip-inner{
  transform:rotateY(180deg);
}

.app-flip:hover .app-back-cta::after,
.app-flip.is-flipped .app-back-cta::after{
  transform:translateX(3px);
}

/* hover only for non-flip app cards is already disabled by structure, keep clean */
.apps-grid .app-flip{
  transform:none !important;
}

.apps-grid .app-flip:hover{
  transform:none !important;
}

/* keyboard accessibility */
.app-flip:focus-visible{
  outline:none;
}

.app-flip:focus-visible .app-face{
  box-shadow:
    0 0 0 1px rgba(255,138,61,.10) inset,
    0 0 0 3px rgba(255,138,61,.16),
    var(--shadow-soft);
}

/* mobile tuning */
@media (max-width:760px){
  .service-card:hover span:last-child{
    transform:translateX(6px);
  }

  .app-flip,
  .app-flip-inner{
    min-height:148px;
  }

  .app-face{
    padding:20px;
  }
}

/* ===== Services: staggered entrance + autonomous motion ===== */
.service-card{
  position:relative;
  overflow:hidden;
  isolation:isolate;
}

.service-card .service-icon{
  position:relative;
  z-index:2;
  transition:
    transform .45s cubic-bezier(.22,.61,.36,1),
    background .25s ease,
    border-color .25s ease,
    box-shadow .25s ease,
    opacity .35s ease;
}

.service-card span:last-child{
  position:relative;
  z-index:2;
  display:inline-block;
  transform:translateX(0);
  opacity:.92;
  transition:
    transform .55s cubic-bezier(.22,.61,.36,1),
    opacity .35s ease,
    color .24s ease,
    text-shadow .25s ease;
}

.service-card::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  background:
    linear-gradient(90deg, rgba(255,138,61,.00), rgba(255,138,61,.06), rgba(255,138,61,.00));
  transform:translateX(-120%);
  opacity:0;
}

.service-card::after{
  content:"";
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:3px;
  border-radius:3px;
  background:linear-gradient(180deg, #ffb070, #ff8a3d);
  box-shadow:0 0 18px rgba(255,138,61,.18);
  transform:scaleY(.25);
  transform-origin:center;
  opacity:.28;
  transition:transform .4s ease, opacity .3s ease;
}

/* autonomous live state when revealed */
.service-card.is-live::before{
  animation:serviceSweep 3.8s ease-in-out infinite;
  opacity:1;
}

.service-card.is-live::after{
  transform:scaleY(1);
  opacity:.9;
}

.service-card.is-live .service-icon{
  animation:serviceIconFloat 3.2s ease-in-out infinite;
  box-shadow:0 10px 24px rgba(255,138,61,.12);
}

.service-card.is-live span:last-child{
  animation:serviceTextFloat 3.2s ease-in-out infinite;
  color:#fff;
  text-shadow:0 0 14px rgba(255,138,61,.08);
}

@keyframes serviceSweep{
  0%{
    transform:translateX(-120%);
    opacity:0;
  }
  15%{
    opacity:1;
  }
  45%{
    opacity:1;
  }
  100%{
    transform:translateX(120%);
    opacity:0;
  }
}

@keyframes serviceIconFloat{
  0%,100%{
    transform:translateX(0) translateY(0) scale(1);
  }
  50%{
    transform:translateX(4px) translateY(-1px) scale(1.05);
  }
}

@keyframes serviceTextFloat{
  0%,100%{
    transform:translateX(0);
    opacity:.94;
  }
  50%{
    transform:translateX(8px);
    opacity:1;
  }
}

/* stagger delays */
.service-grid .service-card:nth-child(1).is-live::before,
.service-grid .service-card:nth-child(1).is-live .service-icon,
.service-grid .service-card:nth-child(1).is-live span:last-child{ animation-delay:0s; }

.service-grid .service-card:nth-child(2).is-live::before,
.service-grid .service-card:nth-child(2).is-live .service-icon,
.service-grid .service-card:nth-child(2).is-live span:last-child{ animation-delay:.18s; }

.service-grid .service-card:nth-child(3).is-live::before,
.service-grid .service-card:nth-child(3).is-live .service-icon,
.service-grid .service-card:nth-child(3).is-live span:last-child{ animation-delay:.36s; }

.service-grid .service-card:nth-child(4).is-live::before,
.service-grid .service-card:nth-child(4).is-live .service-icon,
.service-grid .service-card:nth-child(4).is-live span:last-child{ animation-delay:.54s; }

.service-grid .service-card:nth-child(5).is-live::before,
.service-grid .service-card:nth-child(5).is-live .service-icon,
.service-grid .service-card:nth-child(5).is-live span:last-child{ animation-delay:.72s; }

.service-grid .service-card:nth-child(6).is-live::before,
.service-grid .service-card:nth-child(6).is-live .service-icon,
.service-grid .service-card:nth-child(6).is-live span:last-child{ animation-delay:.90s; }

/* optional subtle hover, but not required */
.service-card:hover .service-icon{
  transform:translateX(6px) scale(1.06);
}

.service-card:hover span:last-child{
  transform:translateX(10px);
}

/* ===== Apps: magnetic hover + richer 3D depth ===== */
.app-flip{
  perspective:1400px;
  transform-style:preserve-3d;
}

.app-flip-inner{
  position:relative;
  display:block;
  width:100%;
  min-height:160px;
  transform-style:preserve-3d;
  transition:
    transform .72s cubic-bezier(.2,.7,.2,1),
    filter .28s ease;
  will-change:transform;
}

.app-face{
  transform-style:preserve-3d;
}

.app-face-front::after{
  content:"";
  position:absolute;
  inset:auto -10% -32% auto;
  width:170px;
  height:170px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(255,138,61,.16), transparent 68%);
  filter:blur(6px);
  opacity:.75;
  transform:translateZ(20px);
  pointer-events:none;
}

.app-face-front .app-title{
  transform:translateZ(36px);
}

.app-face-front .app-desc{
  transform:translateZ(24px);
}

.app-face-back .app-back-title{
  transform:translateZ(34px);
}

.app-face-back .app-back-desc{
  transform:translateZ(22px);
}

.app-face-back .app-back-cta{
  transform:translateZ(30px);
}

.app-flip.is-magnetic .app-flip-inner{
  filter:drop-shadow(0 24px 34px rgba(0,0,0,.26));
}

.app-flip.is-magnetic .app-face-front,
.app-flip.is-magnetic .app-face-back{
  border-color:rgba(255,138,61,.18);
  box-shadow:
    0 18px 40px rgba(0,0,0,.34),
    0 0 0 1px rgba(255,138,61,.06) inset;
}

.app-flip.is-magnetic .app-face-front::after{
  opacity:1;
}

.app-flip:hover .app-back-cta::after,
.app-flip.is-flipped .app-back-cta::after{
  transform:translateX(3px);
}

/* smoother mobile */
@media (max-width:760px){
  .service-card.is-live::before{
    animation-duration:4.8s;
  }

  .service-card.is-live .service-icon,
  .service-card.is-live span:last-child{
    animation-duration:4s;
  }
}

/* ===== Premium header ===== */
.site-header{
  background:
    linear-gradient(180deg, rgba(6,6,6,.88), rgba(6,6,6,.74)) !important;
  border-bottom:1px solid rgba(255,255,255,.06) !important;
  box-shadow:
    0 10px 30px rgba(0,0,0,.16),
    0 1px 0 rgba(255,255,255,.02) inset;
}

.header-row{
  min-height:82px;
}

.brand{
  position:relative;
  letter-spacing:-.04em;
}

.brand::after{
  content:"";
  display:inline-block;
  width:8px;
  height:8px;
  margin-left:10px;
  border-radius:50%;
  vertical-align:middle;
  background:linear-gradient(180deg, #ffb070, #ff8a3d);
  box-shadow:0 0 16px rgba(255,138,61,.35);
}

.nav{
  gap:28px;
}

.nav a{
  font-size:15px;
  letter-spacing:.01em;
}

.header-actions .btn{
  min-height:46px;
  padding:0 20px;
}

.header-actions .btn-ghost{
  background:rgba(255,255,255,.02);
  backdrop-filter:blur(8px);
}

/* ===== Hero premium composition ===== */
.hero-compact{
  padding-top:82px !important;
  padding-bottom:30px !important;
}

.hero-grid{
  gap:36px !important;
  align-items:center;
}

.hero-copy{
  position:relative;
  z-index:2;
}

.eyebrow{
  min-height:38px;
  padding:0 14px;
  font-weight:700;
  box-shadow:0 8px 24px rgba(255,138,61,.08);
}

.hero h1{
  max-width:760px;
  font-size:clamp(44px, 7vw, 78px) !important;
  line-height:.94 !important;
  letter-spacing:-.055em !important;
}

.hero h1::after{
  margin-top:22px !important;
  height:5px !important;
  background:linear-gradient(90deg, rgba(255,138,61,1), rgba(255,194,133,.30)) !important;
  box-shadow:
    0 0 30px rgba(255,138,61,.22),
    0 0 10px rgba(255,138,61,.12);
}

.hero-copy .lead{
  max-width:620px !important;
  font-size:20px !important;
  color:#aaaaaa !important;
}

.hero-actions{
  gap:16px !important;
  margin-top:30px !important;
}

.hero-actions .btn-primary{
  min-width:220px;
}

.hero-actions .btn-secondary{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.09);
}

.hero-bullets{
  margin-top:2px;
  gap:20px !important;
}

.hero-bullets span{
  color:#d0d0d0;
  font-weight:500;
}

/* extra premium halo */
.hero-copy::before{
  content:"";
  position:absolute;
  left:-40px;
  top:-30px;
  width:220px;
  height:220px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(255,138,61,.10), transparent 70%);
  filter:blur(12px);
  pointer-events:none;
  z-index:-1;
}

/* ===== Hero card premium depth ===== */
.hero-card{
  min-height:500px !important;
}

.status-card{
  border-radius:34px !important;
}

.status-card .status-title{
  font-size:31px !important;
  line-height:1.02;
}

.status-card .status-text{
  font-size:16px;
}

.ip-summary{
  border-radius:20px !important;
}

.ip-value{
  font-size:28px !important;
}

.metric{
  min-height:108px;
  justify-content:center;
}

.metric-value{
  letter-spacing:-.03em;
}

/* ===== Trust bar richer ===== */
.trust-bar{
  padding-top:2px !important;
  padding-bottom:18px !important;
}

.trust-pill{
  min-height:56px !important;
  background:
    linear-gradient(180deg, rgba(20,20,20,.96), rgba(12,12,12,.98)) !important;
  border:1px solid rgba(255,255,255,.07) !important;
  color:#e2e2e2 !important;
  font-size:15px;
  letter-spacing:.01em;
}

/* ===== Pricing luxury polish ===== */
.pricing-first{
  padding-top:56px !important;
}

.pricing-grid{
  gap:20px !important;
}

.price-card,
.trial-card{
  border-radius:28px !important;
  padding:26px !important;
  background:
    linear-gradient(180deg, rgba(18,18,18,.98), rgba(10,10,10,.99)) !important;
  border:1px solid rgba(255,255,255,.06) !important;
}

.price-card h3,
.trial-card h3{
  font-size:27px !important;
  margin-bottom:12px !important;
}

.price{
  font-size:44px !important;
  line-height:1;
}

.price span{
  font-size:17px !important;
}

.price-card ul li,
.trial-card p{
  color:#a7a7a7;
}

.price-card .btn,
.trial-card .btn{
  min-height:50px;
}

.featured{
  transform:translateY(-4px);
  border:1px solid rgba(255,138,61,.22) !important;
  background:
    linear-gradient(180deg, rgba(28,18,12,.98), rgba(12,9,8,.99)) !important;
  box-shadow:
    0 24px 60px rgba(0,0,0,.34),
    0 0 0 1px rgba(255,138,61,.08) inset,
    0 0 60px rgba(255,138,61,.06);
}

.featured .price{
  color:#fff;
}

.featured .btn-primary{
  box-shadow:
    0 14px 34px rgba(255,138,61,.20),
    0 0 0 1px rgba(255,255,255,.02) inset;
}

.badge{
  top:18px !important;
  right:18px !important;
  min-height:30px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0 12px !important;
  font-size:11px !important;
  letter-spacing:.05em;
  text-transform:uppercase;
}

.plan-tab{
  min-height:44px !important;
  padding:0 18px !important;
}

.plan-tab.active{
  background:rgba(255,138,61,.12) !important;
  box-shadow:
    0 0 0 1px rgba(255,138,61,.08) inset,
    0 8px 20px rgba(255,138,61,.06);
}

/* ===== Services section a bit richer ===== */
.service-card{
  min-height:98px;
  border-radius:22px;
}

.service-icon{
  width:42px !important;
  height:42px !important;
  border-radius:13px !important;
}

/* ===== Devices section premium spacing ===== */
.apps-grid{
  gap:18px !important;
}

.app-face{
  border-radius:24px !important;
}

.app-back-cta{
  color:#ffbf90 !important;
}

/* ===== FAQ premium ===== */
.faq-item{
  border-radius:22px !important;
  background:
    linear-gradient(180deg, rgba(18,18,18,.96), rgba(10,10,10,.98)) !important;
}

.faq-item summary{
  font-size:20px !important;
  padding:24px 26px !important;
}

.faq-item p{
  padding:0 26px 24px !important;
  color:#a6a6a6 !important;
}

/* ===== Final CTA richer ===== */
.cta-final{
  padding-top:62px !important;
  padding-bottom:72px !important;
}

.cta-box{
  padding:34px !important;
  border-radius:30px !important;
  background:
    linear-gradient(180deg, rgba(22,16,12,.96), rgba(10,9,8,.98)) !important;
  border:1px solid rgba(255,138,61,.16) !important;
  box-shadow:
    0 28px 70px rgba(0,0,0,.34),
    0 0 0 1px rgba(255,138,61,.05) inset;
}

.cta-box h2{
  font-size:42px !important;
  line-height:.98;
  letter-spacing:-.04em;
}

.cta-box p{
  font-size:17px;
  color:#b0a39b !important;
}

.cta-actions .btn{
  min-width:200px;
}

/* ===== Footer luxury cleanup ===== */
.site-footer{
  padding-top:12px !important;
  padding-bottom:34px !important;
  background:
    linear-gradient(180deg, rgba(0,0,0,0), rgba(7,7,7,.82)) !important;
  border-top:1px solid rgba(255,255,255,.05) !important;
}

.footer-grid{
  gap:30px !important;
  padding-top:16px;
}

.footer-brand{
  font-size:30px !important;
}

.site-footer p{
  color:#9b9b9b !important;
}

.footer-grid h4{
  font-size:15px;
  letter-spacing:.03em;
  text-transform:uppercase;
  color:#f1f1f1 !important;
}

.footer-grid a{
  color:#9b9b9b !important;
}

.footer-grid a:hover{
  color:#fff !important;
}

.footer-bottom{
  margin-top:26px !important;
  padding-top:20px !important;
  color:#888 !important;
}

/* subtle top and bottom fade edges */
main{
  position:relative;
}

main::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-1px;
  height:120px;
  pointer-events:none;
  background:linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.22));
}

/* ===== Better mobile premium layout ===== */
@media (max-width:1100px){
  .hero-grid{
    gap:26px !important;
  }

  .cta-box h2{
    font-size:36px !important;
  }
}

@media (max-width:760px){
  .site-header{
    background:rgba(6,6,6,.92) !important;
  }

  .header-row{
    min-height:72px !important;
  }

  .hero h1{
    font-size:clamp(36px, 10vw, 52px) !important;
  }

  .hero-copy .lead{
    font-size:17px !important;
  }

  .hero-actions{
    gap:12px !important;
  }

  .status-card .status-title{
    font-size:26px !important;
  }

  .price{
    font-size:38px !important;
  }

  .featured{
    transform:none;
  }

  .faq-item summary{
    font-size:18px !important;
  }

  .cta-box{
    padding:26px !important;
  }

  .cta-box h2{
    font-size:32px !important;
  }

  .cta-actions .btn{
    min-width:0;
  }

  main::after{
    height:80px;
  }
}

/* ===== Hero cleanup ===== */
.hero-eyebrow-premium{
  display:inline-flex;
  align-items:center;
  gap:10px;
}

.eyebrow-dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:linear-gradient(180deg, #ffb070, #ff8a3d);
  box-shadow:0 0 14px rgba(255,138,61,.35);
}

.hero-mini-trust{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:6px;
}

.hero-mini-trust span{
  min-height:34px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0 12px;
  border-radius:999px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.07);
  color:#d7d7d7;
  font-size:14px;
  font-weight:600;
}

/* ===== Smaller mobile cards ===== */
@media (max-width:760px){
  .service-card{
    min-height:76px !important;
    padding:14px 16px !important;
    gap:12px !important;
    border-radius:18px !important;
  }

  .service-card span:last-child{
    font-size:16px !important;
  }

  .service-icon{
    width:34px !important;
    height:34px !important;
    border-radius:10px !important;
    font-size:16px !important;
  }

  .app-flip,
  .app-flip-inner{
    min-height:118px !important;
  }

  .app-face{
    padding:16px !important;
    border-radius:18px !important;
    gap:6px !important;
  }

  .app-title,
  .app-back-title{
    font-size:18px !important;
  }

  .app-desc,
  .app-back-desc{
    font-size:13px !important;
    line-height:1.35 !important;
  }

  .metric{
    min-height:86px !important;
    padding:14px !important;
  }

  .metric-value{
    font-size:22px !important;
  }

  .metric-label{
    font-size:13px !important;
  }

  .price-card,
  .trial-card{
    padding:20px !important;
    border-radius:22px !important;
  }

  .price-card h3,
  .trial-card h3{
    min-height:auto !important;
    font-size:23px !important;
  }

  .price{
    min-height:auto !important;
    font-size:34px !important;
  }

  .faq-item{
    border-radius:18px !important;
  }

  .faq-item summary{
    padding:18px 18px !important;
    font-size:17px !important;
  }

  .faq-item p{
    padding:0 18px 18px !important;
    font-size:14px !important;
    line-height:1.55 !important;
  }

  .cta-box{
    padding:22px !important;
    border-radius:22px !important;
  }
}

/* ===== App flip fix + device logos ===== */
.app-flip{
  perspective:1400px;
  cursor:pointer;
}

.app-flip-inner{
  position:relative;
  display:block;
  width:100%;
  min-height:160px;
  transform-style:preserve-3d;
  transition:transform .72s cubic-bezier(.2,.7,.2,1), filter .28s ease;
  will-change:transform;
}

.app-face{
  position:absolute;
  inset:0;
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
}

.app-face-front{
  transform:rotateY(0deg);
}

.app-face-back{
  transform:rotateY(180deg);
}

.app-flip:hover .app-flip-inner,
.app-flip:focus-visible .app-flip-inner,
.app-flip.is-flipped .app-flip-inner{
  transform:rotateY(180deg) !important;
}

.app-back-icons{
  display:flex;
  gap:10px;
  align-items:center;
  margin-bottom:4px;
}

.app-back-icons span{
  width:34px;
  height:34px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:10px;
  background:rgba(255,138,61,.08);
  border:1px solid rgba(255,138,61,.14);
  color:#ffbf90;
  font-size:18px;
  box-shadow:0 8px 18px rgba(255,138,61,.08);
}

/* ===== FAQ smoother ===== */
.faq-list{
  display:grid;
  gap:12px;
}

.faq-item{
  overflow:hidden;
  transition:
    border-color .24s ease,
    box-shadow .24s ease,
    background .24s ease,
    transform .24s ease;
}

.faq-item summary{
  position:relative;
  list-style:none;
  cursor:pointer;
  transition:background .24s ease, color .24s ease, padding .24s ease;
}

.faq-item summary::after{
  content:"+";
  position:absolute;
  right:22px;
  top:50%;
  transform:translateY(-50%) rotate(0deg);
  width:28px;
  height:28px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
  color:#ffb078;
  font-weight:800;
  transition:transform .28s ease, background .24s ease, border-color .24s ease;
}

.faq-item[open] summary::after{
  transform:translateY(-50%) rotate(45deg);
  background:rgba(255,138,61,.08);
  border-color:rgba(255,138,61,.14);
}

.faq-item:hover{
  transform:translateY(-1px);
}

.faq-item p{
  opacity:0;
  transform:translateY(-4px);
  transition:opacity .28s ease, transform .28s ease;
}

.faq-item[open] p{
  opacity:1;
  transform:translateY(0);
}

.faq-item summary::-webkit-details-marker{
  display:none;
}

/* keep service block lively without click dependence */
.service-card{
  cursor:default;
}

/* ===== Popular badge overlap fix ===== */
.price-card,
.trial-card{
  overflow:hidden;
}

.badge{
  top:14px !important;
  right:14px !important;
  z-index:3;
  max-width:calc(100% - 28px);
  white-space:nowrap;
}

.featured{
  padding-top:56px !important;
  position:relative;
}

/* ===== Featured card gentle shake / live accent ===== */
.featured{
  animation:featuredFloat 4.8s ease-in-out infinite;
  transform-origin:center center;
}

@keyframes featuredFloat{
  0%,100%{
    transform:translateY(-4px) rotate(0deg);
  }
  20%{
    transform:translateY(-5px) rotate(-0.35deg);
  }
  40%{
    transform:translateY(-3px) rotate(0.35deg);
  }
  60%{
    transform:translateY(-5px) rotate(-0.2deg);
  }
  80%{
    transform:translateY(-4px) rotate(0.2deg);
  }
}

/* keep hover stronger than idle animation */
.pricing-grid > .featured:hover{
  transform:translateY(-18px) scale(1.025) !important;
}

/* ===== Better back side for device cards ===== */
.app-back-chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:6px;
}

.app-back-chips span{
  min-height:28px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0 10px;
  border-radius:999px;
  background:rgba(255,138,61,.08);
  border:1px solid rgba(255,138,61,.14);
  color:#ffbf90;
  font-size:12px;
  font-weight:700;
  letter-spacing:.02em;
  box-shadow:0 8px 18px rgba(255,138,61,.06);
}

/* disable old icon row if still remains somewhere */
.app-back-icons{
  display:none !important;
}

/* ===== FAQ smoother / less jumpy ===== */
.faq-item{
  transform:none !important;
}

.faq-item:hover{
  transform:none !important;
}

.faq-item summary{
  padding-right:62px !important;
}

.faq-item p{
  will-change:opacity, transform;
}

.faq-item summary::after{
  transition:
    transform .34s cubic-bezier(.22,.61,.36,1),
    background .24s ease,
    border-color .24s ease,
    box-shadow .24s ease;
}

.faq-item[open] summary::after{
  box-shadow:0 8px 20px rgba(255,138,61,.08);
}

/* ===== Smaller mobile IP card ===== */
@media (max-width:760px){
  .hero-card{
    min-height:auto !important;
  }

  .status-card{
    padding:18px !important;
    border-radius:24px !important;
  }

  .status-top{
    margin-bottom:12px !important;
  }

  .status-card .status-title{
    font-size:22px !important;
    margin-bottom:8px !important;
  }

  .status-card .status-text{
    font-size:14px !important;
    line-height:1.5 !important;
    margin-bottom:12px !important;
  }

  .status-bar{
    margin-bottom:12px !important;
  }

  .ip-summary{
    padding:14px !important;
    margin-bottom:12px !important;
    border-radius:16px !important;
  }

  .ip-label{
    font-size:12px !important;
    margin-bottom:6px !important;
  }

  .ip-value{
    font-size:20px !important;
  }

  .ip-shield{
    width:42px !important;
    height:42px !important;
    flex:0 0 42px !important;
    border-radius:12px !important;
    font-size:20px !important;
  }

  .status-grid{
    gap:10px !important;
  }

  .metric{
    min-height:74px !important;
    padding:12px !important;
    border-radius:14px !important;
  }

  .metric-value{
    font-size:18px !important;
  }

  .metric-label{
    font-size:12px !important;
    margin-top:4px !important;
  }

  .ip-card-actions{
    margin-top:12px !important;
  }

  .ip-card-actions .btn{
    min-height:44px !important;
  }

  /* ===== Compact pricing on mobile ===== */
  .pricing-grid{
    grid-template-columns:1fr !important;
    gap:14px !important;
  }

  .price-card,
  .trial-card{
    padding:16px !important;
    border-radius:18px !important;
  }

  .price-card h3,
  .trial-card h3{
    font-size:20px !important;
    margin-bottom:8px !important;
  }

  .price{
    font-size:30px !important;
    margin-bottom:10px !important;
  }

  .price span{
    font-size:14px !important;
  }

  .price-card ul{
    margin-bottom:12px !important;
    line-height:1.5 !important;
    padding-left:16px !important;
  }

  .price-card ul li{
    font-size:14px !important;
  }

  .payment-box{
    margin-top:14px !important;
    padding-top:12px !important;
  }

  .payment-box h4{
    margin-bottom:8px !important;
    font-size:14px !important;
  }

  .payment-list{
    gap:8px !important;
  }

  .payment-list span{
    min-height:28px !important;
    padding:0 10px !important;
    font-size:12px !important;
  }

  .featured{
    padding-top:42px !important;
    animation:featuredFloatMobile 4.8s ease-in-out infinite;
  }

  .badge{
    top:10px !important;
    right:10px !important;
    font-size:10px !important;
    min-height:26px !important;
    padding:0 10px !important;
  }

  @keyframes featuredFloatMobile{
    0%,100%{
      transform:translateY(0) rotate(0deg);
    }
    50%{
      transform:translateY(-2px) rotate(.12deg);
    }
  }

  .pricing-grid > .featured:hover{
    transform:none !important;
  }

  /* ===== Smaller device cards mobile ===== */
  .app-flip,
  .app-flip-inner{
    min-height:104px !important;
  }

  .app-face{
    padding:14px !important;
    gap:4px !important;
  }

  .app-title,
  .app-back-title{
    font-size:16px !important;
  }

  .app-desc,
  .app-back-desc{
    font-size:12px !important;
    line-height:1.3 !important;
  }

  .app-back-chips{
    gap:6px !important;
    margin-bottom:4px !important;
  }

  .app-back-chips span{
    min-height:24px !important;
    padding:0 8px !important;
    font-size:11px !important;
  }

  .app-back-cta{
    font-size:13px !important;
  }
}

/* ===== Mobile polish ===== */
@media (max-width:760px){
  .hero-compact{
    padding-top:32px !important;
    padding-bottom:10px !important;
  }

  .hero-grid{
    gap:16px !important;
  }

  .eyebrow,
  .hero-eyebrow-premium{
    min-height:32px !important;
    padding:0 10px !important;
    font-size:12px !important;
    gap:8px !important;
  }

  .hero h1{
    font-size:clamp(30px, 8.4vw, 42px) !important;
    line-height:.96 !important;
    margin-bottom:10px !important;
  }

  .hero h1::after{
    margin-top:14px !important;
    width:84px !important;
    height:4px !important;
  }

  .hero-copy .lead{
    font-size:14px !important;
    line-height:1.45 !important;
    max-width:100% !important;
  }

  .hero-actions{
    margin-top:18px !important;
    gap:10px !important;
  }

  .hero-actions .btn{
    min-height:46px !important;
    font-size:14px !important;
  }

  .hero-mini-trust{
    margin-top:2px !important;
    gap:8px !important;
  }

  .hero-mini-trust span{
    min-height:28px !important;
    padding:0 10px !important;
    font-size:12px !important;
  }

  .trust-bar{
    padding-top:0 !important;
    padding-bottom:10px !important;
  }

  .trust-bar-grid{
    gap:8px !important;
  }

  .trust-pill{
    min-height:36px !important;
    padding:0 10px !important;
    font-size:12px !important;
    border-radius:999px !important;
  }

  .section{
    padding:42px 0 !important;
  }

  .section-head{
    margin-bottom:16px !important;
  }

  .section-head h2{
    font-size:28px !important;
    line-height:1.02 !important;
    margin-bottom:8px !important;
  }

  .section-head p{
    font-size:14px !important;
    line-height:1.45 !important;
  }

  .service-grid{
    gap:10px !important;
  }

  .service-card{
    min-height:68px !important;
    padding:12px 14px !important;
    gap:10px !important;
    border-radius:16px !important;
  }

  .service-card span:last-child{
    font-size:15px !important;
    line-height:1.2 !important;
  }

  .service-icon{
    width:30px !important;
    height:30px !important;
    font-size:14px !important;
    border-radius:9px !important;
  }

  .cta-final{
    padding-top:34px !important;
    padding-bottom:30px !important;
  }

  .cta-box{
    padding:18px !important;
    border-radius:18px !important;
    gap:14px !important;
  }

  .cta-box h2{
    font-size:24px !important;
    margin-bottom:6px !important;
  }

  .cta-box p{
    font-size:13px !important;
    line-height:1.4 !important;
  }

  .cta-actions{
    gap:8px !important;
  }

  .cta-actions .btn{
    min-height:42px !important;
    font-size:14px !important;
  }

  .mobile-sticky-cta{
    left:12px !important;
    right:12px !important;
    bottom:10px !important;
  }

  .mobile-sticky-cta .btn{
    min-height:46px !important;
    font-size:14px !important;
    border-radius:14px !important;
  }

  body{
    padding-bottom:72px !important;
  }
}

/* ===== FAQ smoother / no jump ===== */
.faq-list{
  display:grid;
  gap:10px;
}

.faq-item{
  overflow:hidden;
  transform:none !important;
  transition:
    border-color .24s ease,
    box-shadow .24s ease,
    background .24s ease;
}

.faq-item:hover{
  transform:none !important;
}

.faq-item summary{
  padding-right:62px !important;
  user-select:none;
}

.faq-item summary::after{
  content:"+";
  position:absolute;
  right:18px;
  top:50%;
  transform:translateY(-50%) rotate(0deg);
  width:28px;
  height:28px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
  color:#ffb078;
  font-weight:800;
  transition:
    transform .30s cubic-bezier(.22,.61,.36,1),
    background .24s ease,
    border-color .24s ease,
    box-shadow .24s ease;
}

.faq-item.is-open summary::after{
  transform:translateY(-50%) rotate(45deg);
  background:rgba(255,138,61,.08);
  border-color:rgba(255,138,61,.16);
  box-shadow:0 8px 20px rgba(255,138,61,.08);
}

.faq-item .faq-content{
  height:0;
  overflow:hidden;
  transition:height .34s cubic-bezier(.22,.61,.36,1);
}

.faq-item .faq-content-inner{
  padding:0 26px 22px;
}

.faq-item p{
  opacity:1 !important;
  transform:none !important;
  margin:0;
  color:#a6a6a6 !important;
}

/* mobile faq tighter */
@media (max-width:760px){
  .faq-item summary{
    padding:16px 48px 16px 16px !important;
    font-size:16px !important;
  }

  .faq-item summary::after{
    right:12px !important;
    width:24px !important;
    height:24px !important;
    border-radius:8px !important;
    font-size:14px !important;
  }

  .faq-item .faq-content-inner{
    padding:0 16px 16px !important;
  }

  .faq-item p{
    font-size:13px !important;
    line-height:1.5 !important;
  }
}

/* ===== Featured pricing behavior ===== */
.featured{
  transform:none !important;
  animation:featuredIdle 4.2s ease-in-out infinite !important;
  border:1px solid rgba(255,138,61,.14) !important;
}

@keyframes featuredIdle{
  0%,100%{
    transform:rotate(0deg);
    box-shadow:
      0 18px 40px rgba(0,0,0,.28),
      0 0 0 1px rgba(255,138,61,.04) inset;
  }
  50%{
    transform:rotate(.15deg);
    box-shadow:
      0 20px 44px rgba(0,0,0,.30),
      0 0 0 1px rgba(255,138,61,.06) inset,
      0 0 26px rgba(255,138,61,.05);
  }
}

.featured:hover{
  animation:featuredShakeHover .52s ease-in-out infinite !important;
  border-color:rgba(255,138,61,.34) !important;
  box-shadow:
    0 22px 48px rgba(0,0,0,.34),
    0 0 0 1px rgba(255,138,61,.10) inset,
    0 0 34px rgba(255,138,61,.10) !important;
}

@keyframes featuredShakeHover{
  0%,100%{
    transform:rotate(0deg) scale(1.01);
  }
  20%{
    transform:rotate(-0.55deg) scale(1.01);
  }
  40%{
    transform:rotate(0.55deg) scale(1.01);
  }
  60%{
    transform:rotate(-0.35deg) scale(1.01);
  }
  80%{
    transform:rotate(0.35deg) scale(1.01);
  }
}

.pricing-grid > .featured:hover{
  transform:none !important;
}

@media (max-width:760px){
  .featured{
    animation:featuredIdleMobile 4.2s ease-in-out infinite !important;
  }

  @keyframes featuredIdleMobile{
    0%,100%{
      transform:rotate(0deg);
    }
    50%{
      transform:rotate(.08deg);
    }
  }

  .featured:hover{
    animation:none !important;
    border-color:rgba(255,138,61,.18) !important;
  }
}

/* ===== Premium nav hover ===== */
.nav a{
  position:relative;
  overflow:visible;
  transition:color .28s ease, text-shadow .28s ease;
}

.nav a::before{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  width:0;
  height:34px;
  border-radius:999px;
  transform:translate(-50%,-50%);
  background:radial-gradient(circle, rgba(255,138,61,.16), rgba(255,138,61,.05) 55%, transparent 75%);
  opacity:0;
  transition:width .28s ease, opacity .28s ease;
  z-index:-1;
}

.nav a::after{
  background:linear-gradient(90deg, #ffb070, #ff8a3d, #ffd5b0) !important;
  height:2px !important;
  box-shadow:0 0 12px rgba(255,138,61,.22);
}

.nav a:hover{
  color:#fff !important;
  text-shadow:0 0 10px rgba(255,138,61,.16);
}

.nav a:hover::before{
  width:110%;
  opacity:1;
}

.nav a.is-active{
  color:#fff !important;
  text-shadow:0 0 10px rgba(255,138,61,.16);
}

.nav a.is-active::before{
  width:110%;
  opacity:.85;
}

/* ===== Hero line richer ===== */
.hero h1::after{
  width:220px !important;
  height:6px !important;
  border-radius:999px !important;
  background:
    linear-gradient(90deg,
      rgba(255,138,61,0) 0%,
      rgba(255,138,61,.95) 14%,
      rgba(255,205,160,.95) 48%,
      rgba(255,138,61,.95) 78%,
      rgba(255,138,61,0) 100%) !important;
  background-size:200% 100% !important;
  box-shadow:
    0 0 24px rgba(255,138,61,.24),
    0 0 40px rgba(255,138,61,.10) !important;
  animation:heroLineFlow 3.2s linear infinite, titleLinePulse 3.6s ease-in-out infinite !important;
}

@keyframes heroLineFlow{
  0%{ background-position:200% 50%; }
  100%{ background-position:0% 50%; }
}

/* ===== Service cards become premium flip ===== */
.service-flip-grid{
  gap:18px !important;
}

.service-flip{
  perspective:1200px;
  min-height:110px;
  padding:0 !important;
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
  overflow:visible !important;
  cursor:pointer;
}

.service-flip::before,
.service-flip::after{
  display:none !important;
}

.service-flip-inner{
  position:relative;
  min-height:110px;
  width:100%;
  transform-style:preserve-3d;
  transition:transform .72s cubic-bezier(.2,.7,.2,1), filter .28s ease;
  will-change:transform;
}

.service-face{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:14px;
  padding:22px;
  border-radius:22px;
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
  border:1px solid rgba(255,255,255,.06);
  box-shadow:var(--shadow-soft);
  overflow:hidden;
}

.service-face::before{
  content:"";
  position:absolute;
  inset:auto auto -36px -36px;
  width:110px;
  height:110px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(255,138,61,.14), transparent 68%);
  opacity:.85;
}

.service-front{
  background:linear-gradient(180deg, rgba(17,17,17,.94), rgba(10,10,10,.98));
  transform:rotateY(0deg);
}

.service-back{
  background:linear-gradient(180deg, rgba(28,18,12,.98), rgba(11,8,7,.98));
  border:1px solid rgba(255,138,61,.18);
  transform:rotateY(180deg);
  justify-content:center;
  flex-direction:column;
  align-items:flex-start;
  gap:8px;
}

.service-title,
.service-back-title,
.service-back-text,
.service-icon{
  position:relative;
  z-index:1;
}

.service-title{
  font-size:20px;
  font-weight:800;
  color:#fff;
}

.service-back-title{
  font-size:18px;
  font-weight:800;
  color:#ffcfab;
}

.service-back-text{
  color:#f3e2d3;
  line-height:1.45;
}

.service-flip:hover .service-flip-inner,
.service-flip.is-flipped .service-flip-inner{
  transform:rotateY(180deg);
  filter:drop-shadow(0 20px 34px rgba(0,0,0,.22));
}

/* ===== Apps become compact and calm ===== */
.apps-wrap{
  position:relative;
}

.apps-grid-compact{
  position:relative;
  gap:14px !important;
}

.app-plain{
  min-height:98px !important;
  padding:16px 18px !important;
  border-radius:18px !important;
  background:linear-gradient(180deg, rgba(17,17,17,.92), rgba(11,11,11,.97)) !important;
  border:1px solid rgba(255,255,255,.05) !important;
  box-shadow:0 10px 24px rgba(0,0,0,.16) !important;
  transition:
    transform .24s ease,
    border-color .24s ease,
    box-shadow .24s ease,
    background .24s ease;
}

.app-plain::before{
  display:none !important;
}

.app-plain:hover{
  transform:translateY(-2px);
  border-color:rgba(255,255,255,.08) !important;
  box-shadow:0 14px 30px rgba(0,0,0,.22) !important;
}

.app-plain .app-title{
  font-size:18px !important;
  font-weight:800;
}

.app-plain .app-desc{
  font-size:13px !important;
  line-height:1.4;
  color:#9f9f9f !important;
}

/* hide old flip visuals if any remain */
.app-flip,
.app-flip-inner,
.app-face,
.app-back-chips,
.app-back-title,
.app-back-desc,
.app-back-cta{
  all:unset;
}

.apps-grid .app-card{
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:6px;
}

/* ===== Ghost jumper ===== */
.apps-ghost{
  position:absolute;
  top:88px;
  left:0;
  width:64px;
  height:64px;
  pointer-events:none;
  z-index:5;
  transform:translate3d(0,0,0);
  transition:transform .44s cubic-bezier(.22,.61,.36,1), opacity .24s ease;
  opacity:.92;
}

.ghost-body{
  position:relative;
  width:52px;
  height:52px;
  margin:6px auto 0;
  border-radius:26px 26px 16px 16px;
  background:linear-gradient(180deg, rgba(255,245,238,.98), rgba(255,220,198,.98));
  box-shadow:
    0 12px 24px rgba(255,138,61,.16),
    0 0 0 1px rgba(255,138,61,.08) inset;
}

.ghost-body::before,
.ghost-body::after{
  content:"";
  position:absolute;
  bottom:-5px;
  width:14px;
  height:14px;
  background:inherit;
  border-radius:50%;
}

.ghost-body::before{ left:4px; }
.ghost-body::after{ right:4px; }

.ghost-eyes{
  position:absolute;
  top:18px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  gap:10px;
}

.ghost-eyes span{
  width:6px;
  height:8px;
  border-radius:50%;
  background:#2f2017;
}

.apps-ghost.is-hopping{
  animation:ghostHop .44s ease;
}

@keyframes ghostHop{
  0%{ transform:translate3d(var(--ghost-x,0), var(--ghost-y,0),0) scale(1); }
  35%{ transform:translate3d(var(--ghost-x,0), calc(var(--ghost-y,0) - 18px),0) scale(1.05); }
  100%{ transform:translate3d(var(--ghost-x,0), var(--ghost-y,0),0) scale(1); }
}

/* ===== Pricing premium interaction ===== */
.pricing-grid:hover > .price-card:not(.featured),
.pricing-grid:hover > .trial-card{
  transform:translateY(8px);
  transition:transform .28s ease, opacity .28s ease;
}

.featured{
  animation:none !important;
  transform:none !important;
  transition:
    transform .18s ease,
    border-color .18s ease,
    box-shadow .18s ease,
    filter .18s ease !important;
}

.featured:hover{
  animation:featuredShakeStrong .34s linear infinite !important;
  border-color:#ff8a3d !important;
  box-shadow:
    0 26px 54px rgba(0,0,0,.34),
    0 0 0 1px rgba(255,138,61,.16) inset,
    0 0 46px rgba(255,138,61,.22) !important;
  filter:brightness(1.04);
}

@keyframes featuredShakeStrong{
  0%,100%{ transform:rotate(0deg) scale(1.01); }
  20%{ transform:rotate(-0.9deg) scale(1.012); }
  40%{ transform:rotate(0.9deg) scale(1.012); }
  60%{ transform:rotate(-0.65deg) scale(1.012); }
  80%{ transform:rotate(0.65deg) scale(1.012); }
}

/* ===== FAQ stays smooth and stable ===== */
.faq-item{
  transform:none !important;
}

.faq-item:hover{
  transform:none !important;
}

/* ===== Mobile ===== */
@media (max-width:760px){
  .hero h1::after{
    width:130px !important;
    height:5px !important;
  }

  .service-flip{
    min-height:88px !important;
  }

  .service-flip-inner{
    min-height:88px !important;
  }

  .service-face{
    min-height:88px !important;
    padding:16px !important;
    border-radius:16px !important;
    gap:10px !important;
  }

  .service-title{
    font-size:16px !important;
  }

  .service-back-title{
    font-size:15px !important;
  }

  .service-back-text{
    font-size:13px !important;
    line-height:1.3 !important;
  }

  .apps-ghost{
    display:none;
  }

  .apps-grid-compact{
    gap:10px !important;
  }

  .app-plain{
    min-height:78px !important;
    padding:14px !important;
    border-radius:14px !important;
  }

  .app-plain .app-title{
    font-size:16px !important;
  }

  .app-plain .app-desc{
    font-size:12px !important;
  }

  .pricing-grid:hover > .price-card:not(.featured),
  .pricing-grid:hover > .trial-card{
    transform:none !important;
  }

  .featured:hover{
    animation:none !important;
    filter:none !important;
  }
}

/* ===== Animated VPN background ===== */
body{
  background:
    radial-gradient(circle at 15% 18%, rgba(255,138,61,.10), transparent 22%),
    radial-gradient(circle at 82% 14%, rgba(255,138,61,.06), transparent 18%),
    radial-gradient(circle at 50% 78%, rgba(255,120,40,.05), transparent 22%),
    linear-gradient(180deg, #020202 0%, #070707 100%) !important;
  background-size:130% 130%, 140% 140%, 150% 150%, 100% 100% !important;
  animation:vpnBgShift 20s ease-in-out infinite !important;
}

@keyframes vpnBgShift{
  0%{ background-position:14% 18%, 82% 14%, 50% 78%, 0 0; }
  25%{ background-position:18% 20%, 78% 18%, 52% 74%, 0 0; }
  50%{ background-position:12% 24%, 84% 12%, 48% 82%, 0 0; }
  75%{ background-position:16% 16%, 80% 20%, 54% 76%, 0 0; }
  100%{ background-position:14% 18%, 82% 14%, 50% 78%, 0 0; }
}

/* ===== Hero premium animation ===== */
.hero h1{
  position:relative;
}

.hero-rotator-wrap{
  display:block;
  min-height:1.1em;
  margin-top:10px;
}

.hero-rotator{
  display:inline-block;
  color:#ffbf90;
  text-shadow:0 0 18px rgba(255,138,61,.18);
  transform-origin:left center;
  transition:opacity .28s ease, transform .28s ease;
}

.hero-signal-row{
  display:flex;
  align-items:flex-end;
  gap:8px;
  height:34px;
  margin:12px 0 4px;
}

.hero-signal-row span{
  width:10px;
  border-radius:999px;
  background:linear-gradient(180deg, rgba(255,194,150,.85), rgba(255,138,61,.95));
  box-shadow:0 0 16px rgba(255,138,61,.16);
  animation:heroSignal 1.6s ease-in-out infinite;
}

.hero-signal-row span:nth-child(1){ height:10px; animation-delay:0s; }
.hero-signal-row span:nth-child(2){ height:20px; animation-delay:.15s; }
.hero-signal-row span:nth-child(3){ height:32px; animation-delay:.3s; }
.hero-signal-row span:nth-child(4){ height:18px; animation-delay:.45s; }
.hero-signal-row span:nth-child(5){ height:26px; animation-delay:.6s; }

@keyframes heroSignal{
  0%,100%{ transform:scaleY(.82); opacity:.72; }
  50%{ transform:scaleY(1.08); opacity:1; }
}

/* ===== Premium nav hover ===== */
.nav a{
  position:relative;
  transition:color .28s ease, text-shadow .28s ease;
}

.nav a::before{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  width:0;
  height:34px;
  border-radius:999px;
  transform:translate(-50%,-50%);
  background:radial-gradient(circle, rgba(255,138,61,.16), rgba(255,138,61,.05) 55%, transparent 75%);
  opacity:0;
  transition:width .28s ease, opacity .28s ease;
  z-index:-1;
}

.nav a:hover{
  color:#fff !important;
  text-shadow:0 0 10px rgba(255,138,61,.16);
}

.nav a:hover::before,
.nav a.is-active::before{
  width:110%;
  opacity:1;
}

/* ===== Pricing premium ===== */
.pricing-grid-premium{
  display:grid !important;
  grid-template-columns:repeat(3,1fr) !important;
  gap:20px !important;
}

.pricing-grid-premium .price-card{
  overflow:hidden !important;
  min-height:100%;
  display:flex;
  flex-direction:column;
  padding:26px !important;
  border-radius:28px !important;
  background:linear-gradient(180deg, rgba(18,18,18,.98), rgba(10,10,10,.99)) !important;
  border:1px solid rgba(255,255,255,.06) !important;
  box-shadow:0 18px 40px rgba(0,0,0,.20) !important;
  transition:
    transform .16s ease,
    border-color .16s ease,
    box-shadow .16s ease,
    filter .16s ease !important;
}

.pricing-grid-premium .price-card-top{
  margin-bottom:10px;
}

.pricing-grid-premium .price-card h3{
  font-size:27px !important;
  margin:0 0 10px !important;
}

.pricing-grid-premium .price{
  font-size:44px !important;
  line-height:1;
  margin:0 0 6px !important;
}

.pricing-grid-premium .price-card ul{
  flex:1;
}

.pricing-grid-premium .price-card:hover{
  animation:tariffShake .34s linear infinite;
  border-color:rgba(255,138,61,.34) !important;
  box-shadow:
    0 22px 48px rgba(0,0,0,.34),
    0 0 0 1px rgba(255,138,61,.10) inset,
    0 0 34px rgba(255,138,61,.10) !important;
  filter:brightness(1.04);
}

@keyframes tariffShake{
  0%,100%{ transform:rotate(0deg) scale(1.01); }
  20%{ transform:rotate(-0.8deg) scale(1.01); }
  40%{ transform:rotate(0.8deg) scale(1.01); }
  60%{ transform:rotate(-0.55deg) scale(1.01); }
  80%{ transform:rotate(0.55deg) scale(1.01); }
}

.pricing-grid-premium .featured{
  border-color:rgba(255,138,61,.18) !important;
}

.badge{
  top:14px !important;
  right:14px !important;
  z-index:3;
  max-width:calc(100% - 28px);
  white-space:nowrap;
  min-height:28px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0 12px !important;
  font-size:11px !important;
  letter-spacing:.05em;
  text-transform:uppercase;
}

/* ===== Service flip cards solid back ===== */
.service-flip-grid{
  display:grid !important;
  grid-template-columns:repeat(3,1fr) !important;
  gap:16px !important;
}

.service-flip{
  perspective:1200px !important;
  min-height:108px !important;
  padding:0 !important;
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
  overflow:visible !important;
  cursor:pointer !important;
}

.service-flip .service-flip-inner{
  position:relative !important;
  display:block !important;
  width:100% !important;
  min-height:108px !important;
  transform-style:preserve-3d !important;
  transition:transform .72s cubic-bezier(.2,.7,.2,1) !important;
}

.service-flip .service-face{
  position:absolute !important;
  inset:0 !important;
  display:flex !important;
  align-items:center !important;
  gap:14px !important;
  padding:20px !important;
  border-radius:20px !important;
  backface-visibility:hidden !important;
  -webkit-backface-visibility:hidden !important;
  border:1px solid rgba(255,255,255,.06) !important;
  box-shadow:0 10px 24px rgba(0,0,0,.16) !important;
  overflow:hidden !important;
  opacity:1 !important;
}

.service-flip .service-front{
  background:linear-gradient(180deg, rgba(17,17,17,1), rgba(10,10,10,1)) !important;
  transform:rotateY(0deg) !important;
}

.service-flip .service-back{
  background:linear-gradient(180deg, rgba(28,18,12,1), rgba(11,8,7,1)) !important;
  border:1px solid rgba(255,138,61,.18) !important;
  transform:rotateY(180deg) !important;
  flex-direction:column !important;
  align-items:flex-start !important;
  justify-content:center !important;
  gap:8px !important;
}

.service-flip .service-title{
  font-size:20px !important;
  font-weight:800 !important;
  color:#fff !important;
}

.service-flip .service-back-title{
  font-size:18px !important;
  font-weight:800 !important;
  color:#ffcfab !important;
}

.service-flip .service-back-text{
  color:#f3e2d3 !important;
  line-height:1.4 !important;
  opacity:1 !important;
}

.service-flip.is-flipped .service-flip-inner,
.service-flip:hover .service-flip-inner{
  transform:rotateY(180deg) !important;
}

/* ===== Apps clean hover ===== */
.apps-grid-compact{
  display:grid !important;
  grid-template-columns:repeat(3,1fr) !important;
  gap:14px !important;
}

.apps-grid-compact .app-card.app-plain{
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
  gap:6px !important;
  min-height:92px !important;
  padding:16px 18px !important;
  border-radius:18px !important;
  background:linear-gradient(180deg, rgba(17,17,17,.92), rgba(11,11,11,.97)) !important;
  border:1px solid rgba(255,255,255,.05) !important;
  box-shadow:0 10px 24px rgba(0,0,0,.16) !important;
  transition:
    transform .24s ease,
    border-color .24s ease,
    box-shadow .24s ease,
    background .24s ease !important;
}

.apps-grid-compact .app-card.app-plain:hover{
  transform:translateY(-2px) !important;
  border-color:rgba(255,138,61,.26) !important;
  box-shadow:
    0 16px 32px rgba(0,0,0,.22),
    0 0 0 1px rgba(255,138,61,.08) inset,
    0 0 22px rgba(255,138,61,.06) !important;
  background:linear-gradient(180deg, rgba(24,16,12,.96), rgba(12,10,9,.98)) !important;
}

.apps-grid-compact .app-title{
  display:block !important;
  font-size:18px !important;
  font-weight:800 !important;
  color:#fff !important;
}

.apps-grid-compact .app-desc{
  display:block !important;
  font-size:13px !important;
  line-height:1.4 !important;
  color:#9f9f9f !important;
}

/* ===== Mobile ===== */
@media (max-width:760px){
  .hero-rotator-wrap{
    min-height:1em;
    margin-top:8px;
  }

  .hero-signal-row{
    height:24px;
    gap:6px;
    margin:8px 0 2px;
  }

  .hero-signal-row span{
    width:8px;
  }

  .pricing-grid-premium{
    grid-template-columns:1fr !important;
    gap:14px !important;
  }

  .pricing-grid-premium .price-card{
    padding:16px !important;
    border-radius:18px !important;
  }

  .pricing-grid-premium .price-card h3{
    font-size:20px !important;
  }

  .pricing-grid-premium .price{
    font-size:30px !important;
  }

  .badge{
    top:10px !important;
    right:10px !important;
    font-size:10px !important;
    min-height:24px !important;
  }

  .service-flip-grid{
    grid-template-columns:1fr !important;
    gap:10px !important;
  }

  .service-flip,
  .service-flip .service-flip-inner{
    min-height:84px !important;
  }

  .service-flip .service-face{
    min-height:84px !important;
    padding:14px !important;
    border-radius:16px !important;
    gap:10px !important;
  }

  .service-flip .service-title{
    font-size:16px !important;
  }

  .service-flip .service-back-title{
    font-size:15px !important;
  }

  .service-flip .service-back-text{
    font-size:13px !important;
  }

  .apps-grid-compact{
    grid-template-columns:1fr !important;
    gap:10px !important;
  }

  .apps-grid-compact .app-card.app-plain{
    min-height:78px !important;
    padding:14px !important;
    border-radius:14px !important;
  }

  .apps-grid-compact .app-title{
    font-size:16px !important;
  }

  .apps-grid-compact .app-desc{
    font-size:12px !important;
  }
}
