/* ==============================================
   Asira — Visual Enhancement Layer (v2)
   Glassmorphism · Animated Gradients · Glows
============================================== */

/* === Animated background orbs === */
@keyframes orbFloat1 {
  0%,100% { transform: translate(0,0) scale(1); }
  50%     { transform: translate(40px,-30px) scale(1.08); }
}
@keyframes orbFloat2 {
  0%,100% { transform: translate(0,0) scale(1); }
  50%     { transform: translate(-30px,40px) scale(1.12); }
}
@keyframes orbFloat3 {
  0%,100% { transform: translate(0,0); }
  50%     { transform: translate(20px,20px); }
}
@keyframes shine {
  0%   { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}
@keyframes gridDrift {
  0%   { background-position: 0 0; }
  100% { background-position: 60px 60px; }
}
@keyframes sparkle {
  0%,100% { opacity:.3; transform: scale(.7); }
  50%     { opacity: 1;  transform: scale(1.2); }
}

/* Hero atmosphere — replaces flat backgrounds with depth */
.hero-atmosphere {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 0;
}
.hero-atmosphere::before,
.hero-atmosphere::after,
.hero-atmosphere .orb-c {
  content: '';
  position: absolute;
  border-radius: 50%;
  filter: blur(70px);
}
.hero-atmosphere::before {
  width: 560px; height: 560px;
  background: radial-gradient(circle, rgba(26,163,154,.35) 0%, transparent 70%);
  top: -180px; right: -120px;
  animation: orbFloat1 14s ease-in-out infinite;
}
.hero-atmosphere::after {
  width: 480px; height: 480px;
  background: radial-gradient(circle, rgba(87,108,188,.32) 0%, transparent 70%);
  bottom: -160px; left: -80px;
  animation: orbFloat2 16s ease-in-out infinite;
}
.hero-atmosphere .orb-c {
  width: 360px; height: 360px;
  background: radial-gradient(circle, rgba(165,215,232,.45) 0%, transparent 70%);
  top: 30%; left: 40%;
  animation: orbFloat3 18s ease-in-out infinite;
}
.hero-atmosphere .grid-overlay {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(11,36,71,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(11,36,71,.04) 1px, transparent 1px);
  background-size: 60px 60px;
  mask-image: radial-gradient(ellipse 70% 60% at 50% 40%, #000 30%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse 70% 60% at 50% 40%, #000 30%, transparent 80%);
  animation: gridDrift 30s linear infinite;
}

/* Glass card */
.glass {
  background: rgba(255,255,255,.65);
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  border: 1px solid rgba(255,255,255,.85);
  box-shadow:
    0 1px 0 rgba(255,255,255,.9) inset,
    0 30px 60px -20px rgba(11,36,71,.18);
  border-radius: 24px;
}
.glass-dark {
  background: linear-gradient(135deg, rgba(11,36,71,.92), rgba(25,55,109,.88));
  backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,.10);
  color: #fff;
  box-shadow: 0 30px 80px rgba(11,36,71,.30);
  border-radius: 24px;
}

/* Sparkles (use within hero / spacea) */
.sparkle {
  position: absolute;
  width: 6px; height: 6px;
  background: radial-gradient(circle, #fff, transparent 70%);
  border-radius: 50%;
  animation: sparkle 2.4s ease-in-out infinite;
}
.sparkle.s1 { top: 12%; right: 18%; animation-delay: 0s; }
.sparkle.s2 { top: 30%; left: 8%;  animation-delay: .6s; width:8px; height:8px; }
.sparkle.s3 { bottom: 22%; right: 30%; animation-delay: 1.2s; }
.sparkle.s4 { bottom: 40%; left: 22%; animation-delay: 1.8s; width:5px; height:5px; }

/* Improved hero stat */
.stat-pill {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 10px 16px;
  background: rgba(255,255,255,.75);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(11,36,71,.06);
  border-radius: 999px;
  box-shadow: var(--shadow-xs);
  font-size: 13px;
  font-weight: 600;
  color: var(--asira-navy);
}
.stat-pill .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--asira-teal);
  box-shadow: 0 0 0 4px rgba(26,163,154,.15);
  animation: sparkle 2s ease-in-out infinite;
}

/* Trust strip — small icon + label */
.trust-strip {
  display: flex; flex-wrap: wrap; gap: 22px 32px;
  margin-top: 30px;
  padding: 18px 22px;
  background: rgba(255,255,255,.55);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(11,36,71,.05);
  border-radius: 18px;
}
.trust-item {
  display: flex; align-items: center; gap: 10px;
  font-size: 13px; color: var(--text-2);
  font-weight: 500;
}
.trust-item svg { color: var(--asira-teal); }

/* Card upgrades */
.card, .service-card, .feature-card, .pp-card, .pkg-card, .panel, .testimonial, .project-card {
  position: relative;
}
.service-card::after,
.pp-card::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg, transparent 60%, rgba(26,163,154,.5));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  opacity: 0;
  transition: opacity .3s ease;
  pointer-events: none;
}
.service-card:hover::after,
.pp-card:hover::after { opacity: 1; }

.service-card { box-shadow: 0 1px 0 rgba(11,36,71,.03); }
.service-card .icon {
  background: linear-gradient(135deg, #1AA39A 0%, #19376D 100%);
  color: #fff;
  box-shadow: 0 12px 24px -10px rgba(26,163,154,.45);
}

.pp-card .pp-icon {
  background: linear-gradient(135deg, #6E3FF3 0%, #3B1F8B 100%);
  color: #fff;
  box-shadow: 0 12px 24px -10px rgba(110,63,243,.45);
}

/* Section dividers with shine */
.section-divider {
  position: relative;
  text-shadow: none;
}

/* Floating mockup glow + tilt */
.hero-mock {
  position: relative;
}
.hero-mock::before {
  content: '';
  position: absolute;
  inset: -40px;
  background: radial-gradient(ellipse at center, rgba(26,163,154,.25), transparent 60%);
  filter: blur(40px);
  z-index: -1;
  pointer-events: none;
}
.hero-mock .mockup-frame {
  transition: transform .6s cubic-bezier(.2,.8,.2,1);
  will-change: transform;
}

/* CTA banner — luxe upgrade */
.cta-banner {
  background:
    radial-gradient(ellipse at 80% 20%, rgba(165,215,232,.35), transparent 60%),
    radial-gradient(ellipse at 10% 90%, rgba(26,163,154,.40), transparent 60%),
    linear-gradient(135deg, #0E7C75 0%, #0B2447 100%);
  position: relative;
  overflow: hidden;
}
.cta-banner::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 40px 40px;
  mask-image: radial-gradient(ellipse at top right, #000, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse at top right, #000, transparent 70%);
  pointer-events: none;
}

/* Marquee improvements (partners) */
.partners-strip {
  position: relative;
  padding: 32px 0;
  background:
    linear-gradient(90deg, #fff, transparent 8%, transparent 92%, #fff),
    #FBFDFF;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

/* Section background variants */
.bg-soft {
  background:
    radial-gradient(900px 400px at 80% 10%, rgba(165,215,232,.20), transparent 60%),
    radial-gradient(700px 500px at 20% 80%, rgba(207,224,244,.22), transparent 60%),
    linear-gradient(180deg, #FBFDFF 0%, #F4F8FC 100%);
}
.bg-mesh {
  background:
    radial-gradient(at 20% 20%, rgba(26,163,154,.10), transparent 50%),
    radial-gradient(at 80% 30%, rgba(87,108,188,.10), transparent 50%),
    radial-gradient(at 40% 80%, rgba(165,215,232,.20), transparent 50%),
    #FBFDFF;
}
.bg-purple-mesh {
  background:
    radial-gradient(at 20% 20%, rgba(110,63,243,.12), transparent 50%),
    radial-gradient(at 80% 80%, rgba(167,139,250,.18), transparent 50%),
    radial-gradient(at 50% 50%, rgba(213,200,250,.18), transparent 60%),
    #FBFAFF;
}

/* Big heading shine effect */
.shine-text {
  background: linear-gradient(110deg,
    #19376D 20%,
    #1AA39A 40%,
    #fff 50%,
    #1AA39A 60%,
    #576CBC 80%);
  background-size: 200% 100%;
  -webkit-background-clip: text;
          background-clip: text;
  color: transparent;
  animation: shine 8s linear infinite;
}

/* Decorative chip — annotates a feature */
.chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11.5px; font-weight: 600;
  background: rgba(255,255,255,.85);
  border: 1px solid rgba(11,36,71,.08);
  color: var(--asira-navy);
  box-shadow: var(--shadow-xs);
}

/* Floating cards over the mockup */
.float-card {
  position: absolute;
  background: rgba(255,255,255,.95);
  backdrop-filter: blur(14px);
  border: 1px solid rgba(11,36,71,.05);
  border-radius: 14px;
  padding: 12px 14px;
  box-shadow: 0 12px 30px rgba(11,36,71,.12);
  display: flex; align-items: center; gap: 10px;
  font-size: 13px;
  z-index: 3;
  animation: orbFloat3 6s ease-in-out infinite;
}
.float-card .ic {
  width: 32px; height: 32px;
  border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.float-card.tl { top: 14px; right: 14px; animation-delay: 0s; }
.float-card.bl { bottom: 24px; left: 14px; animation-delay: 1.5s; }
.float-card.br { bottom: 70px; right: 14px; animation-delay: 3s; }
.float-card.tr { top: 14px; left: 14px; animation-delay: .8s; }

/* Spacea hero special */
.cosmos-bg {
  position: absolute; inset: 0;
  pointer-events: none; overflow: hidden; z-index: 0;
  background:
    radial-gradient(900px 600px at 80% 0%, rgba(110,63,243,.30), transparent 60%),
    radial-gradient(700px 500px at 0% 50%, rgba(167,139,250,.25), transparent 60%),
    radial-gradient(800px 400px at 50% 100%, rgba(213,200,250,.30), transparent 60%);
}
.cosmos-bg::after {
  content: '';
  position: absolute; inset: 0;
  background-image:
    radial-gradient(2px 2px at 12% 20%, #fff, transparent 50%),
    radial-gradient(1.5px 1.5px at 24% 70%, #fff, transparent 50%),
    radial-gradient(2px 2px at 60% 30%, #fff, transparent 50%),
    radial-gradient(1px 1px at 78% 70%, #fff, transparent 50%),
    radial-gradient(2px 2px at 88% 18%, #fff, transparent 50%),
    radial-gradient(1.5px 1.5px at 38% 50%, #fff, transparent 50%),
    radial-gradient(1px 1px at 50% 84%, #fff, transparent 50%);
  opacity: .8;
  animation: sparkle 4s ease-in-out infinite alternate;
}

/* Custom scrollbar */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: #F4F7FB; }
::-webkit-scrollbar-thumb { background: #C7D3E0; border-radius: 6px; border: 2px solid #F4F7FB; }
::-webkit-scrollbar-thumb:hover { background: #A5B5C7; }

/* Selection */
::selection { background: rgba(26,163,154,.20); color: var(--asira-navy); }

/* Buttons get a subtle inner shine */
.btn-primary {
  background:
    linear-gradient(180deg, rgba(255,255,255,.18), transparent 50%),
    linear-gradient(135deg, var(--asira-teal-dark) 0%, var(--asira-teal) 100%);
  position: relative;
  overflow: hidden;
}
.btn-primary::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.3) 50%, transparent 70%);
  background-size: 200% 100%;
  background-position: -200% 0;
  transition: background-position .6s ease;
  pointer-events: none;
}
.btn-primary:hover::before { background-position: 200% 0; }

.btn-purple {
  background:
    linear-gradient(180deg, rgba(255,255,255,.18), transparent 50%),
    linear-gradient(135deg, #5B2DD9 0%, #8A5CF6 100%);
}

/* Numbered ribbon (steps) */
.step-ribbon {
  position: relative;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 22px;
  text-align: center;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.step-ribbon::before {
  content: attr(data-step);
  position: absolute;
  top: -14px; right: 22px;
  background: linear-gradient(135deg, var(--asira-teal-dark), var(--asira-teal));
  color: #fff;
  font-weight: 800;
  width: 32px; height: 32px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px;
  box-shadow: 0 6px 16px rgba(26,163,154,.35);
}
.step-ribbon:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: rgba(26,163,154,.30); }

/* Connector lines for timelines */
.connector-line {
  position: relative;
}
.connector-line::after {
  content: '';
  position: absolute;
  top: 70px;
  right: 14%;
  left: 14%;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--asira-teal-light), var(--asira-teal-light), transparent);
  z-index: 0;
}

/* Image polish — subtle ring + shadow */
.img-ring {
  border-radius: 16px;
  box-shadow:
    0 0 0 1px rgba(11,36,71,.06),
    0 24px 60px -20px rgba(11,36,71,.20);
}

/* ============ Spacea wordmark (icon + text composed in HTML) ============ */
.spacea-brand {
  display: inline-flex;
  align-items: center;
  gap: 16px;
  vertical-align: middle;
}
.spacea-brand--lg { gap: 22px; }
.spacea-brand .mark {
  height: 90px;
  width: auto;
  flex-shrink: 0;
}
.spacea-brand--lg .mark { height: 120px; }
.spacea-brand--sm .mark { height: 44px; }
.spacea-brand .words {
  display: flex;
  flex-direction: column;
  gap: 2px;
  line-height: 1;
}
.spacea-brand .en {
  font-family: 'Inter','SF Pro Display','Helvetica Neue',Arial,sans-serif;
  font-weight: 800;
  font-size: 38px;
  letter-spacing: -1.2px;
  color: #1B1340;
}
.spacea-brand .ar {
  font-family: 'IBM Plex Sans Arabic','Tajawal',sans-serif;
  font-weight: 700;
  font-size: 26px;
  color: #1B1340;
}
.spacea-brand--lg .en { font-size: 50px; }
.spacea-brand--lg .ar { font-size: 34px; }
.spacea-brand--sm .en { font-size: 22px; letter-spacing: -.6px; }
.spacea-brand--sm .ar { font-size: 16px; }
.spacea-brand--light .en, .spacea-brand--light .ar { color: #fff; }

/* ============ Modern testimonial cards ============ */
.t-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 24px;
  padding: 32px 28px;
  position: relative;
  height: 100%;
  display: flex;
  flex-direction: column;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  overflow: hidden;
}
.t-card::before {
  content: '"';
  position: absolute;
  top: -8px; right: 24px;
  font-family: Georgia, serif;
  font-size: 110px;
  font-weight: 800;
  line-height: 1;
  color: rgba(26,163,154,.10);
  pointer-events: none;
}
.t-card::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1.5px;
  background: linear-gradient(135deg, transparent 50%, rgba(26,163,154,.5));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity: 0;
  transition: opacity .3s ease;
  pointer-events: none;
}
.t-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 30px 60px -20px rgba(11,36,71,.20);
}
.t-card:hover::after { opacity: 1; }
.t-card .stars {
  color: #F5B400;
  font-size: 16px;
  letter-spacing: 3px;
  margin-bottom: 16px;
}
.t-card blockquote {
  font-size: 16px;
  line-height: 1.85;
  color: var(--text-2);
  font-weight: 500;
  margin: 0 0 24px;
  flex: 1;
}
.t-card .person {
  display: flex;
  align-items: center;
  gap: 14px;
  padding-top: 20px;
  border-top: 1px dashed var(--border);
}
.t-card .person-pic {
  width: 52px; height: 52px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--asira-teal), var(--asira-navy-700));
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px;
  font-weight: 800;
  flex-shrink: 0;
  box-shadow: 0 8px 18px -6px rgba(26,163,154,.40);
  position: relative;
}
.t-card .person-pic::after {
  content: '';
  position: absolute;
  bottom: -2px; right: -2px;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: #1AA39A;
  border: 3px solid #fff;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3'><polyline points='20 6 9 17 4 12'/></svg>");
  background-size: 9px 9px;
  background-repeat: no-repeat;
  background-position: center;
}
.t-card .person h5 {
  margin: 0;
  font-size: 16px;
  color: var(--asira-navy);
  font-weight: 700;
}
.t-card .person span {
  display: block;
  font-size: 13px;
  color: var(--text-3);
  margin-top: 2px;
}
.t-card .logo-mini {
  margin-right: auto;
  font-size: 11px;
  font-weight: 700;
  color: var(--text-3);
  background: var(--bg-soft);
  padding: 4px 10px;
  border-radius: 6px;
}
/* Variant accents */
.t-card--purple .stars { color: #F5B400; }
.t-card--purple .person-pic { background: linear-gradient(135deg, #6E3FF3, #3B1F8B); box-shadow: 0 8px 18px -6px rgba(110,63,243,.40); }
.t-card--purple::before { color: rgba(110,63,243,.10); }
.t-card--purple::after { background: linear-gradient(135deg, transparent 50%, rgba(110,63,243,.5)); }

.t-card--orange .person-pic { background: linear-gradient(135deg, #FB923C, #C2410C); box-shadow: 0 8px 18px -6px rgba(251,146,60,.40); }
.t-card--blue .person-pic { background: linear-gradient(135deg, #576CBC, #19376D); box-shadow: 0 8px 18px -6px rgba(87,108,188,.40); }

/* ===== FAQ accordion (shared — AEO) ===== */
.faq-list{display:grid;gap:14px;}
.faq-item{background:#fff;border:1px solid var(--border);border-radius:16px;padding:0 22px;transition:border-color .25s ease,box-shadow .25s ease;}
.faq-item[open]{border-color:rgba(26,163,154,.45);box-shadow:0 10px 30px -16px rgba(8,25,58,.35);}
.faq-item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0;}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary h3{margin:0;font-size:16.5px;color:var(--asira-navy);font-weight:700;}
.faq-ic{position:relative;width:22px;height:22px;flex-shrink:0;}
.faq-ic::before,.faq-ic::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--asira-teal);border-radius:2px;}
.faq-ic::before{width:14px;height:2.5px;}
.faq-ic::after{width:2.5px;height:14px;transition:transform .25s ease,opacity .25s ease;}
.faq-item[open] .faq-ic::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0;}
.faq-a{padding:0 0 22px;}
.faq-a p{margin:0;color:var(--text-2);font-size:15px;line-height:1.95;}
