

:root {
  --bg:         #030610;
  --bg2:        #050918;
  --glass:      rgba(255,255,255,.045);
  --glass-md:   rgba(255,255,255,.075);
  --glass-hi:   rgba(255,255,255,.11);
  --glass-dark: rgba(4,6,20,.8);
  --gborder:    rgba(255,255,255,.10);
  --gborder-hi: rgba(255,255,255,.20);
  --primary:    var(--brand-primary);
  --primary2:   var(--brand-primary-h);
  --accent:     var(--brand-accent);
  --secondary:  var(--brand-secondary);
  --purple:     var(--brand-accent);
  --green:      var(--brand-success);
  --text:       #eef2ff;
  --muted:      #6b7a99;
  --nav-h:      80px;
  --glow-p:     rgba(var(--brand-primary-rgb), 0.4);
  --glow-a:     rgba(var(--brand-accent-rgb), 0.4);
  --glow-s:     rgba(var(--brand-secondary-rgb), 0.28);
  --tr:         .28s cubic-bezier(.4,0,.2,1);
  --tr-bounce:  .45s cubic-bezier(.34,1.56,.64,1);
  --radius:     20px;
  --radius-lg:  28px;
  --radius-xl:  36px;
}

body.light {
  --bg:         #f0f2ff;
  --bg2:        #e4e8f8;
  --glass:      rgba(0,0,0,.04);
  --glass-md:   rgba(0,0,0,.06);
  --glass-hi:   rgba(0,0,0,.09);
  --glass-dark: rgba(255,255,255,.92);
  --gborder:    rgba(0,0,0,.09);
  --gborder-hi: rgba(0,0,0,.18);
  --text:       #111827;
  --muted:      #4b5563;
  --glow-p:     rgba(var(--brand-primary-rgb), 0.4);
  --glow-a:     rgba(var(--brand-secondary-rgb), 0.4);

  background-color: #f0f2ff !important;
  color: #111827 !important;
}

body.light .gradient-cycle { color: transparent !important; }

body:not(.light) {
  background-color: #030610 !important;
  color: #eef2ff;
}

body.light .nav-logo,
body.light .nav-links a { color: #111827; }
body.light .nav-links a:hover { color: var(--primary); }

.mobile-user-card {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 16px; margin: 6px 0 8px;
  border-radius: 14px;
  background: rgba(var(--brand-primary-rgb), 0.1);
  border: 1px solid rgba(var(--brand-primary-rgb), 0.2);
}
.mobile-user-card img {
  width: 42px; height: 42px; border-radius: 50%;
  object-fit: cover;
  border: 2px solid rgba(var(--brand-primary-rgb), 0.2);
}
.mobile-user-card > div { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.mobile-user-card strong {
  font-size: .92rem; font-weight: 900; color: #fff;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.mobile-user-card small {
  font-size: .72rem; color: rgba(255,255,255,.6);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.mobile-user-link {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 18px; border-radius: 14px;
  font-size: .92rem; font-weight: 700;
  color: rgba(255,255,255,.85);
  background: transparent; border: none;
  text-align: start; width: 100%;
  transition: all .18s ease; cursor: pointer;
}
.mobile-user-link i {
  width: 20px; text-align: center; font-size: 15px;
  color: rgba(255,255,255,.55);
}
.mobile-user-link:hover {
  background: rgba(var(--brand-primary-rgb), 0.1);
  color: #fff;
  padding-inline-start: 22px;
}
.mobile-user-link:hover i { color: var(--primary2); }
.mobile-user-logout { color: #fca5a5 !important; }
.mobile-user-logout i { color: #f87171 !important; }
.mobile-user-logout:hover { background: rgba(var(--brand-danger-rgb), 0.1) !important; color: #fff !important; }
.mobile-user-logout:hover i { color: var(--brand-danger) !important; }

body.light .mobile-user-card {
  background: rgba(var(--brand-primary-rgb), 0.1);
  border-color: rgba(var(--brand-primary-rgb), 0.2);
}
body.light .mobile-user-card strong { color: #111827; }
body.light .mobile-user-card small { color: #6b7280; }
body.light .mobile-user-link { color: #374151; }
body.light .mobile-user-link i { color: #6b7280; }
body.light .mobile-user-link:hover { background: rgba(var(--brand-primary-rgb), 0.1); color: #111827; }
body.light .mobile-user-link:hover i { color: var(--primary); }
body.light .mobile-user-logout { color: var(--brand-danger) !important; }
body.light .mobile-user-logout i { color: var(--brand-danger) !important; }
body.light .mobile-user-logout:hover { background: rgba(var(--brand-danger-rgb), 0.1) !important; }
body.light .btn-login { color: #1f2937; border-color: rgba(0,0,0,.12); }
body.light .btn-login:hover { background: rgba(var(--brand-primary-rgb), 0.1); }

body.light .stat strong,
body.light .h1, body.light h1, body.light h2, body.light h3 { color: #111827; }
body.light .stat span,
body.light .hero-sub { color: #4b5563; }

body.light #bgCanvas   { opacity: .12 !important; }
body.light .bg-orb     { opacity: 0   !important; transition: opacity .5s ease; }
body.light .grid-overlay { opacity: .18 !important; }

body.light .reel-card,
body.light .design-card,
body.light .plan-card,
body.light .faq-item {
  background: rgba(255,255,255,.85) !important;
  border-color: rgba(var(--brand-primary-rgb), 0.2) !important;
  box-shadow: 0 4px 20px rgba(var(--brand-primary-rgb), 0.3) !important;
  color: #111827;
}
body.light .reel-card:hover,
body.light .design-card:hover,
body.light .plan-card:hover {
  background: rgba(255,255,255,.97) !important;
  border-color: rgba(var(--brand-primary-rgb), 0.2) !important;
  box-shadow: 0 12px 36px rgba(var(--brand-primary-rgb), 0.3) !important;
}
body.light .plan-card.featured {
  background: rgba(var(--brand-primary-rgb), 0.1) !important;
  border-color: rgba(var(--brand-primary-rgb), 0.2) !important;
  box-shadow: 0 12px 40px rgba(var(--brand-primary-rgb), 0.3), 0 0 0 1px rgba(var(--brand-primary-rgb), 0.3) !important;
}

body.light .plan-card h3,
body.light .faq-q { color: #111827; }
body.light .plan-desc,
body.light .faq-a p,
body.light .plan-features li { color: #4b5563; }
body.light .price {
  background: linear-gradient(135deg, var(--brand-accent), var(--primary));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}

body.light .mobile-drawer {
  background: rgba(255,255,255,.95) !important;
  color: #111827;
}

body.light .hcard {
  background: rgba(255,255,255,.6) !important;
  border-color: rgba(0,0,0,.08) !important;
  box-shadow:
    0 32px 80px rgba(var(--brand-primary-rgb), 0.15),
    inset 0 1px 0 rgba(255,255,255,.6),
    inset 0 -1px 0 rgba(0,0,0,.03) !important;
}
body.light .hcard-header,
body.light .hcard-id,
body.light .hstep-info strong,
body.light .chat-bubble.ai,
body.light .chat-bubble.me { color: #111827 !important; text-shadow: none; }
body.light .hstep-info small { color: #4b5563 !important; }
body.light .hcard-id {
  background: rgba(var(--brand-primary-rgb), 0.1);
  border-color: rgba(var(--brand-primary-rgb), 0.2);
}
body.light .chat-bubble.ai { background: rgba(var(--brand-primary-rgb), 0.2); border-color: rgba(var(--brand-primary-rgb), 0.2); }
body.light .chat-bubble.me { background: rgba(var(--brand-secondary-rgb), 0.2); border-color: rgba(var(--brand-secondary-rgb), 0.2); }
body.light .chat-bubble.ai i { color: var(--primary); }

.btn-theme {
  width: 40px; height: 40px; border-radius: 12px;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  color: var(--brand-warning);
  font-size: 16px;
  cursor: pointer;
  transition: all var(--tr);
}
.btn-theme:hover {
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.22);
  transform: rotate(15deg);
}
body.light .btn-theme {
  background: rgba(var(--brand-primary-rgb), 0.1);
  border-color: rgba(var(--brand-primary-rgb), 0.2);
  color: var(--brand-primary);
}
body.light .btn-theme:hover {
  background: rgba(var(--brand-primary-rgb), 0.1);
  border-color: rgba(var(--brand-primary-rgb), 0.2);
}

@keyframes loaderFill    { to { width: 100%; } }
@keyframes orbFloat      { 0%{transform:translate(0,0)scale(1)} 50%{transform:translate(20px,-18px)scale(1.05)} 100%{transform:translate(-14px,12px)scale(.97)} }
@keyframes orbPulse      { 0%,100%{opacity:.65} 50%{opacity:1} }
@keyframes meshDrift     { 0%{background-position:0% 0%} 100%{background-position:100% 100%} }
@keyframes fadeUp        { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeDown      { from{opacity:0;transform:translateY(-16px)} to{opacity:1;transform:translateY(0)} }

@keyframes navIn         { from{opacity:0;transform:translateX(-50%) translateY(-16px)} to{opacity:1;transform:translateX(-50%) translateY(0)} }
@keyframes fadeLeft      { from{opacity:0;transform:translateX(28px)} to{opacity:1;transform:translateX(0)} }
@keyframes fadeRight     { from{opacity:0;transform:translateX(-28px)} to{opacity:1;transform:translateX(0)} }
@keyframes scaleIn       { from{opacity:0;transform:scale(.92)} to{opacity:1;transform:scale(1)} }
@keyframes floatY        { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-12px)} }
@keyframes floatRotate   { 0%,100%{transform:translateY(0) rotate(0deg)} 50%{transform:translateY(-8px) rotate(5deg)} }
@keyframes gradShift     { 0%{background-position:0% 50%} 50%{background-position:100% 50%} 100%{background-position:0% 50%} }
@keyframes glowPulse     { 0%,100%{box-shadow:0 0 0 0 rgba(var(--brand-primary-rgb), 0.3)} 50%{box-shadow:0 0 36px 10px rgba(var(--brand-primary-rgb), 0.3)} }
@keyframes ringRotate    { to{transform:rotate(360deg)} }
@keyframes dotOrbit      { to{transform:rotate(360deg) translateX(var(--r,110px)) rotate(-360deg)} }
@keyframes shimmerSweep  { 0%{left:-100%} 100%{left:200%} }
@keyframes badgePop      { 0%{opacity:0;transform:scale(.6) translateY(8px)} 65%{transform:scale(1.06) translateY(-2px)} 100%{opacity:1;transform:scale(1) translateY(0)} }
@keyframes borderGlow    { 0%,100%{border-color:rgba(var(--brand-primary-rgb), 0.2)} 50%{border-color:rgba(var(--brand-primary-rgb), 0.2)} }
@keyframes ripple        { 0%{transform:scale(1);opacity:.5} 100%{transform:scale(2.8);opacity:0} }
@keyframes cardAppear    { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:translateY(0)} }
@keyframes successPop    { from{transform:scale(0)} to{transform:scale(1)} }
@keyframes typewriterBlink { 50%{opacity:0} }
@keyframes lineGrow      { from{transform:scaleX(0)} to{transform:scaleX(1)} }
@keyframes hintBounce    { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(8px)} }

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
* { font-family:'Cairo',sans-serif; }
html {
  scroll-behavior: smooth;
  overflow-x: clip;
}
body {
  background-color: #030610;
  color: var(--text);
  min-height: 100vh;
  overflow-x: clip;
  transition: background-color .5s ease, color .4s ease;
}
a { color:inherit; text-decoration:none; }
img,video { display:block; max-width:100%; }
button { cursor:pointer; border:none; background:none; color:inherit; font:inherit; }
ul,ol { list-style:none; }

::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:linear-gradient(180deg,var(--primary),var(--accent)); border-radius:99px; }
::selection { background:rgba(var(--brand-primary-rgb), 0.1); color:#fff; }
:focus-visible { outline:2px solid var(--primary); outline-offset:3px; border-radius:4px; }

.scroll-bar {
  position:fixed; top:0; left:0;
  height:2px; width:0%;
  background:linear-gradient(90deg,var(--primary),var(--accent),var(--secondary));
  z-index:9999;
  transition:width .08s linear;
  box-shadow:0 0 8px rgba(var(--brand-primary-rgb), 0.3);
}

.loader {
  position:fixed; inset:0;
  background:var(--bg);
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  gap:32px; z-index:9000;
  transition:opacity .6s, visibility .6s;
}
.loader.hide { opacity:0; visibility:hidden; pointer-events:none; }
.loader-logo {
  font-size:clamp(2.2rem,5vw,3.8rem);
  font-weight:900; letter-spacing:.06em; color:var(--text);
  animation:fadeDown .5s ease;
}
.loader-logo span { color:var(--primary); }
.loader-track {
  width:240px; height:2px;
  background:rgba(255,255,255,.08);
  border-radius:99px; overflow:hidden;
}
.loader-fill {
  height:100%; width:0%;
  background:linear-gradient(90deg,var(--primary),var(--accent),var(--secondary));
  border-radius:99px;
  animation:loaderFill 1.4s ease forwards;
  box-shadow:0 0 10px rgba(var(--brand-primary-rgb), 0.3);
}

#bgCanvas {
  position:fixed; inset:0;
  pointer-events:none; z-index:0;
}

body::before {
  content:'';
  position:fixed; inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 20% 10%, rgba(var(--brand-primary-rgb), 0.35) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 80% 80%, rgba(var(--brand-accent-rgb,168,85,247),.10) 0%, transparent 55%),
    radial-gradient(ellipse 50% 40% at 60% 30%, rgba(var(--brand-secondary-rgb), 0.35) 0%, transparent 50%),
    radial-gradient(ellipse 70% 60% at 10% 90%, rgba(var(--brand-secondary-rgb,236,72,153),.07) 0%, transparent 55%);
  pointer-events:none; z-index:0;
}

.bg-orb {
  position:fixed; border-radius:50%;

  filter:blur(70px); pointer-events:none; z-index:0;
  will-change: transform;
  animation:orbFloat 16s ease-in-out infinite, orbPulse 10s ease-in-out infinite;
}
.bg-orb.o1 { width:580px; height:580px; background:radial-gradient(circle,rgba(var(--brand-primary-rgb), 0.1) 0%,transparent 70%); top:-200px; right:-180px; animation-duration:13s,12s; }
.bg-orb.o2 { width:480px; height:480px; background:radial-gradient(circle,rgba(var(--brand-secondary-rgb), 0.1) 0%,transparent 70%); bottom:5%; left:-160px; animation-duration:17s,15s; animation-delay:-6s,-4s; }
.bg-orb.o3 { width:400px; height:400px; background:radial-gradient(circle,rgba(var(--brand-accent-rgb,168,85,247),.13) 0%,transparent 70%); top:45%; right:15%; animation-duration:21s,18s; animation-delay:-10s,-8s; }
.bg-orb.o4 { width:620px; height:620px; background:radial-gradient(circle,rgba(var(--brand-secondary-rgb,236,72,153),.08) 0%,transparent 70%); bottom:-250px; right:5%; animation-duration:25s,22s; animation-delay:-14s,-11s; }

@media (max-width: 768px) {
  .bg-orb { filter: blur(45px); }
  .bg-orb.o3, .bg-orb.o4 { display: none; }
}

.grid-overlay {
  position:fixed; inset:0; pointer-events:none; z-index:0;
  background-image:
    linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px);
  background-size:72px 72px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%, black 30%, transparent 100%);
}

.nav {
  position:fixed;

  top:14px;
  left:50%;
  transform:translateX(-50%);
  width:calc(100% - 28px); max-width:1220px;
  height:62px;
  display:flex; align-items:center;
  padding:0 20px; gap:10px;
  z-index:800; border-radius:22px;

  background:rgba(255,255,255,.06);
  backdrop-filter:blur(14px) saturate(1.4);
  -webkit-backdrop-filter:blur(14px) saturate(1.4);
  border:1px solid rgba(255,255,255,.18);
  box-shadow:
    0 4px 30px rgba(0,0,0,.22),
    inset 0 1px 0 rgba(255,255,255,.22),
    inset 0 -1px 0 rgba(255,255,255,.06);
  transition:background var(--tr), border-color var(--tr), box-shadow var(--tr);

  animation:navIn .55s ease both;
}

.nav.nav-scrolled {
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.24);
  box-shadow:
    0 8px 40px rgba(0,0,0,.28),
    inset 0 1px 0 rgba(255,255,255,.26),
    inset 0 -1px 0 rgba(255,255,255,.07);
}

body.light .nav {
  background:rgba(255,255,255,.55);
  border-color:rgba(0,0,0,.08);
  box-shadow:
    0 4px 30px rgba(var(--brand-primary-rgb), 0.15),
    inset 0 1px 0 rgba(255,255,255,.7);
}
body.light .nav.nav-scrolled {
  background:rgba(255,255,255,.75);
  border-color:rgba(0,0,0,.1);
  box-shadow:
    0 8px 40px rgba(var(--brand-primary-rgb), 0.15),
    inset 0 1px 0 rgba(255,255,255,.75);
}
.nav-logo {
  font-size:1.18rem; font-weight:900; letter-spacing:.05em;
  color:#fff; white-space:nowrap; flex-shrink:0;
}
.nav-logo span { color:var(--primary); text-shadow:0 0 16px rgba(var(--brand-primary-rgb), 0.35); }

.nav-links {
  display:flex; align-items:center; gap:1px;
  flex:1; justify-content:center; min-width:0;
}
.nav-links a {
  padding:6px 12px; border-radius:10px;
  font-size:.86rem; font-weight:600; color:rgba(255,255,255,.7);
  transition:color var(--tr), background var(--tr);
  white-space:nowrap; position:relative;
}
.nav-links a::after {
  content:''; position:absolute;
  bottom:2px; left:50%; transform:translateX(-50%) scaleX(0);
  width:14px; height:2px; border-radius:99px;
  background:linear-gradient(90deg,var(--primary),var(--accent));
  transition:transform .25s;
}
.nav-links a:hover { color:#fff; background:rgba(255,255,255,.08); }
.nav-links a:hover::after { transform:translateX(-50%) scaleX(1); }
.nav-links a.active { color:#fff; background:rgba(var(--brand-primary-rgb), 0.1); }
.nav-links a.active::after { transform:translateX(-50%) scaleX(1); }

.nav-right {
  display:flex; align-items:center; gap:6px;
  flex-shrink:0; margin-inline-start:auto;
}

.btn-lang {
  padding:5px 11px; border-radius:9px;
  font-size:.76rem; font-weight:800;
  color:#fff;
  border:1px solid rgba(255,255,255,.25);
  background:rgba(255,255,255,.10);
  transition:all var(--tr);
  white-space:nowrap; flex-shrink:0; cursor:pointer;
}
.btn-lang:hover { border-color:var(--primary); background:rgba(var(--brand-primary-rgb), 0.2); }

.btn-currency {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 10px; border-radius: 9px;
  font-size: .78rem; font-weight: 700;
  color: #fff;
  border: 1px solid rgba(255,255,255,.25);
  background: rgba(255,255,255,.10);
  transition: all var(--tr);
  white-space: nowrap; flex-shrink: 0; cursor: pointer;
}
.btn-currency:hover { border-color: var(--primary); background: rgba(var(--brand-primary-rgb), 0.2); }

.currency-drop {
  position: fixed;
  z-index: 9999;
  background: var(--card, var(--bg2, #15171c));
  border: 1px solid var(--gborder);
  border-radius: 14px;
  padding: 8px;
  min-width: 240px;
  max-width: calc(100vw - 16px);

  max-height: min(70vh, 420px);
  overflow-y: auto;
  box-shadow: 0 16px 40px rgba(0,0,0,.45);
  backdrop-filter: blur(16px);
  animation: smartModalIn .15s ease;

  scrollbar-width: thin;
  scrollbar-color: var(--brand-primary) transparent;
}
.currency-drop::-webkit-scrollbar { width: 6px; }
.currency-drop::-webkit-scrollbar-thumb { background: var(--brand-primary); border-radius: 3px; }
body.light .currency-drop {
  background: #ffffff;
  border-color: rgba(0,0,0,0.08);
  box-shadow: 0 16px 40px rgba(15,23,42,0.18);
}
.currency-drop-item {
  display: flex; align-items: center; gap: 10px;
  width: 100%; padding: 9px 12px; border-radius: 9px;
  background: none; border: none;
  color: var(--muted); font-size: 13px; font-family: inherit;
  cursor: pointer; text-align: start;
  transition: background .15s, color .15s;
}
.currency-drop-item span:first-child { font-size: 18px; }
.currency-drop-item span:nth-child(2) { font-weight: 700; color: var(--text); min-width: 38px; }
.currency-drop-item small { opacity: .65; font-size: 11px; }
.currency-drop-item:hover { background: var(--glass); color: var(--text); }
.currency-drop-item.active { background: color-mix(in srgb, var(--primary) 15%, transparent); color: var(--primary); }
.currency-drop-item.active span:nth-child(2) { color: var(--primary); }

.btn-login {
  display:inline-flex; align-items:center;
  padding:7px 15px; border-radius:11px;
  font-size:.83rem; font-weight:700; color:#fff;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.09);
  transition:all var(--tr);
  white-space:nowrap; flex-shrink:0;
}
.btn-login:hover {
  background:rgba(255,255,255,.15);
  border-color:rgba(255,255,255,.35);
  transform:translateY(-1px);
}

.btn-primary {
  display:inline-flex; align-items:center; gap:8px;
  padding:9px 20px; border-radius:12px;
  font-size:.88rem; font-weight:700; color:#fff;
  background:linear-gradient(135deg,var(--primary) 0%,var(--purple) 100%);
  box-shadow:0 4px 18px var(--glow-p), inset 0 1px 0 rgba(255,255,255,.2);
  transition:filter var(--tr), transform var(--tr), box-shadow var(--tr);
  white-space:nowrap; flex-shrink:0;
  position:relative; overflow:hidden;
}
.btn-primary::before {
  content:''; position:absolute;
  top:0; left:-100%; width:55%; height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);
  transition:left .5s;
}
.btn-primary:hover::before { left:160%; }
.btn-primary:hover {
  filter:brightness(1.12);
  transform:translateY(-2px);
  box-shadow:0 8px 28px var(--glow-p), inset 0 1px 0 rgba(255,255,255,.25);
}
.btn-primary:active { transform:translateY(0); }
.nav-cta { padding:7px 16px; font-size:.82rem; }

.btn-ripple {
  position:absolute; border-radius:50%;
  background:rgba(255,255,255,.28); pointer-events:none;
  animation:ripple .65s ease forwards;
}

.btn-outline {
  display:inline-flex; align-items:center; gap:8px;
  padding:11px 24px; border-radius:13px;
  font-size:.9rem; font-weight:700; color:var(--text);
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.05);
  backdrop-filter:blur(10px);
  transition:background var(--tr), transform var(--tr), border-color var(--tr);
}
.btn-outline:hover {
  background:rgba(255,255,255,.10);
  border-color:rgba(255,255,255,.30);
  transform:translateY(-2px);
}

.user-chip { position:relative; }
.user-chip-btn {
  display:flex; align-items:center; gap:8px;
  padding:5px 12px 5px 6px; border-radius:999px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);
  backdrop-filter:blur(12px);
  transition:background var(--tr);
}
.user-chip-btn:hover { background:rgba(255,255,255,.12); }
.user-chip-btn img {
  width:30px; height:30px; border-radius:50%;
  object-fit:cover; border:2px solid rgba(255,255,255,.25);
}
.user-chip-btn span { font-size:.83rem; font-weight:700; }
.user-chip-btn i { font-size:.72rem; color:var(--muted); transition:transform .2s; }
.user-chip-btn[aria-expanded="true"] i { transform:rotate(180deg); }

.user-drop {
  position:absolute; top:calc(100% + 10px);
  inset-inline-end:0;
  min-width:260px;
  background:rgba(8,11,28,.94);
  backdrop-filter:blur(16px) saturate(1.4);
  border:1px solid rgba(255,255,255,.13);
  border-radius:18px;
  box-shadow:0 24px 60px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.1);
  padding:10px;
  display:none; flex-direction:column; gap:2px;
  animation:fadeDown .22s ease;
  z-index:100;
}
.user-drop.open { display:flex; }
body.light .user-drop {
  background: rgba(255,255,255,.98);
  border-color: rgba(0,0,0,.1);
  box-shadow: 0 24px 60px rgba(var(--brand-primary-rgb), 0.3), inset 0 1px 0 rgba(255,255,255,.6);
}

.user-drop-header {
  display:flex; align-items:center; gap:12px;
  padding:10px 8px 12px;
}
.user-drop-header img {
  width:42px; height:42px; border-radius:50%;
  object-fit:cover;
  border:2px solid rgba(var(--brand-primary-rgb), 0.2);
  box-shadow:0 4px 12px rgba(var(--brand-primary-rgb), 0.3);
}
.user-drop-header div { display:flex; flex-direction:column; gap:2px; min-width:0; }
.user-drop-header strong {
  font-size:.92rem; font-weight:900; color:#ffffff;
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.user-drop-header small {
  font-size:.72rem; color:rgba(255,255,255,.55);
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:170px;
}
body.light .user-drop-header strong { color:#111827; }
body.light .user-drop-header small { color:#6b7280; }

.user-drop-divider {
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);
  margin:4px 0;
}
body.light .user-drop-divider {
  background:linear-gradient(90deg,transparent,rgba(0,0,0,.1),transparent);
}

.user-drop-item,
.user-drop a, .user-drop button {
  display:flex; align-items:center; gap:11px;
  padding:10px 12px; border-radius:12px;
  font-size:.86rem; font-weight:700; color:rgba(255,255,255,.78);
  transition:all .18s ease; text-align:start;
  border:none; background:transparent; cursor:pointer;
  width:100%;
}
.user-drop-item i,
.user-drop a i,
.user-drop button i {
  width:18px; text-align:center; font-size:14px;
  color:rgba(255,255,255,.5);
  transition:color .18s ease;
}
.user-drop-item:hover,
.user-drop a:hover, .user-drop button:hover {
  color:#ffffff;
  background:rgba(var(--brand-primary-rgb), 0.1);
  padding-inline-start:16px;
}
.user-drop-item:hover i,
.user-drop a:hover i,
.user-drop button:hover i {
  color:var(--primary2);
}
body.light .user-drop-item,
body.light .user-drop a,
body.light .user-drop button {
  color:#374151;
}
body.light .user-drop-item i,
body.light .user-drop a i,
body.light .user-drop button i {
  color:#6b7280;
}
body.light .user-drop-item:hover,
body.light .user-drop a:hover,
body.light .user-drop button:hover {
  color:#111827;
  background:rgba(var(--brand-primary-rgb), 0.1);
}
body.light .user-drop-item:hover i,
body.light .user-drop a:hover i,
body.light .user-drop button:hover i {
  color:var(--primary);
}

.user-drop-logout { color:#fca5a5 !important; }
.user-drop-logout i { color:#f87171 !important; }
.user-drop-logout:hover {
  background:rgba(var(--brand-danger-rgb), 0.1) !important;
  color:#fff !important;
}
.user-drop-logout:hover i { color:var(--brand-danger) !important; }
body.light .user-drop-logout { color:var(--brand-danger) !important; }
body.light .user-drop-logout i { color:var(--brand-danger) !important; }
body.light .user-drop-logout:hover { background:rgba(var(--brand-danger-rgb), 0.1) !important; }

.user-drop-theme em {
  font-style:normal;
  background:rgba(var(--brand-primary-rgb), 0.1);
  padding:2px 8px;
  border-radius:99px;
  font-size:.68rem !important;
  font-weight:700;
  color:var(--brand-primary-h,#a5b4fc);
}
body.light .user-drop-theme em {
  background:rgba(var(--brand-primary-rgb), 0.1);
  color:var(--brand-primary);
}

.hamburger {
  display:none; flex-direction:column; gap:5px;
  padding:8px; border-radius:10px;
  border:1px solid var(--gborder); background:var(--glass);
  transition:background .2s;
}
.hamburger span {
  display:block; width:20px; height:2px;
  background:var(--text); border-radius:99px;
  transition:transform .3s, opacity .3s;
}
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

.mobile-overlay {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.55); z-index:700;
  backdrop-filter:blur(4px);
}
.mobile-overlay.open { display:block; }

.mobile-menu {
  position:fixed; top:0; inset-inline-end:-100%;
  width:min(320px,85vw); height:100vh;
  background:rgba(5,8,22,.96);
  backdrop-filter:blur(40px) saturate(1.8);
  border-inline-start:1px solid rgba(255,255,255,.1);
  z-index:750; transition:inset-inline-end .35s cubic-bezier(.4,0,.2,1);
  box-shadow:-20px 0 60px rgba(0,0,0,.5);
}
.mobile-menu.open { inset-inline-end:0; }
.mobile-menu-inner {
  padding:88px 20px 32px;
  display:flex; flex-direction:column; gap:4px;
}
.mobile-menu-inner a {
  padding:14px 18px; border-radius:14px;
  font-size:1rem; font-weight:700; color:var(--muted);
  border:1px solid transparent;
  transition:all .22s;
}
.mobile-menu-inner a:hover {
  color:var(--text);
  background:rgba(var(--brand-primary-rgb), 0.1);
  border-color:rgba(var(--brand-primary-rgb), 0.2);
  padding-inline-start:24px;
}

.mobile-menu-divider {
  height:1px;
  background:rgba(255,255,255,.08);
  margin:10px 0 6px;
}
.mobile-login-btn {
  display:block;
  padding:14px 18px; border-radius:14px;
  font-size:1rem; font-weight:700; color:var(--text);
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.07);
  text-align:center; transition:all .22s;
}
.mobile-login-btn:hover {
  background:rgba(255,255,255,.13);
  border-color:rgba(255,255,255,.28);
}
.mobile-start-btn {
  display:flex; align-items:center; justify-content:center; gap:9px;
  padding:14px 18px; border-radius:14px;
  font-size:1rem; font-weight:700; color:#fff;
  background:linear-gradient(135deg,var(--primary),var(--accent));
  box-shadow:0 4px 18px rgba(var(--brand-primary-rgb), 0.3);
  border:none; margin-top:4px; transition:all .22s;
}
.mobile-start-btn:hover { filter:brightness(1.1); transform:translateY(-1px); }

.hero {
  position:relative; min-height:100vh;
  display:flex; align-items:center;
  padding:var(--nav-h) 0 60px;
  z-index:1; overflow:hidden;
}

.hero::before {
  content:'';
  position:absolute; top:-10%; left:50%; transform:translateX(-50%);
  width:min(900px,140vw); height:min(900px,140vw);
  background:radial-gradient(circle,rgba(var(--brand-primary-rgb), 0.1) 0%,rgba(var(--brand-accent-rgb,139,92,246),.08) 35%,transparent 68%);
  pointer-events:none;
}

.hero-inner {
  position:relative; z-index:1;
  max-width:1200px; margin:0 auto;
  padding:0 clamp(16px,4vw,48px);
  width:100%;
  display:grid; grid-template-columns:1fr 1fr;
  gap:clamp(24px,4vw,60px); align-items:center;
}

.hero-left {
  display:flex; flex-direction:column;
  align-items:flex-start; gap:0;
}
[dir="ltr"] .hero-left { align-items:flex-start; }

.hero-badge {
  display:inline-flex; align-items:center; gap:10px;
  padding:8px 18px; border-radius:999px;
  background:rgba(var(--brand-primary-rgb), 0.1);
  border:1px solid rgba(var(--brand-primary-rgb), 0.2);
  color:var(--brand-primary-h,#a5b4fc); font-size:.78rem; font-weight:700;
  letter-spacing:.06em; margin-bottom:22px;
  backdrop-filter:blur(12px);
  animation:badgePop .6s .2s ease both;
}

.badge-dot {
  width:7px; height:7px; border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 10px var(--accent);
  animation:orbPulse 2s ease-in-out infinite;
}

.hero-h1 {
  font-size:clamp(2rem,5vw,4rem);
  font-weight:900; line-height:1.2;
  margin-bottom:26px;
  letter-spacing:-.02em;

  min-height:2.4em;
  display:flex; align-items:flex-start;
}

.hero-h1-anim {
  animation: heroTitleIn .65s cubic-bezier(.22,1,.36,1) both;
}
@keyframes heroTitleIn {
  from { transform: translateY(28px); }
  to   { transform: translateY(0); }
}

.gradient-cycle {
  display:block;
  background:linear-gradient(270deg,var(--primary),var(--accent),var(--purple),var(--secondary),var(--primary));
  background-size:400% 400%;
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
  animation:gradShift 6s ease infinite;

  white-space:normal;
  word-break:break-word;
}
body.light .gradient-cycle { -webkit-text-fill-color:transparent; color:transparent !important; }

#typeTarget {

  display:inline;
}

#typeWrapper::after {
  content:'|';
  display:inline-block;

  -webkit-text-fill-color:var(--primary) !important;
  color:var(--primary) !important;
  background:none !important;
  -webkit-background-clip:unset !important;
  background-clip:unset !important;
  animation:typewriterBlink .75s step-end infinite;
  font-weight:300;
  margin-inline-start:2px;
}

.hero-p {
  font-size:clamp(.95rem,1.8vw,1.08rem);
  color:var(--muted); line-height:1.9;
  max-width:480px; margin-bottom:32px;
}

.hero-actions { display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-bottom:36px; }

.hero-stats {
  display:flex; align-items:center; gap:0;
  padding:16px 24px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.09);
  border-radius:18px;
  backdrop-filter:blur(8px);
}
.stat { display:flex; flex-direction:column; align-items:center; gap:2px; padding:0 18px; }
.stat strong {
  font-size:1.5rem; font-weight:900;
  background:linear-gradient(135deg,#fff,rgba(var(--brand-primary-h-rgb,165,180,252),.9));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.stat span { font-size:.73rem; color:var(--muted); font-weight:600; white-space:nowrap; }
.stat-sep { width:1px; height:36px; background:rgba(255,255,255,.1); }

.hero-right {
  position:relative; display:flex;
  align-items:center; justify-content:center;
  padding:clamp(12px,3vw,32px);
}

.hcard {
  width:100%; max-width:400px;

  background:rgba(255,255,255,.07);
  backdrop-filter:blur(16px) saturate(1.3);
  -webkit-backdrop-filter:blur(16px) saturate(1.3);
  border:1px solid rgba(255,255,255,.18);
  border-radius:28px;
  padding:clamp(18px,3vw,28px);
  box-shadow:
    0 32px 80px rgba(0,0,0,.35),
    inset 0 1px 0 rgba(255,255,255,.22),
    inset 0 -1px 0 rgba(255,255,255,.05);
  position:relative; overflow:hidden;
  animation:floatY 6s ease-in-out infinite;
}

.hcard::before {
  content:'';
  position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(var(--brand-primary-rgb), 0.15),rgba(var(--brand-accent-rgb,139,92,246),.5),transparent);
}

.hcard::after {
  content:'';
  position:absolute; top:-40px; left:50%; transform:translateX(-50%);
  width:200px; height:200px;
  background:radial-gradient(circle,rgba(var(--brand-primary-rgb), 0.1) 0%,transparent 65%);
  pointer-events:none;
}

.hcard-header {
  display:flex; align-items:center; gap:10px;
  font-size:.74rem; font-weight:800; letter-spacing:.08em;
  color:#ffffff; margin-bottom:20px;
  text-shadow:0 1px 2px rgba(0,0,0,.3);
}
.live-dot {
  width:7px; height:7px; border-radius:50%;
  background:var(--brand-success);
  box-shadow:0 0 0 2px rgba(var(--brand-success-rgb), 0.3);
  animation:orbPulse 1.5s ease-in-out infinite;
}
.hcard-id {
  margin-inline-start:auto;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.2);
  padding:3px 10px; border-radius:6px;
  font-size:.7rem; color:#ffffff; font-weight:700;
}

.hcard-steps { display:flex; flex-direction:column; gap:0; margin-bottom:20px; }
.hstep {
  display:flex; align-items:flex-start; gap:12px;
  padding:10px 0; position:relative;
}
.hstep:not(:last-child)::before {
  content:'';
  position:absolute; inset-inline-start:15px; top:34px;
  width:2px; height:calc(100% - 16px);
  background:rgba(255,255,255,.06); border-radius:99px;
}
.hstep.done .hstep-icon { background:rgba(var(--brand-success-rgb), 0.2); border-color:rgba(var(--brand-success-rgb), 0.2); color:#4ade80; }
.hstep.active .hstep-icon {
  background:rgba(var(--brand-primary-rgb), 0.2); border-color:rgba(var(--brand-primary-rgb), 0.2); color:var(--brand-primary-h,#a5b4fc);
  animation:glowPulse 2s ease-in-out infinite;
}
.hstep-icon {
  width:32px; height:32px; border-radius:50%;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  display:flex; align-items:center; justify-content:center;
  font-size:.8rem; flex-shrink:0; color:var(--muted);
}
.hstep-info { display:flex; flex-direction:column; gap:2px; }
.hstep-info strong { font-size:.85rem; font-weight:800; color:#ffffff; }
.hstep-info small { font-size:.72rem; color:rgba(255,255,255,.7); font-weight:600; }

.hcard-chat { display:flex; flex-direction:column; gap:8px; }
.chat-bubble {
  display:inline-flex; align-items:center; gap:8px;
  padding:9px 14px; border-radius:14px;
  font-size:.79rem; font-weight:600; max-width:88%;
}
.chat-bubble.ai {
  background:rgba(var(--brand-primary-rgb), 0.1);
  border:1px solid rgba(var(--brand-primary-rgb), 0.2);
  color:#ffffff;
  font-weight:600;
}
.chat-bubble.ai i { color:var(--brand-primary-h,#a5b4fc); }
.chat-bubble.me {
  background:rgba(var(--brand-secondary-rgb), 0.1);
  border:1px solid rgba(var(--brand-secondary-rgb), 0.2);
  color:#ffffff;
  font-weight:600;
  align-self:flex-end;
}

.hcard-deco {
  position:absolute; border-radius:14px;
  background:rgba(10,14,36,.9);
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 8px 24px rgba(0,0,0,.4);
  padding:10px 14px;
  font-size:.75rem; font-weight:700; color:var(--brand-primary-h,#a5b4fc);
  display:flex; align-items:center; gap:6px;
  white-space:nowrap; pointer-events:none;
}
.hcard-deco i { font-size:.9rem; }
.hcard-deco.d1 { top:-18px; inset-inline-start:-18px; color:var(--brand-secondary,#f472b6); border-color:rgba(var(--brand-secondary-rgb,244,114,182),.25); animation:floatY 4s ease-in-out infinite; }
.hcard-deco.d2 { top:-14px; inset-inline-end:-22px; color:var(--brand-success); border-color:rgba(52,211,153,.25); animation:floatY 5s 1s ease-in-out infinite; }
.hcard-deco.d3 { bottom:-14px; inset-inline-start:-16px; color:var(--brand-info,#60a5fa); border-color:rgba(var(--brand-info-rgb,96,165,250),.25); animation:floatY 4.5s .5s ease-in-out infinite; }

.scroll-hint {
  position:absolute; bottom:28px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:8px;
}
.scroll-hint-line {
  width:2px; height:44px; border-radius:99px;
  background:linear-gradient(180deg,rgba(var(--brand-primary-rgb), 0.15),transparent);
  animation:hintBounce 2s ease-in-out infinite;
}

.section {
  position:relative; z-index:1;
  padding:clamp(60px,8vw,110px) clamp(16px,4vw,48px);
  max-width:1240px; margin:0 auto;
}

.section-head {
  display:flex; align-items:flex-start;
  justify-content:space-between; gap:20px;
  margin-bottom:52px;
}
.section-head.center {
  flex-direction:column; align-items:center; text-align:center;
  margin-bottom:52px;
}
.section-head h2 {
  font-size:clamp(1.7rem,3.5vw,2.6rem);
  font-weight:900; margin:8px 0 10px;
  letter-spacing:-.02em;
}
.section-head p { font-size:.95rem; color:var(--muted); max-width:520px; line-height:1.8; }

.section-badge {
  display:inline-flex; align-items:center; gap:8px;
  padding:5px 14px; border-radius:999px;
  font-size:.7rem; font-weight:800; letter-spacing:.12em;
  color:var(--primary2);
  background:rgba(var(--brand-primary-rgb), 0.1);
  border:1px solid rgba(var(--brand-primary-rgb), 0.2);
}
.section-badge.dark {
  color:rgba(255,255,255,.5);
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.12);
}
.section-badge::before {
  content:''; width:5px; height:5px; border-radius:50%;
  background:var(--primary); box-shadow:0 0 6px var(--primary);
}

.grad-text {
  background:linear-gradient(135deg,var(--primary),var(--accent));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

.works-section {}

.tabs {
  display:flex; gap:4px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.09);
  border-radius:14px; padding:4px;
  backdrop-filter:blur(10px);
}
.tab {
  padding:8px 20px; border-radius:11px;
  font-size:.84rem; font-weight:700; color:var(--muted);
  transition:all .25s;
}
.tab.active {
  background:linear-gradient(135deg,var(--primary),var(--purple));
  color:#fff;
  box-shadow:0 4px 14px var(--glow-p);
}

.works-pane { display:none; }
.works-pane.active { display:block; }

.reels-grid {
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:12px;
}
.reel-card {
  position:relative; border-radius:20px; overflow:hidden;
  aspect-ratio:9/16; cursor:pointer;
  border:1px solid rgba(255,255,255,.08);
  transition:transform .35s cubic-bezier(.22,1,.36,1), box-shadow .35s;

  contain: layout paint;
  will-change: transform;
}
.reel-card:hover {
  transform:translateY(-6px) scale(1.02);
  box-shadow:0 24px 56px rgba(0,0,0,.45), 0 0 0 1px rgba(var(--brand-primary-rgb), 0.3);
}
.reel-card video,
.reel-card img { width:100%; height:100%; object-fit:cover; }
.reel-overlay {
  position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(4,6,18,.9) 100%);
  display:flex; flex-direction:column;
  justify-content:flex-end; padding:14px;
  opacity:0; transition:opacity .3s;
}
.reel-card:hover .reel-overlay { opacity:1; }
.reel-play {
  position:absolute; top:50%; left:50%;
  transform:translate(-50%,-50%);
  width:42px; height:42px; border-radius:50%;
  background:rgba(var(--brand-primary-rgb), 0.1);
  backdrop-filter:blur(6px);
  display:flex; align-items:center; justify-content:center;
  font-size:.85rem; color:#fff;
  box-shadow:0 0 20px rgba(var(--brand-primary-rgb), 0.3), 0 2px 8px rgba(0,0,0,.4);

  opacity:.88; transition:opacity .25s, transform .25s, box-shadow .25s;
}
.reel-card:hover .reel-play {
  opacity:1;
  transform:translate(-50%,-50%) scale(1.15);
  box-shadow:0 0 28px rgba(var(--brand-primary-rgb), 0.3), 0 4px 16px rgba(0,0,0,.5);
}

.designs-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.design-card {
  position: relative;
  border-radius:20px; overflow:hidden;
  aspect-ratio:1/1; cursor:pointer;
  border:1px solid rgba(255,255,255,.08);
  transition:transform .35s cubic-bezier(.22,1,.36,1), box-shadow .35s;
  background-color: rgba(255,255,255,0.04);
}
.design-card:hover {
  transform:translateY(-6px) scale(1.03);
  box-shadow:0 24px 56px rgba(0,0,0,.45), 0 0 0 1px rgba(var(--brand-secondary-rgb), 0.3);
}
.design-card img { width:100%; height:100%; object-fit:cover; }

.reel-label {
  position:absolute; top:10px; inset-inline-start:10px;
  padding:3px 10px; border-radius:8px;
  font-size:.65rem; font-weight:800; letter-spacing:.08em;
  background:rgba(var(--brand-primary-rgb), 0.1);
  backdrop-filter:blur(6px);
  color:#fff; z-index:2;
}
.design-card {
  border-radius:20px;
  aspect-ratio:1/1; cursor:pointer;
  border:1px solid rgba(255,255,255,.08);
  background-size:cover; background-position:center;
  background-color:rgba(var(--brand-primary-rgb), 0.1);
  transition:transform .35s cubic-bezier(.22,1,.36,1), box-shadow .35s;
  position:relative; overflow:hidden;
}
.design-card:hover {
  transform:translateY(-6px) scale(1.03);
  box-shadow:0 24px 56px rgba(0,0,0,.45), 0 0 0 1px rgba(var(--brand-secondary-rgb), 0.3);
}

.btn-more {
  display:flex; align-items:center; justify-content:center;
  margin:28px auto 0; padding:11px 32px;
  border-radius:13px; font-size:.88rem; font-weight:700;
  color:var(--primary2);
  border:1px solid rgba(var(--brand-primary-rgb), 0.2);
  background:rgba(var(--brand-primary-rgb), 0.1);
  backdrop-filter:blur(10px);
  transition:all .25s;
}
.btn-more:hover {
  background:rgba(var(--brand-primary-rgb), 0.1);
  border-color:rgba(var(--brand-primary-rgb), 0.2);
  transform:translateY(-1px);
}

.services-section {}

.services-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 22px;
  overflow: visible;
}

.svc-card3-wrap {
  position: relative;
  padding-top: 44px;
}

.svc-card3 {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.09);
  box-shadow: 0 4px 24px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.07);
  cursor: default;
  transition:
    box-shadow .4s,
    border-color .3s;
  will-change: transform;

  transition: transform .55s cubic-bezier(.23,1,.32,1),
              box-shadow .4s,
              border-color .3s;
}
.svc-card3:hover {
  border-color: color-mix(in srgb, var(--c) 55%, transparent);
  box-shadow:
    0 24px 60px rgba(0,0,0,.45),
    0 0 0 1px color-mix(in srgb, var(--c) 30%, transparent),
    inset 0 1px 0 rgba(255,255,255,.13);
}

.svc-c3-glow {
  --gx: 50%; --gy: 50%;
  position: absolute; inset: 0;
  background: radial-gradient(
    circle 170px at var(--gx) var(--gy),
    var(--c) 0%,
    transparent 68%
  );
  opacity: 0;
  transition: opacity .35s;
  pointer-events: none;
  z-index: 0;
  mix-blend-mode: screen;
}

.svc-c3-shine {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    115deg,
    transparent 30%,
    rgba(255,255,255,.07) 48%,
    rgba(255,255,255,.13) 50%,
    rgba(255,255,255,.07) 52%,
    transparent 70%
  );
  transform: translateX(-120%) skewX(-10deg);
  pointer-events: none;
  z-index: 1;
  transition: transform .0s;
}
.svc-card3:hover .svc-c3-shine {
  transform: translateX(140%) skewX(-10deg);
  transition: transform .7s cubic-bezier(.4,0,.2,1);
}

.svc-c3-top {
  position: relative;
  z-index: 2;
  height: 128px;
  display: flex;
  align-items: center;
  justify-content: center;

  background: linear-gradient(
    145deg,
    color-mix(in srgb, var(--c) 22%, transparent) 0%,
    color-mix(in srgb, var(--c) 8%, transparent) 100%
  );
  border-bottom: 1px solid rgba(255,255,255,.06);
  overflow: hidden;
}

.svc-c3-top::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    radial-gradient(circle, rgba(255,255,255,.09) 1px, transparent 1px);
  background-size: 22px 22px;
  pointer-events: none;
}

.svc-c3-top::after {
  content: '';
  position: absolute;
  width: 80px; height: 80px;
  border-radius: 50%;
  background: var(--c);
  filter: blur(38px);
  opacity: .28;
  top: -20px;
  inset-inline-end: -10px;
  pointer-events: none;
}

.svc-c3-num {
  position: absolute;
  top: 12px;
  inset-inline-start: 16px;
  font-size: .78rem;
  font-weight: 800;
  color: rgba(255,255,255,.2);
  letter-spacing: .04em;
  line-height: 1;
  font-family: 'Inter', 'Segoe UI', sans-serif;
}

.svc-c3-icon {
  width: 66px; height: 66px;
  border-radius: 20px;
  background: rgba(0,0,0,.35);
  border: 1px solid rgba(255,255,255,.14);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.8rem;
  color: var(--c);
  box-shadow:
    0 8px 28px color-mix(in srgb, var(--c) 45%, transparent),
    inset 0 1px 0 rgba(255,255,255,.18);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  position: relative; z-index: 2;
  transition: transform .45s cubic-bezier(.34,1.56,.64,1), box-shadow .4s;
}
.svc-card3:hover .svc-c3-icon {
  transform: translateY(-4px) scale(1.08);
  box-shadow:
    0 16px 40px color-mix(in srgb, var(--c) 55%, transparent),
    inset 0 1px 0 rgba(255,255,255,.22);
}

.svc-c3-body {
  position: relative; z-index: 2;
  padding: 20px 22px 24px;
}
.svc-c3-name {
  font-size: 1rem;
  font-weight: 800;
  color: var(--text);
  margin-bottom: 8px;
  line-height: 1.3;
  transition: color .28s;
}
.svc-card3:hover .svc-c3-name {
  color: color-mix(in srgb, var(--c) 60%, var(--text));
}
.svc-c3-desc {
  font-size: .83rem;
  color: var(--muted);
  line-height: 1.72;
  margin: 0;
}

.svc-c3-line {
  display: block;
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(
    90deg,
    transparent,
    var(--c) 40%,
    var(--c) 60%,
    transparent
  );
  transform: scaleX(0);
  transform-origin: center;
  transition: transform .45s cubic-bezier(.34,1.56,.64,1);
}
.svc-card3:hover .svc-c3-line { transform: scaleX(1); }

body.light .svc-card3 {
  background: rgba(255,255,255,.9);
  border-color: rgba(0,0,0,.07);
  box-shadow: 0 4px 24px rgba(0,0,0,.08);
}
body.light .svc-card3:hover {
  box-shadow: 0 20px 50px rgba(0,0,0,.13);
}
body.light .svc-c3-name  { color: #111827; }
body.light .svc-c3-desc  { color: #4b5563; }
body.light .svc-c3-num   { color: rgba(0,0,0,.18); }
body.light .svc-c3-icon  { background: rgba(255,255,255,.85); }
body.light .svc-c3-glow  { mix-blend-mode: multiply; opacity: 0 !important; }

@media (prefers-reduced-motion: reduce) {
  .svc-card3 { transition: box-shadow .3s, border-color .3s; }
  .svc-c3-shine { display: none; }
}

@media (max-width: 600px) {
  .services-grid        { grid-template-columns: 1fr 1fr; gap: 14px; }
  .svc-card3-wrap       { padding-top: 36px; }
  .svc-c3-top           { height: 80px; }
  .svc-c3-body          { padding: 14px 16px 18px; }
  .svc-c3-name          { font-size: .9rem; }
  .svc-c3-desc          { font-size: .78rem; }
  .svc-c3-badge         { width: 60px; height: 60px; border-radius: 16px; font-size: 1.5rem; top: 6px; }
}
@media (max-width: 380px) {
  .services-grid { grid-template-columns: 1fr; }
}

.svc-c3-badge {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 80px; height: 80px;
  border-radius: 22px;
  background: rgba(8,10,30,.85);
  border: 1px solid rgba(255,255,255,.14);
  display: flex; align-items: center; justify-content: center;
  font-size: 2rem;
  z-index: 10;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow:
    0 10px 32px color-mix(in srgb, var(--c) 40%, transparent),
    inset 0 1px 0 rgba(255,255,255,.18);
  transition: transform .45s cubic-bezier(.34,1.56,.64,1), box-shadow .4s;
  overflow: hidden;
}
.svc-c3-badge img {
  width: 100%; height: 100%;
  object-fit: cover;
  border-radius: inherit;
}
.svc-card3-wrap:hover .svc-c3-badge {
  transform: translateX(-50%) translateY(-6px) scale(1.1);
  box-shadow:
    0 18px 48px color-mix(in srgb, var(--c) 55%, transparent),
    inset 0 1px 0 rgba(255,255,255,.25);
}
body.light .svc-c3-badge {
  background: rgba(255,255,255,.92);
  border-color: rgba(0,0,0,.1);
}

.svc-c3-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px; height: 30px;
  border-radius: 50%;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  color: var(--muted);
  font-size: .8rem;
  margin-top: 14px;
  transition: background .28s, color .28s, transform .35s cubic-bezier(.34,1.56,.64,1);
  cursor: pointer;
}
.svc-card3:hover .svc-c3-cta {
  background: color-mix(in srgb, var(--c) 20%, transparent);
  color: var(--c);
  transform: translateX(-4px);
}
body.ltr .svc-card3:hover .svc-c3-cta { transform: translateX(4px); }
body.ltr .svc-c3-cta i               { transform: rotate(180deg); }

.svc-modal-overlay {
  position: fixed; inset: 0;
  background: rgba(3,6,16,.75);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  z-index: 9000;
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s;
}
.svc-modal-overlay.open {
  opacity: 1;
  pointer-events: all;
}
.svc-modal-box {
  background: rgba(12,14,35,.96);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 28px;
  width: 100%;
  max-width: 480px;
  overflow: hidden;
  box-shadow: 0 32px 80px rgba(0,0,0,.6), inset 0 1px 0 rgba(255,255,255,.08);
  transform: translateY(30px) scale(.96);
  transition: transform .35s cubic-bezier(.34,1.56,.64,1);
  position: relative;
}
.svc-modal-overlay.open .svc-modal-box {
  transform: translateY(0) scale(1);
}

.svc-modal-hero {
  height: 110px;
  background: linear-gradient(
    145deg,
    color-mix(in srgb, var(--c, var(--brand-primary)) 28%, transparent) 0%,
    color-mix(in srgb, var(--c, var(--brand-primary)) 8%, transparent) 100%
  );
  display: flex; align-items: flex-end; justify-content: center;
  padding-bottom: 0;
  position: relative;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.svc-modal-hero::before {
  content: '';
  position: absolute; inset: 0;
  background-image: radial-gradient(circle, rgba(255,255,255,.07) 1px, transparent 1px);
  background-size: 22px 22px;
}

.svc-modal-badge {
  width: 80px; height: 80px;
  border-radius: 22px;
  background: rgba(0,0,0,.45);
  border: 1px solid rgba(255,255,255,.14);
  display: flex; align-items: center; justify-content: center;
  font-size: 2.1rem;
  position: absolute;
  bottom: -36px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18);
  overflow: hidden;
}
.svc-modal-badge img {
  width: 100%; height: 100%; object-fit: cover; border-radius: inherit;
}

.svc-modal-body {
  padding: 52px 28px 32px;
}
.svc-modal-name {
  font-size: 1.5rem;
  font-weight: 900;
  color: var(--text);
  margin-bottom: 12px;
  text-align: center;
}
.svc-modal-desc {
  font-size: .92rem;
  color: var(--muted);
  line-height: 1.75;
  text-align: center;
  margin-bottom: 22px;
}
.svc-modal-feats {
  list-style: none;
  padding: 0; margin: 0;
  display: flex;
  flex-direction: column;
  gap: 11px;
}
.svc-modal-feats li {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: .9rem;
  color: var(--text);
  padding: 10px 14px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 12px;
}
.svc-modal-feats li i {
  font-size: .8rem;
  flex-shrink: 0;
}

.svc-modal-close {
  position: absolute;
  top: 12px; inset-inline-end: 12px;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.18);
  color: #fff;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: .95rem;
  z-index: 100;
  transition: background .22s, transform .28s;
  pointer-events: all;
}
.svc-modal-close:hover {
  background: rgba(var(--brand-secondary-rgb,236,72,153),.35);
  transform: rotate(90deg);
}

.svc-modal-hero::before { pointer-events: none; }

body.light .svc-modal-box {
  background: rgba(255,255,255,.97);
  border-color: rgba(0,0,0,.08);
}
body.light .svc-modal-name { color: #111827; }
body.light .svc-modal-desc { color: #4b5563; }
body.light .svc-modal-feats li {
  background: rgba(0,0,0,.03);
  border-color: rgba(0,0,0,.07);
  color: #111827;
}

.ai-section {
  padding:clamp(60px,8vw,110px) clamp(16px,4vw,48px);
  max-width:1240px; margin:0 auto; z-index:1; position:relative;
}
.ai-section::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 70% 60% at 50% 50%,rgba(var(--brand-primary-rgb), 0.1) 0%,transparent 65%);
  pointer-events:none;
}
.ai-wrap {
  display:grid; grid-template-columns:1fr 1fr;
  gap:clamp(32px,5vw,72px); align-items:center;
}
.ai-content { display:flex; flex-direction:column; gap:0; }
.ai-content h2 { font-size:clamp(1.7rem,3.5vw,2.6rem); font-weight:900; margin:8px 0 14px; line-height:1.2; }
.ai-content p { font-size:.95rem; color:var(--muted); line-height:1.9; margin-bottom:28px; }

.ai-chips { display:flex; flex-wrap:wrap; gap:10px; }
.ai-chip {
  display:inline-flex; align-items:center; gap:7px;
  padding:8px 16px; border-radius:999px;
  font-size:.8rem; font-weight:700;
  background:rgba(var(--brand-primary-rgb), 0.1);
  border:1px solid rgba(var(--brand-primary-rgb), 0.2);
  color:var(--primary2);
  transition:all .25s;
}
.ai-chip:hover {
  background:rgba(var(--brand-primary-rgb), 0.1);
  border-color:rgba(var(--brand-primary-rgb), 0.2);
  transform:translateY(-1px);
}
.ai-chip i { color:var(--accent); }

.ai-visual {
  position:relative; display:flex;
  align-items:center; justify-content:center;
  min-height:320px;
}
.ai-ring {
  position:relative; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
}
.ai-ring.r1 {
  width:280px; height:280px;
  border:1px solid rgba(var(--brand-primary-rgb), 0.2);
  background:radial-gradient(circle,rgba(var(--brand-primary-rgb), 0.1) 0%,transparent 70%);
  box-shadow:0 0 60px rgba(var(--brand-primary-rgb), 0.3), inset 0 0 40px rgba(var(--brand-primary-rgb), 0.3);
  animation:ringRotate 20s linear infinite;
}
.ai-ring.r2 {
  width:200px; height:200px;
  border:1px solid rgba(var(--brand-secondary-rgb), 0.2);
  background:radial-gradient(circle,rgba(var(--brand-secondary-rgb), 0.1) 0%,transparent 65%);
  animation:ringRotate 14s linear infinite reverse;
}
.ai-ring.r3 {
  width:130px; height:130px;
  border:1px solid rgba(var(--brand-accent-rgb,168,85,247),.25);
  background:radial-gradient(circle,rgba(var(--brand-accent-rgb,168,85,247),.08) 0%,transparent 60%);
  animation:ringRotate 8s linear infinite;
}
.ai-core {
  width:78px; height:78px; border-radius:50%;
  background:linear-gradient(135deg,var(--primary),var(--purple));
  display:flex; align-items:center; justify-content:center;
  font-size:.85rem; font-weight:900; color:#fff; letter-spacing:.06em;
  box-shadow:0 0 30px rgba(var(--brand-primary-rgb), 0.3), 0 0 60px rgba(var(--brand-primary-rgb), 0.3);
}
.ai-dot {
  position:absolute; top:0; left:50%; transform:translateX(-50%);
  width:10px; height:10px; border-radius:50%;
  transform-origin:0 140px;
}
.ai-dot.dot-a { background:var(--primary); box-shadow:0 0 10px var(--primary); animation:ringRotate 20s linear infinite; }
.ai-dot.dot-b { background:var(--accent); box-shadow:0 0 10px var(--accent); animation:ringRotate 20s -6s linear infinite; transform-origin:0 130px; }
.ai-dot.dot-c { background:var(--secondary); box-shadow:0 0 10px var(--secondary); animation:ringRotate 20s -12s linear infinite; transform-origin:0 150px; }

.plans-tabs {
  display: flex;
  gap: 10px;
  justify-content: center;
  margin-bottom: 32px;
}
.plans-tab {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 11px 28px;
  border-radius: 50px;
  border: 1.5px solid var(--gborder);
  background: var(--glass);
  color: var(--muted);
  font-size: 15px;
  font-family: inherit;
  cursor: pointer;
  transition: all .2s;
  backdrop-filter: blur(8px);
}
.plans-tab:hover { border-color: var(--primary); color: var(--text); }
.plans-tab.active {
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
  box-shadow: 0 4px 20px color-mix(in srgb, var(--primary) 40%, transparent);
}
.plans-tab-panel { display: none; }
.plans-tab-panel.active { display: block; }

.custom-pkg-wrap {
  margin-top: 28px;
}
.custom-pkg-card {
  display: flex;
  align-items: center;
  gap: 20px;
  background: var(--glass);
  border: 1.5px dashed var(--primary);
  border-radius: 20px;
  padding: 24px 28px;
  backdrop-filter: blur(10px);
  flex-wrap: wrap;
}
.custom-pkg-icon {
  width: 52px; height: 52px;
  border-radius: 14px;
  background: color-mix(in srgb, var(--primary) 15%, transparent);
  display: flex; align-items: center; justify-content: center;
  font-size: 22px;
  color: var(--primary);
  flex-shrink: 0;
}
.custom-pkg-body { flex: 1; min-width: 160px; }
.custom-pkg-body h3 { margin: 0 0 4px; font-size: 17px; color: var(--text); }
.custom-pkg-body p  { margin: 0; font-size: 13px; color: var(--muted); line-height: 1.6; }
.custom-pkg-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.custom-pkg-btn {
  display: flex; align-items: center; gap: 7px;
  padding: 10px 22px;
  border-radius: 50px;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  transition: all .2s;
}
.custom-pkg-btn.whatsapp {
  background: #25D366;
  color: #fff;
  box-shadow: 0 4px 14px rgba(37,211,102,.35);
}
.custom-pkg-btn.whatsapp:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(37,211,102,.5); }
.custom-pkg-btn.email {
  background: var(--glass);
  border: 1.5px solid var(--gborder);
  color: var(--text);
}
.custom-pkg-btn.email:hover { border-color: var(--primary); color: var(--primary); }

.singles-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 20px;
}
.singles-empty {
  text-align: center;
  color: var(--muted);
  padding: 40px;
}
.single-card {
  background: var(--glass);
  border: 1px solid var(--gborder);
  border-radius: 18px;
  padding: 22px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  backdrop-filter: blur(10px);
  transition: transform .2s, box-shadow .2s, border-color .2s;
  position: relative;
  overflow: hidden;
}
.single-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 80% 20%, color-mix(in srgb, var(--sc) 12%, transparent), transparent 60%);
  pointer-events: none;
}
.single-card:hover {
  transform: translateY(-4px);
  border-color: var(--sc);
  box-shadow: 0 12px 32px color-mix(in srgb, var(--sc) 20%, transparent);
}
.single-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.single-card-icon {
  width: 46px; height: 46px;
  border-radius: 12px;
  background: color-mix(in srgb, var(--sc) 15%, transparent);
  display: flex; align-items: center; justify-content: center;
  font-size: 20px;
  color: var(--sc);
}
.single-card-del {
  font-size: 12px;
  color: var(--muted);
  display: flex; align-items: center; gap: 4px;
}
.single-card-body { flex: 1; }
.single-card-name {
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 6px;
}
.single-card-desc {
  font-size: 13px;
  color: var(--muted);
  line-height: 1.6;
  margin: 0;
}
.single-card-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-top: auto;
}
.single-card-price {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.single-old-price {
  font-size: 12px;
  color: var(--muted);
  text-decoration: line-through;
}
.single-price-val {
  font-size: 22px;
  font-weight: 800;
  color: var(--sc);
}
.single-card-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 9px 18px;
  border-radius: 50px;
  background: var(--sc);
  color: #fff;
  border: none;
  font-size: 13px;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  transition: all .2s;
  white-space: nowrap;
}
.single-card-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 18px color-mix(in srgb, var(--sc) 40%, transparent);
}

.plans-section {}
.plans-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:22px; align-items:stretch;
}
.plan-card {
  background:rgba(255,255,255,.036);
  border:1px solid rgba(255,255,255,.10);
  border-radius:var(--radius-xl);
  padding:32px 28px;
  backdrop-filter:blur(10px) saturate(1.2);
  -webkit-backdrop-filter:blur(10px) saturate(1.2);
  box-shadow:0 8px 36px rgba(0,0,0,.3), inset 0 1px 0 rgba(255,255,255,.09);
  position:relative; overflow:hidden;
  transition:transform .35s cubic-bezier(.22,1,.36,1), border-color .3s, box-shadow .3s, background .45s ease;

  display:flex; flex-direction:column;
}
.plan-card::before {
  content:''; position:absolute;
  top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);
}
.plan-card:not(.featured):hover {
  transform:translateY(-5px);
  border-color:rgba(var(--brand-primary-rgb), 0.2);
  box-shadow:0 20px 56px rgba(0,0,0,.38), 0 0 0 1px rgba(var(--brand-primary-rgb), 0.3);
}
.plan-card.featured {
  background:rgba(var(--brand-primary-rgb), 0.1);
  border-color:rgba(var(--brand-primary-rgb), 0.2);
  box-shadow:0 12px 48px rgba(var(--brand-primary-rgb), 0.3), 0 0 0 1px rgba(var(--brand-primary-rgb), 0.3), inset 0 1px 0 rgba(255,255,255,.12);
  animation:borderGlow 3.5s ease-in-out infinite;
  margin-block:-12px;
}
.plan-card.featured::before {
  background:linear-gradient(90deg,transparent,rgba(var(--brand-primary-rgb), 0.15),rgba(var(--brand-accent-rgb,139,92,246),.5),transparent);
}

.featured-badge {
  display:inline-flex; align-items:center; gap:6px;
  padding:4px 12px; border-radius:999px;
  font-size:.68rem; font-weight:800; letter-spacing:.1em;
  background:linear-gradient(135deg,var(--primary),var(--purple));
  color:#fff; margin-bottom:16px;
  box-shadow:0 4px 12px var(--glow-p);
}
.plan-card h3 { font-size:1.1rem; font-weight:800; margin-bottom:6px; }
.plan-desc { font-size:.83rem; color:var(--muted); margin-bottom:0; line-height:1.7; }
.plan-divider {
  height:1px; background:rgba(255,255,255,.07);
  margin:18px 0;
}
.price-block { display:flex; align-items:baseline; gap:6px; flex-wrap:wrap; }
.price {
  font-size:2.5rem; font-weight:900;
  background:linear-gradient(135deg,var(--text),rgba(var(--brand-primary-h-rgb,165,180,252),.85));
  -webkit-background-clip:text; background-clip:text; color:transparent;
  line-height:1;
}
.price-currency { font-size:1.2rem; vertical-align:super; }
.price-period { font-size:.82rem; color:var(--muted); font-weight:600; }
.plan-features {
  display:flex; flex-direction:column; gap:10px;
  margin-bottom:24px;
  flex:1;
}
.plan-features li {
  display:flex; align-items:center; gap:10px;
  font-size:.84rem; color:var(--muted);
}
.feat-icon {
  width:20px; height:20px; border-radius:6px;
  background:rgba(var(--brand-success-rgb), 0.1);
  border:1px solid rgba(var(--brand-success-rgb), 0.2);
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; font-size:.65rem; color:var(--green);
}
.plan-cta {
  display:flex; align-items:center; justify-content:center; gap:8px;
  width:100%; padding:13px; border-radius:14px;
  font-size:.9rem; font-weight:700; cursor:pointer;
  transition:all .25s; border:none;
}
.plan-cta-primary {
  background:linear-gradient(135deg,var(--primary),var(--purple));
  color:#fff;
  box-shadow:0 4px 18px var(--glow-p);
}
.plan-cta-primary:hover { filter:brightness(1.1); transform:translateY(-2px); }
.plan-cta-outline {
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.15) !important;
  color:var(--text);
}
.plan-cta-outline:hover { background:rgba(255,255,255,.10); transform:translateY(-2px); }

.workflow-section { overflow: visible; }

.pipeline {
  display: flex;
  align-items: stretch;
  gap: 0;
  position: relative;
  padding: 20px 0 40px;
}

.pipe-step {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  position: relative;
  min-width: 0;
}

.pipe-connector {
  display: flex;
  align-items: flex-start;
  padding-top: 62px;
  flex-shrink: 0;
  width: 60px;
  position: relative;
}
.pipe-line {
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, rgba(var(--brand-primary-rgb), 0.15), rgba(var(--brand-accent-rgb,139,92,246),.4));
  position: relative;
  overflow: visible;
}

.pipe-dot {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(-50%, -50%);
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--primary);
  box-shadow: 0 0 10px var(--primary), 0 0 20px rgba(var(--brand-primary-rgb), 0.3);
  animation: pipeDotTravel 2.4s ease-in-out infinite;
}
@keyframes pipeDotTravel {
  0%   { left: 0%;   opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { left: 100%; opacity: 0; }
}
[dir="rtl"] .pipe-dot { animation: pipeDotTravelRTL 2.4s ease-in-out infinite; }
@keyframes pipeDotTravelRTL {
  0%   { left: 100%; opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { left: 0%;   opacity: 0; }
}

.pipe-node {
  position: relative;
  width: 88px; height: 88px;
  margin-bottom: 28px;
  flex-shrink: 0;
}

.pipe-node-ring {
  position: absolute; inset: -6px;
  border-radius: 50%;
  border: 2px dashed rgba(var(--brand-primary-rgb), 0.2);
  animation: ringRotate 12s linear infinite;
}
.pipe-step:hover .pipe-node-ring { border-color: rgba(var(--brand-primary-rgb), 0.2); animation-duration: 4s; }

.pipe-node-inner {
  width: 88px; height: 88px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.8rem; color: #fff;
  position: relative; z-index: 1;
  box-shadow: 0 12px 36px rgba(0,0,0,.35);
  transition: transform .4s cubic-bezier(.34,1.56,.64,1), box-shadow .4s;
}
.pipe-step:hover .pipe-node-inner { transform: translateY(-6px) scale(1.08); }

.pipe-num {
  position: absolute;
  top: -6px; inset-inline-start: -6px;
  width: 26px; height: 26px;
  border-radius: 50%;
  background: var(--bg2, #050918);
  border: 2px solid var(--primary);
  color: var(--primary);
  font-size: .65rem; font-weight: 900;
  display: flex; align-items: center; justify-content: center;
  z-index: 2;
  box-shadow: 0 0 12px rgba(var(--brand-primary-rgb), 0.3);
}

.pipe-node--1 .pipe-node-inner {
  background: linear-gradient(135deg, var(--brand-primary), var(--brand-primary-h));
  box-shadow: 0 12px 36px rgba(var(--brand-primary-rgb), 0.3);
}
.pipe-node--2 .pipe-node-inner {
  background: linear-gradient(135deg, var(--brand-secondary), #0e7490);
  box-shadow: 0 12px 36px rgba(var(--brand-secondary-rgb), 0.3);
}
.pipe-node--3 .pipe-node-inner {
  background: linear-gradient(135deg, var(--brand-accent), var(--brand-accent));
  box-shadow: 0 12px 36px rgba(var(--brand-accent-rgb,168,85,247),.45);
}
.pipe-node--4 .pipe-node-inner {
  background: linear-gradient(135deg, var(--brand-success), var(--brand-success));
  box-shadow: 0 12px 36px rgba(var(--brand-success-rgb), 0.3);
}
.pipe-node--1 .pipe-node-ring { border-color: rgba(var(--brand-primary-rgb), 0.2); }
.pipe-node--2 .pipe-node-ring { border-color: rgba(var(--brand-secondary-rgb), 0.2); }
.pipe-node--3 .pipe-node-ring { border-color: rgba(var(--brand-accent-rgb,168,85,247),.35); }
.pipe-node--4 .pipe-node-ring { border-color: rgba(var(--brand-success-rgb), 0.2); }

.pipe-info {
  background: rgba(255,255,255,.038);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: var(--radius-lg);
  padding: 22px 18px 18px;
  backdrop-filter: blur(8px) saturate(1.2);
  -webkit-backdrop-filter: blur(8px) saturate(1.2);
  box-shadow: 0 6px 28px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.08);
  text-align: center;
  width: 100%;
  transition: transform .35s cubic-bezier(.22,1,.36,1), border-color .3s, box-shadow .3s;
}
.pipe-step:hover .pipe-info {
  transform: translateY(-3px);
  border-color: rgba(var(--brand-primary-rgb), 0.2);
  box-shadow: 0 16px 44px rgba(0,0,0,.3), inset 0 1px 0 rgba(255,255,255,.12);
}
.pipe-info h3 {
  font-size: 1rem; font-weight: 800;
  margin-bottom: 8px; color: var(--text);
}
.pipe-info p {
  font-size: .82rem; color: var(--muted);
  line-height: 1.75; margin-bottom: 14px;
}

.pipe-tags {
  display: flex; flex-wrap: wrap; gap: 6px;
  justify-content: center;
}
.pipe-tags span {
  font-size: .7rem; font-weight: 700;
  padding: 3px 10px; border-radius: 999px;
  background: rgba(var(--brand-primary-rgb), 0.1);
  border: 1px solid rgba(var(--brand-primary-rgb), 0.2);
  color: var(--primary2);
  white-space: nowrap;
}

body.light .pipe-info {
  background: rgba(255,255,255,.85) !important;
  border-color: rgba(var(--brand-primary-rgb), 0.2) !important;
  box-shadow: 0 4px 20px rgba(var(--brand-primary-rgb), 0.3) !important;
}
body.light .pipe-info h3 { color: #111827; }
body.light .pipe-info p  { color: #4b5563; }
body.light .pipe-tags span {
  background: rgba(var(--brand-primary-rgb), 0.1);
  border-color: rgba(var(--brand-primary-rgb), 0.2);
  color: var(--primary);
}
body.light .pipe-num {
  background: #f0f2ff;
}

@media (max-width: 900px) {
  .pipeline {
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 10px 0 20px;
  }
  .pipe-step { flex-direction: row; align-items: flex-start; gap: 20px; }
  .pipe-node  { margin-bottom: 0; flex-shrink: 0; }
  .pipe-info  { text-align: start; }
  .pipe-tags  { justify-content: flex-start; }
  .pipe-connector {
    width: 2px; height: 48px;
    padding: 0;
    margin: 4px 0 4px 43px;
    align-items: flex-start;
    flex-direction: column;
  }
  .pipe-line { width: 2px; height: 100%; }
  .pipe-dot {
    top: 0; left: 50%;
    transform: translate(-50%, -50%);
    animation: pipeDotTravelV 2s ease-in-out infinite;
  }
  @keyframes pipeDotTravelV {
    0%   { top: 0%;   opacity: 0; }
    10%  { opacity: 1; }
    90%  { opacity: 1; }
    100% { top: 100%; opacity: 0; }
  }
  [dir="rtl"] .pipe-connector { margin: 4px 43px 4px 0; }
}
@media (max-width: 600px) {
  .pipe-node { width: 70px; height: 70px; }
  .pipe-node-inner { width: 70px; height: 70px; font-size: 1.5rem; }
  .pipe-connector { margin-inline-start: 35px; }
  [dir="rtl"] .pipe-connector { margin-inline-end: 35px; }
}

.faq-section {}
.faq-list { max-width:720px; margin:0 auto; display:flex; flex-direction:column; gap:12px; }
.faq-item {
  background:rgba(255,255,255,.034);
  border:1px solid rgba(255,255,255,.09);
  border-radius:18px;
  backdrop-filter:blur(8px) saturate(1.2);
  overflow:hidden;
  transition:border-color .25s, box-shadow .25s, background .45s ease;
}
.faq-item.open {
  border-color:rgba(var(--brand-primary-rgb), 0.2);
  box-shadow:0 8px 28px rgba(0,0,0,.2), 0 0 0 1px rgba(var(--brand-primary-rgb), 0.3);
}
.faq-q {
  width:100%; display:flex; align-items:center; justify-content:space-between;
  padding:18px 22px; gap:16px;
  font-size:.93rem; font-weight:700; color:var(--text);
  text-align:start; transition:color .25s;
}
.faq-q:hover { color:var(--primary2); }
.faq-q i { color:var(--primary); font-size:.85rem; transition:transform .3s; flex-shrink:0; }
.faq-item.open .faq-q i { transform:rotate(45deg); }
.faq-a { display:none; padding:0 22px 18px; }
.faq-item.open .faq-a { display:block; }
.faq-a p { font-size:.87rem; color:var(--muted); line-height:1.85; }

.footer {
  position:relative; z-index:1;
  margin-top:60px;
  border-top:1px solid rgba(255,255,255,.07);
  background:rgba(4,6,18,.85);
  backdrop-filter:blur(12px);
}
.footer-inner {
  max-width:1240px; margin:0 auto;
  padding:44px clamp(16px,4vw,48px) 28px;
  display:flex; flex-wrap:wrap;
  align-items:center; justify-content:space-between;
  gap:20px;
}
.footer-logo {
  font-size:1.2rem; font-weight:900; letter-spacing:.05em; color:var(--text);
}
.footer-logo span { color:var(--primary); text-shadow:0 0 16px rgba(var(--brand-primary-rgb), 0.35); }

.footer-legal {
  display:flex; flex-wrap:wrap; gap:6px; align-items:center;
}
.footer-legal a {
  padding:6px 14px; border-radius:10px;
  font-size:.78rem; font-weight:700; color:var(--muted);
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.04);
  transition:all .22s;
}
.footer-legal a:hover {
  color:var(--text);
  background:rgba(var(--brand-primary-rgb), 0.1);
  border-color:rgba(var(--brand-primary-rgb), 0.2);
}

.footer-badges {
  display:flex; align-items:center; gap:12px;
}
.footer-badge-ssl {
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 12px; border-radius:10px;
  font-size:.75rem; font-weight:700;
  background:rgba(var(--brand-success-rgb), 0.1);
  border:1px solid rgba(var(--brand-success-rgb), 0.2);
  color:#4ade80;
}
.footer-badge-ssl i { font-size:.8rem; }
.footer-card-icon {
  font-size:1.8rem;
  transition:transform .22s, filter .22s;
}
.footer-card-icon:hover { transform:scale(1.12); filter:brightness(1.2); }
.fa-cc-visa { color:#1a56db; }
.fa-cc-mastercard { color:#eb001b; }

.footer-copy { font-size:.78rem; color:var(--muted); }

.footer-socials { display:flex; gap:8px; }
.footer-socials a {
  width:36px; height:36px; border-radius:10px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.09);
  display:flex; align-items:center; justify-content:center;
  font-size:.9rem; color:var(--muted);
  transition:all .22s;
}
.footer-socials a:hover {
  background:rgba(var(--brand-primary-rgb), 0.1);
  border-color:rgba(var(--brand-primary-rgb), 0.2);
  color:var(--primary2);
  transform:translateY(-2px);
}

.reel-modal {
  display:none; position:fixed; inset:0;
  background:rgba(2,4,14,.88);
  backdrop-filter:blur(22px) saturate(1.6);
  z-index:2000; align-items:center; justify-content:center;
}
.reel-modal.open { display:flex; }
.modal-close {
  position:absolute; top:20px; inset-inline-end:20px;
  width:42px; height:42px; border-radius:12px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);
  color:var(--text); font-size:.95rem;
  display:flex; align-items:center; justify-content:center;
  transition:background .2s, transform .2s;
  z-index:10;
}
.modal-close:hover { background:rgba(255,255,255,.13); transform:scale(1.06); }

#modalMediaWrap {
  max-width: 95vw;
  max-height: 90vh;
  border-radius: 22px;
  overflow: hidden;
  background: #000;
  box-shadow: 0 30px 80px rgba(0,0,0,.55), 0 0 0 1px rgba(255,255,255,.08);
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;

  aspect-ratio: 9 / 16;
  height: 90vh;
}

#modalMediaWrap[data-ratio] {
  aspect-ratio: var(--media-ratio, 9 / 16);
  height: auto;
  max-height: 90vh;
}
#modalMediaWrap video,
#modalMediaWrap img {
  width: 100%;
  height: 100%;

  object-fit: contain;
  display: block;
  background: #000;
}

.reel-card video,
.reel-card img { object-fit: cover; }

.auth-modal {
  display:none; position:fixed; inset:0; z-index:1800;
  align-items:center; justify-content:center;
  padding:16px;
  background:rgba(2,4,14,.75);
  backdrop-filter:blur(24px) saturate(1.8);
}
.auth-modal.open { display:flex; }
.auth-modal-box {
  width:100%; max-width:460px;
  background:rgba(7,10,28,.88);
  backdrop-filter:blur(48px) saturate(2);
  -webkit-backdrop-filter:blur(48px) saturate(2);
  border:1px solid rgba(255,255,255,.13);
  border-radius:var(--radius-xl);
  padding:clamp(24px,4vw,40px);
  box-shadow:
    0 40px 100px rgba(0,0,0,.6),
    inset 0 1px 0 rgba(255,255,255,.14),
    0 0 0 1px rgba(var(--brand-primary-rgb), 0.15);
  position:relative; overflow:hidden;
  animation:scaleIn .3s var(--tr-bounce);
}

.auth-modal-box::before {
  content:'';
  position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(var(--brand-primary-rgb), 0.15),rgba(var(--brand-accent-rgb,139,92,246),.5),transparent);
}

.auth-modal-box::after {
  content:'';
  position:absolute; top:-60px; left:50%; transform:translateX(-50%);
  width:280px; height:280px;
  background:radial-gradient(circle,rgba(var(--brand-primary-rgb), 0.1) 0%,transparent 65%);
  pointer-events:none;
}

.auth-modal-close {
  position:absolute; top:16px; inset-inline-end:16px;
  width:34px; height:34px; border-radius:10px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  color:var(--muted); font-size:.8rem;
  display:flex; align-items:center; justify-content:center;
  transition:all .2s; z-index:10;
}
.auth-modal-close:hover { background:rgba(255,255,255,.1); color:var(--text); }

.auth-tabs {
  display:flex; gap:4px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px; padding:4px;
  margin-bottom:28px; position:relative; z-index:1;
}
.auth-tab {
  flex:1; padding:9px; border-radius:11px;
  font-size:.85rem; font-weight:700; color:var(--muted);
  transition:all .25s;
}
.auth-tab.active {
  background:linear-gradient(135deg,var(--primary),var(--purple));
  color:#fff;
  box-shadow:0 3px 12px var(--glow-p);
}

.auth-pane { display:none; position:relative; z-index:1; }
.auth-pane.active { display:block; }
.auth-pane h2 {
  font-size:1.3rem; font-weight:900;
  margin-bottom:6px;
}
.auth-pane p { font-size:.84rem; color:var(--muted); margin-bottom:22px; }

.input-group { display:flex; flex-direction:column; gap:7px; margin-bottom:14px; }
.input-group label { font-size:.78rem; font-weight:700; color:rgba(255,255,255,.5); }
.input-wrap {
  position:relative; display:flex; align-items:center;
}
.input-wrap > i {
  position:absolute; inset-inline-start:14px;
  color:var(--muted); font-size:.85rem; pointer-events:none;
}
.input-wrap input {
  width:100%; padding:11px 14px 11px 40px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.10);
  border-radius:12px; color:var(--text); font-size:.9rem;
  backdrop-filter:blur(8px);
  transition:border-color var(--tr), background var(--tr), box-shadow var(--tr);
  outline:none;
}
[dir="rtl"] .input-wrap input { padding:11px 40px 11px 14px; }
.input-wrap input::placeholder { color:rgba(255,255,255,.25); }
.input-wrap input:focus {
  border-color:var(--primary);
  background:rgba(var(--brand-primary-rgb), 0.1);
  box-shadow:0 0 0 3px rgba(var(--brand-primary-rgb), 0.3);
}
.input-wrap.error input { border-color:var(--secondary); }

.auth-submit {
  width:100%; justify-content:center;
  padding:13px; border-radius:13px; font-size:.95rem;
  margin-top:6px;
}

.auth-terms {
  display:flex; align-items:flex-start; gap:10px;
  margin-bottom:14px; font-size:.8rem; color:var(--muted);
}
.auth-terms input[type="checkbox"] {
  width:16px; height:16px; margin-top:1px; flex-shrink:0;
  accent-color:var(--primary);
}
.auth-terms a { color:var(--primary2); text-decoration:underline; }
.auth-error {
  padding:8px 14px; border-radius:10px;
  background:rgba(248,113,113,.08);
  border:1px solid rgba(248,113,113,.2);
  color:#f87171; font-size:.82rem; text-align:center;
  margin-top:8px;
}

.check-email-panel {
  text-align:center; display:flex; flex-direction:column;
  align-items:center; gap:14px; padding:10px 0;
  position:relative; z-index:1;
}
.check-email-panel .email-icon {
  width:72px; height:72px; border-radius:50%;
  background:rgba(var(--brand-primary-rgb), 0.1);
  border:1px solid rgba(var(--brand-primary-rgb), 0.2);
  display:flex; align-items:center; justify-content:center;
  font-size:1.8rem; color:var(--primary2);
  animation:glowPulse 2.5s ease-in-out infinite;
}
.check-email-panel h3 { font-size:1.1rem; font-weight:800; }
.check-email-panel p { font-size:.86rem; color:var(--muted); line-height:1.8; max-width:340px; }
.resend-btn {
  padding:10px 24px; border-radius:12px;
  font-size:.86rem; font-weight:700; color:var(--primary2);
  border:1px solid rgba(var(--brand-primary-rgb), 0.2);
  background:rgba(var(--brand-primary-rgb), 0.1);
  transition:all .25s;
}
.resend-btn:hover {
  background:rgba(var(--brand-primary-rgb), 0.1);
  border-color:rgba(var(--brand-primary-rgb), 0.2);
  transform:translateY(-1px);
}

.pay-modal {
  display:none; position:fixed; inset:0; z-index:1900;
  align-items:center; justify-content:center;
  padding:16px;
}
.pay-modal.open { display:flex; }
.pay-modal-bg {
  position:absolute; inset:0;
  background:rgba(2,4,14,.8);
  backdrop-filter:blur(28px) saturate(1.8);
}
.pay-modal-box {
  position:relative; z-index:1;
  width:100%; max-width:480px;
  background:rgba(7,10,28,.9);
  backdrop-filter:blur(52px) saturate(2);
  -webkit-backdrop-filter:blur(52px) saturate(2);
  border:1px solid rgba(255,255,255,.13);
  border-radius:var(--radius-xl);
  padding:clamp(22px,4vw,36px);
  box-shadow:
    0 48px 120px rgba(0,0,0,.65),
    inset 0 1px 0 rgba(255,255,255,.16),
    0 0 0 1px rgba(var(--brand-primary-rgb), 0.15);
  overflow:hidden;
  max-height:90vh; overflow-y:auto;
  animation:scaleIn .3s var(--tr-bounce);
}
.pay-modal-box::before {
  content:'';
  position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(var(--brand-primary-rgb), 0.15),rgba(var(--brand-accent-rgb,139,92,246),.5),transparent);
}
.pay-modal-box::after {
  content:'';
  position:absolute; top:-80px; left:50%; transform:translateX(-50%);
  width:320px; height:320px;
  background:radial-gradient(circle,rgba(var(--brand-primary-rgb), 0.1) 0%,transparent 65%);
  pointer-events:none;
}
.pay-modal-close {
  position:absolute; top:16px; inset-inline-end:16px;
  width:36px; height:36px; border-radius:11px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.11);
  color:var(--muted); font-size:.85rem;
  display:flex; align-items:center; justify-content:center;
  transition:all .2s; z-index:10;
}
.pay-modal-close:hover { background:rgba(255,255,255,.12); color:var(--text); }

.pay-modal-head { text-align:center; margin-bottom:20px; position:relative; z-index:1; }
.pay-plan-badge {
  display:inline-flex; padding:4px 12px; border-radius:999px;
  font-size:.68rem; font-weight:800; letter-spacing:.1em;
  background:rgba(var(--brand-primary-rgb), 0.1);
  border:1px solid rgba(var(--brand-primary-rgb), 0.2);
  color:var(--primary2); margin-bottom:8px;
}
.pay-modal-head h3 { font-size:1.15rem; font-weight:800; margin-bottom:4px; }
.pay-plan-price {
  font-size:1.6rem; font-weight:900;
  background:linear-gradient(135deg,var(--text),var(--primary2));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

.cc-scene { width:100%; height:180px; perspective:1000px; margin-bottom:22px; position:relative; z-index:1; }
.cc-card {
  width:100%; height:100%;
  position:relative; transform-style:preserve-3d;
  transition:transform .7s cubic-bezier(.4,0,.2,1);
}
.cc-card.flipped { transform:rotateY(180deg); }
.cc-front,.cc-back {
  position:absolute; inset:0;
  border-radius:18px; padding:18px 20px;
  backface-visibility:hidden;
  display:flex; flex-direction:column; justify-content:space-between;
}
.cc-front {
  background:linear-gradient(135deg,
    color-mix(in srgb, var(--brand-primary) 75%, #000 25%) 0%,
    color-mix(in srgb, var(--brand-accent)  60%, #000 40%) 50%,
    color-mix(in srgb, var(--brand-secondary) 70%, #000 30%) 100%);
  border:1px solid rgba(255,255,255,.2);
  box-shadow:0 20px 60px rgba(0,0,0,.55);
}
.cc-back {
  background:linear-gradient(135deg,
    color-mix(in srgb, var(--brand-primary) 70%, #000 30%) 0%,
    color-mix(in srgb, var(--brand-accent)  55%, #000 45%) 45%,
    color-mix(in srgb, var(--brand-secondary) 65%, #000 35%) 100%);
  border:1px solid rgba(255,255,255,.18);
  transform:rotateY(180deg);
  box-shadow:0 20px 60px rgba(0,0,0,.55);
}
.cc-front-top { display:flex; align-items:center; justify-content:space-between; }
.cc-logo-text { font-size:.7rem; font-weight:900; letter-spacing:.08em; color:rgba(255,255,255,.5); }
.cc-network { font-size:2rem; color:#fff; }
.cc-network .fa-cc-visa       { color:#1a1f71; filter:drop-shadow(0 0 6px rgba(255,255,255,.6)); }
.cc-network .fa-cc-mastercard { color:#eb001b; filter:drop-shadow(0 0 6px rgba(235,0,27,.5)); }
.cc-network .fa-cc-amex       { color:#2e77bc; filter:drop-shadow(0 0 6px rgba(46,119,188,.6)); }
.cc-network .fa-cc-discover   { color:#e65c00; filter:drop-shadow(0 0 6px rgba(230,92,0,.5)); }
.cc-network .fa-cc-jcb        { color:#003087; filter:drop-shadow(0 0 6px rgba(255,255,255,.4)); }
.cc-chip {
  width:40px; height:30px; border-radius:5px;
  background:linear-gradient(135deg,#c8a96e,#f0d090,#c8a96e);
  border:1px solid rgba(255,255,255,.3);
  display:grid; grid-template-columns:1fr 1fr; grid-template-rows:1fr 1fr;
  gap:2px; padding:4px;
  box-shadow:0 2px 8px rgba(0,0,0,.4);
}
.cc-chip>div { background:rgba(180,140,60,.5); border-radius:2px; }
.cc-num {
  font-size:1.1rem; font-weight:700; letter-spacing:.14em; color:#fff;
  text-shadow:0 1px 4px rgba(0,0,0,.5);
  font-variant-numeric:tabular-nums;
}
.cc-bottom { display:flex; align-items:flex-end; gap:20px; }
.cc-label { font-size:.55rem; letter-spacing:.1em; color:rgba(255,255,255,.45); margin-bottom:3px; }
.cc-val { font-size:.82rem; font-weight:700; color:#fff; letter-spacing:.05em; white-space:nowrap; overflow:hidden; max-width:140px; text-overflow:ellipsis; }
.cc-mag-strip { height:38px; background:#111; margin:-1px 0 16px; }
.cc-sig-row { display:flex; align-items:center; gap:10px; padding:0 20px; }
.cc-sig-lines { flex:1; height:32px; background:repeating-linear-gradient(#fff 0,#fff 3px,rgba(200,200,200,.4) 3px,rgba(200,200,200,.4) 6px); border-radius:3px; }
.cc-cvv-box { background:#fff; border-radius:5px; padding:4px 12px; min-width:52px; text-align:center; }
.cc-cvv-box .cc-label { color:#333; }
.cc-cvv-box .cc-val { color:#111; font-size:.9rem; }
.cc-network-back { padding:8px 20px 0; text-align:right; font-size:1.6rem; color:rgba(255,255,255,.4); }

.pay-form { display:flex; flex-direction:column; gap:14px; position:relative; z-index:1; }
.pay-field-group { display:flex; flex-direction:column; gap:6px; }
.pay-field-group label { font-size:.78rem; font-weight:700; color:rgba(255,255,255,.5); }
.pay-field-wrap { position:relative; display:flex; align-items:center; }
.pay-field-wrap>i { position:absolute; left:14px; color:var(--muted); font-size:.85rem; pointer-events:none; }
[dir="rtl"] .pay-field-wrap>i { left:auto; right:14px; }
.pay-field-wrap input {
  width:100%; padding:11px 14px 11px 38px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.10);
  border-radius:12px; color:var(--text); font-size:.9rem;
  backdrop-filter:blur(8px);
  transition:border-color var(--tr), background var(--tr), box-shadow var(--tr);
  outline:none;
}
[dir="rtl"] .pay-field-wrap input { padding:11px 38px 11px 14px; }
.pay-field-wrap input::placeholder { color:rgba(255,255,255,.25); }
.pay-field-wrap input:focus { border-color:var(--primary); background:rgba(var(--brand-primary-rgb), 0.3); box-shadow:0 0 0 3px rgba(var(--brand-primary-rgb), 0.3); }
.pay-field-wrap.error input { border-color:var(--secondary); }
.pay-network-inline { position:absolute; right:12px; font-size:1.3rem; color:#fff; pointer-events:none; }
[dir="rtl"] .pay-network-inline { right:auto; left:12px; }
.pay-row-2 { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.pay-submit-btn { width:100%; justify-content:center; padding:14px; border-radius:14px; font-size:.95rem; margin-top:4px; position:relative; z-index:1; }
.pay-submit-btn.loading { opacity:.7; pointer-events:none; }

.pay-accepted-row {
  display:flex; align-items:center; justify-content:center; gap:10px;
  font-size:.72rem; color:var(--muted); margin-top:10px;
  position:relative; z-index:1;
}
.pay-accepted-brands { display:flex; align-items:center; gap:8px; font-size:1.5rem; }
.pay-accepted-brands .fa-cc-visa       { color:#1a1f71; }
.pay-accepted-brands .fa-cc-mastercard { color:#eb001b; }
.pay-accepted-brands .fa-cc-amex       { color:#006fcf; }
body.light .pay-accepted-brands .fa-cc-visa { color:#1a1f71; }

.pay-otp-step {
  display:none; flex-direction:column; gap:14px;
  position:relative; z-index:1;
  animation:fadeUp .3s ease both;
}
.pay-otp-step.show { display:flex; }

.pay-otp-bank {
  display:flex; align-items:center; gap:10px;
  padding:12px 14px; border-radius:14px;
  background:linear-gradient(135deg,rgba(var(--brand-primary-rgb), 0.15),rgba(var(--brand-secondary-rgb), 0.15));
  border:1px solid rgba(var(--brand-primary-rgb), 0.2);
  font-size:.82rem; font-weight:800; color:var(--text);
}
.pay-otp-bank i { font-size:1.15rem; color:var(--primary2); }

.pay-otp-cardline {
  display:flex; align-items:center; gap:10px;
  padding:11px 14px; border-radius:12px;
  background:var(--glass); border:1px solid var(--gborder);
  font-size:.82rem; font-weight:700; color:var(--text);
}
.pay-otp-cardline i { font-size:1.4rem; }
.pay-otp-cardline .fa-cc-visa       { color:#1a1f71; }
.pay-otp-cardline .fa-cc-mastercard { color:#eb001b; }
.pay-otp-cardline .fa-cc-amex       { color:#006fcf; }
.pay-otp-cardline strong { margin-inline-start:auto; font-size:1rem; color:var(--primary2); }

.pay-otp-msg { font-size:.82rem; color:var(--muted); line-height:1.8; margin:0; }

.pay-otp-demo {
  display:flex; align-items:center; gap:8px; flex-wrap:wrap;
  padding:10px 14px; border-radius:12px;
  background:rgba(var(--brand-warning-rgb), 0.2); border:1px dashed rgba(var(--brand-warning-rgb), 0.2);
  font-size:.74rem; color:#fcd34d;
}
.pay-otp-demo b {
  font-size:1.05rem; letter-spacing:3px; color:var(--brand-warning);
  font-family:'Courier New',monospace;
}
body.light .pay-otp-demo { color:#92400e; }
body.light .pay-otp-demo b { color:#b45309; }

.pay-otp-inputs {
  display:flex; gap:10px; justify-content:center; margin:4px 0; direction:ltr;
}
.pay-otp-box {
  width:46px; height:56px; text-align:center;
  font-size:1.5rem; font-weight:900;
  border-radius:12px;
  background:rgba(255,255,255,.05);
  border:2px solid var(--gborder);
  color:var(--text);
  transition:border-color .15s, box-shadow .15s, transform .15s;
}
.pay-otp-box:focus {
  outline:none; border-color:var(--primary);
  box-shadow:0 0 0 4px rgba(var(--brand-primary-rgb), 0.3);
  transform:translateY(-2px);
}
body.light .pay-otp-box { background:#fff; color:#111827; border-color:rgba(0,0,0,.14); }

.pay-otp-timer { font-size:.76rem; color:var(--muted); text-align:center; font-weight:700; }

.pay-otp-error {
  font-size:.78rem; color:#f87171; text-align:center;
  padding:8px 12px; border-radius:10px;
  background:rgba(248,113,113,.1); border:1px solid rgba(248,113,113,.25);
  font-weight:700;
}

.pay-otp-actions { display:flex; gap:10px; }
.pay-otp-actions button { flex:1; justify-content:center; padding:13px; border-radius:14px; font-size:.9rem; }
.btn-ghost {
  background:var(--glass); border:1px solid var(--gborder);
  color:var(--text); cursor:pointer; font-weight:700;
  transition:background .2s, border-color .2s;
}
.btn-ghost:hover { background:var(--glass-md); border-color:var(--gborder-hi); }
.pay-secure-note {
  text-align:center; font-size:.75rem; color:var(--muted);
  display:flex; align-items:center; justify-content:center; gap:6px;
  margin-top:12px; position:relative; z-index:1;
}
.pay-secure-note i { color:var(--green); }
.pay-success {
  display:none; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; gap:16px; padding:20px 0; position:relative; z-index:1;
}
.pay-success.show { display:flex; }
.pay-success-icon {
  width:72px; height:72px; border-radius:50%;
  background:linear-gradient(135deg,var(--brand-success),var(--brand-success));
  display:flex; align-items:center; justify-content:center;
  font-size:1.9rem; color:#fff;
  box-shadow:0 0 36px rgba(var(--brand-success-rgb), 0.3);
  animation:successPop .5s cubic-bezier(.34,1.56,.64,1);
}
.pay-success h3 { font-size:1.1rem; font-weight:800; color:var(--text); }
.pay-success p { font-size:.88rem; color:var(--muted); }
.pay-cards-row {
  display:flex; align-items:center; justify-content:center; gap:12px;
  margin-top:16px; font-size:1.7rem; position:relative; z-index:1;
}
.pay-cards-row .fa-cc-visa { color:#1a56db; }
.pay-cards-row .fa-cc-mastercard { color:#eb001b; }
.pay-cards-row .fa-cc-amex { color:#2e77bc; }
.pay-cards-row .fa-cc-discover { color:#e65c00; }

.fade-up { opacity:0; transform:translateY(32px); transition:opacity .7s ease, transform .7s cubic-bezier(.22,1,.36,1); }
.fade-up[data-d="0"]{ transition-delay:.05s }
.fade-up[data-d="1"]{ transition-delay:.12s }
.fade-up[data-d="2"]{ transition-delay:.20s }
.fade-up[data-d="3"]{ transition-delay:.30s }
.fade-up[data-d="4"]{ transition-delay:.40s }
.fade-up[data-d="5"]{ transition-delay:.50s }
.fade-up.show { opacity:1; transform:translateY(0); }

.reveal       { opacity:0; transform:translateY(30px);  transition:opacity .7s ease, transform .7s cubic-bezier(.22,1,.36,1); }
.reveal-left  { opacity:0; transform:translateX(-30px); transition:opacity .7s ease, transform .7s cubic-bezier(.22,1,.36,1); }
.reveal-right { opacity:0; transform:translateX(30px);  transition:opacity .7s ease, transform .7s cubic-bezier(.22,1,.36,1); }
.reveal-scale { opacity:0; transform:scale(.93);        transition:opacity .65s ease, transform .65s cubic-bezier(.22,1,.36,1); }
.reveal.show,.reveal-left.show,.reveal-right.show,.reveal-scale.show { opacity:1; transform:none; }
.reveal[data-d="1"],.reveal-left[data-d="1"],.reveal-right[data-d="1"],.reveal-scale[data-d="1"] { transition-delay:.07s }
.reveal[data-d="2"],.reveal-left[data-d="2"],.reveal-right[data-d="2"],.reveal-scale[data-d="2"] { transition-delay:.14s }
.reveal[data-d="3"],.reveal-left[data-d="3"],.reveal-right[data-d="3"],.reveal-scale[data-d="3"] { transition-delay:.21s }
.reveal[data-d="4"],.reveal-left[data-d="4"],.reveal-right[data-d="4"],.reveal-scale[data-d="4"] { transition-delay:.28s }

.card-appear { animation:cardAppear .5s ease both; }

@media (max-width: 1024px) {

  .plans-grid { grid-template-columns: repeat(auto-fit,minmax(260px,1fr)); max-width: 520px; margin-inline: auto; }
  .plan-card.featured { margin-block: 0; }

  .ai-wrap { grid-template-columns:1fr; }
  .ai-visual { order:-1; min-height:260px; }
  .ai-ring.r1 { width:240px; height:240px; }
  .ai-ring.r2 { width:172px; height:172px; }
  .ai-ring.r3 { width:114px; height:114px; }
  .ai-core { width:70px; height:70px; font-size:.82rem; }
  .reels-grid { grid-template-columns:repeat(4,1fr); gap:10px; }
}

@media (max-width: 1024px) {

  .nav-links, .nav-cta, .btn-login { display:none !important; }
  .hamburger { display:flex !important; }
}

@media (max-width: 768px) {

  .btn-currency { display:none !important; }
  .nav { padding: 0 14px; gap: 8px; height: 56px; top: 10px; }
  .nav-logo { font-size: 1rem !important; }
  .nav-right { gap: 6px; }
  .btn-theme, .btn-lang {
    width: 36px !important; height: 36px !important;
    padding: 0 !important; min-width: 36px;
  }


  .hero-inner { grid-template-columns:1fr; gap:36px; text-align:center; }
  .hero-left { align-items:center; }
  .hero-p { text-align:center; margin-inline:auto; }
  .hero-stats { justify-content:center; }
  .hero-actions { justify-content:center; }
  .hero-right { padding:14px; }
  .hcard { max-width:340px; padding:20px; }
  .hcard-deco { display:none; }


  .section-head:not(.center) { flex-direction:column; align-items:flex-start; gap:14px; }

  .footer-inner { flex-direction:column; align-items:center; text-align:center; }
  .pay-row-2 { grid-template-columns:1fr; }
  .reels-grid { grid-template-columns:repeat(3,1fr); gap:8px; }
  .designs-grid { grid-template-columns:repeat(2,1fr); }
}

@media (max-width: 480px) {
  .hero-h1 { font-size:2rem; }
  .cc-scene { height:175px; }
  .cc-num { font-size:.96rem; letter-spacing:.1em; }
  .pay-modal-box { padding:22px 16px 18px; }
  .designs-grid { grid-template-columns:1fr; }

  .nav { padding: 0 10px; gap: 6px; height: 52px; }
  .nav-logo { font-size: 0.92rem !important; letter-spacing: 0.03em !important; }
  .btn-theme, .btn-lang, .hamburger {
    width: 34px !important; height: 34px !important;
  }
}

.mobile-quick-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
  gap: 8px;
  margin: 4px 0;
}
.mobile-quick-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 12px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 12px;
  color: var(--text);
  font: inherit;
  font-size: 0.85rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
}
body.light .mobile-quick-btn {
  background: rgba(0,0,0,0.04);
  border-color: rgba(0,0,0,0.1);
  color: #1f2937;
}
.mobile-quick-btn i {
  color: var(--brand-primary);
  font-size: 0.95rem;
}
.mobile-quick-btn:hover {
  background-color: rgba(var(--brand-primary-rgb), 0.12);
  border-color: var(--brand-primary);
}

@media (max-width: 380px) {
  .btn-lang { display:none !important; }
  .nav { padding:0 8px; gap:4px; }
  .nav-logo { font-size: 0.85rem !important; }
}

@media (max-width: 340px) {
  .btn-theme { display:none !important; }
  .nav-logo { font-size: 0.8rem !important; }
}

body.ltr { direction:ltr; }

.currency-switch-wrap {
  display: flex;
  justify-content: center;
  margin: 0 0 22px;
}
.currency-switch-btn {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 10px 24px;
  background: rgba(var(--brand-primary-rgb), 0.1);
  border: 1.5px solid rgba(var(--brand-primary-rgb), 0.2);
  border-radius: 100px;
  color: var(--brand-primary-h);
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: all .25s;
  font-family: inherit;
  letter-spacing: .02em;
}
.currency-switch-btn:hover {
  background: rgba(var(--brand-primary-rgb), 0.1);
  border-color: rgba(var(--brand-primary-rgb), 0.2);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(var(--brand-primary-rgb), 0.3);
}
.currency-switch-btn i { font-size: 15px; }

.plans-slider {
  display: flex !important;
  flex-direction: row;
  flex-wrap: nowrap;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  gap: 20px;
  padding: 24px 16px 36px;
  -ms-overflow-style: none;
  scrollbar-width: none;
  align-items: stretch;
}
.plans-slider::-webkit-scrollbar { display: none; }
.plans-slider .plan-card {
  scroll-snap-align: center;
  flex: 0 0 300px;
  min-width: 260px;
  margin-block: 0 !important;
}
.plans-slider .plan-card.featured {

  transform: scale(1.025);
  box-shadow: 0 16px 52px rgba(var(--brand-primary-rgb), 0.3), 0 0 0 1.5px rgba(var(--brand-primary-rgb), 0.3);
}
.plans-nav-wrap {
  display: flex;
  justify-content: center;
  gap: 14px;
  margin-top: 16px;
}
.plans-nav-btn {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: rgba(var(--brand-primary-rgb), 0.1);
  border: 1.5px solid rgba(var(--brand-primary-rgb), 0.2);
  color: var(--brand-primary-h);
  font-size: 15px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .2s;
  font-family: inherit;
}
.plans-nav-btn:hover {
  background: rgba(var(--brand-primary-rgb), 0.1);
  transform: scale(1.08);
  box-shadow: 0 4px 16px rgba(var(--brand-primary-rgb), 0.3);
}

@media (max-width: 768px) {

  #plansGrid {
    margin-inline: calc(-1 * clamp(16px, 4vw, 48px)) !important;
    width: 100vw !important;
    max-width: 100vw !important;
    box-sizing: border-box;
  }

  #plansGrid:not(.plans-slider) {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    scroll-snap-type: x mandatory !important;
    scroll-behavior: smooth !important;
    gap: 16px !important;
    padding: 12px 20px 24px !important;
    -ms-overflow-style: none !important;
    scrollbar-width: none !important;
    align-items: stretch !important;
  }
  #plansGrid:not(.plans-slider)::-webkit-scrollbar { display: none; }
  #plansGrid:not(.plans-slider) .plan-card {
    scroll-snap-align: center !important;
    flex: 0 0 80vw !important;
    max-width: 320px !important;
    min-width: 230px !important;
    margin-block: 0 !important;
  }

  .plans-slider {
    padding: 12px 20px 24px !important;
    gap: 16px !important;
  }
  .plans-slider .plan-card {
    flex: 0 0 80vw !important;
    max-width: 320px !important;
    min-width: 230px !important;
    transform: none !important;
    margin-block: 0 !important;
  }
  .plans-slider .plan-card.featured {
    transform: none !important;
    box-shadow: 0 8px 32px rgba(var(--brand-primary-rgb), 0.3) !important;
  }

  .plans-nav-wrap { display: none !important; }
}

@media (prefers-reduced-motion: reduce) {

  .bg-orb, body::before, .grid-overlay {
    animation: none !important;
    transition: none !important;
  }
  .bg-orb.o3, .bg-orb.o4 { display: none; }
}


.reel-card .reel-fallback {
  position: absolute; inset: 0;
  display: grid; place-items: center;
  background: linear-gradient(135deg, rgba(99,102,241,.18), rgba(236,72,153,.10));
  color: rgba(255,255,255,.35);
  font-size: 2.2rem;
  border-radius: inherit;
  z-index: 0;
}
body.light .reel-card .reel-fallback {
  background: linear-gradient(135deg, rgba(99,102,241,.10), rgba(236,72,153,.06));
  color: rgba(31,41,55,.35);
}

.reel-card { position: relative; isolation: isolate; }
.reel-card .reel-poster {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; border-radius: inherit;
  z-index: 1;
}
.reel-card .reel-preview-video {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; border-radius: inherit;
  z-index: 2;
  opacity: 0;
  transition: opacity .35s ease;
  pointer-events: none;
}
.reel-card .reel-preview-video.is-ready { opacity: 1; }
.reel-card .reel-overlay { z-index: 3; }
.reel-card .reel-play   { z-index: 4; }
.reel-card .reel-label  { z-index: 5; }

.cine-modal-spinner {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  background: rgba(0,0,0,0.4);
  z-index: 5;
}
.cine-modal-spinner-ring {
  width: 56px; height: 56px;
  border-radius: 50%;
  border: 3px solid rgba(255,255,255,0.15);
  border-top-color: rgba(var(--brand-primary-rgb, 99,102,241), 0.95);
  animation: tmSpin 0.9s linear infinite;
}
@keyframes tmSpin { to { transform: rotate(360deg); } }

.cine-modal-empty {
  position: absolute; inset: 0;
  display: grid; place-items: center;
  gap: 14px;
  color: rgba(255,255,255,0.55);
  font-size: 16px;
  text-align: center;
}
.cine-modal-empty i { font-size: 48px; color: rgba(255,255,255,0.35); }
