/* ============================================================
   VidQuarry — Components (Microsoft Fluent 2)
   Navbar, Buttons, Cards, Footer, FAQ, Pricing
   ============================================================ */

/* --- NAVBAR --- */
.navbar{position:fixed;top:0;left:0;right:0;height:var(--navbar-height);background:var(--surface-primary);border-bottom:1px solid var(--border-default);z-index:var(--z-sticky);transition:all var(--duration-normal) var(--ease-fluent)}
.navbar.scrolled{background:var(--mica-bg);backdrop-filter:blur(var(--acrylic-blur));-webkit-backdrop-filter:blur(var(--acrylic-blur));box-shadow:var(--shadow-4)}
.navbar-inner{max-width:var(--container-xl);margin:0 auto;padding:0 var(--space-l);height:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--space-m)}
.navbar-brand{display:flex;align-items:center;gap:var(--space-s);text-decoration:none;color:var(--text-primary);font-weight:600;font-size:var(--font-body-lg)}
.navbar-brand img{height:28px;width:auto}
.navbar-nav{display:flex;align-items:center;gap:var(--space-xs)}
.navbar-nav a{color:var(--text-primary);font-size:var(--font-body-sm);font-weight:400;padding:var(--space-s) var(--space-m);border-radius:var(--radius-m);transition:all var(--duration-fast) var(--ease-fluent);text-decoration:none}
.navbar-nav a:hover{background:rgba(0,0,0,0.04);color:var(--text-primary)}
.navbar-nav a.active{font-weight:600}
.navbar-actions{display:flex;align-items:center;gap:var(--space-s)}
.navbar-flag{font-size:20px;cursor:default}
.navbar-lang-btn{font-size:var(--font-body-sm);color:var(--text-secondary);padding:var(--space-xs) var(--space-s);border-radius:var(--radius-m);border:1px solid var(--border-default);cursor:pointer;transition:all var(--duration-fast) var(--ease-fluent);background:transparent}
.navbar-lang-btn:hover{background:rgba(0,0,0,0.04);border-color:var(--border-strong)}
.navbar-toggle{display:none;flex-direction:column;gap:4px;cursor:pointer;padding:var(--space-s)}
.navbar-toggle span{display:block;width:20px;height:2px;background:var(--text-primary);transition:all var(--duration-normal) var(--ease-fluent);border-radius:1px}

/* --- BUTTONS --- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-s);padding:10px 20px;font-size:var(--font-body-sm);font-weight:600;border-radius:var(--radius-m);transition:all var(--duration-normal) var(--ease-fluent);text-decoration:none;line-height:1.2;white-space:nowrap;cursor:pointer;border:none}
.btn:hover{text-decoration:none;transform:scale(0.98)}
.btn:active{transform:scale(0.96)}
.btn-primary{background:var(--primary);color:var(--text-on-primary)}
.btn-primary:hover{background:var(--primary-hover);color:var(--text-on-primary)}
.btn-standard{background:transparent;color:var(--text-primary);border:1px solid var(--border-strong)}
.btn-standard:hover{background:rgba(0,0,0,0.04)}
.btn-subtle{background:transparent;color:var(--text-primary)}
.btn-subtle:hover{background:rgba(0,0,0,0.04)}
.btn-lg{padding:14px 28px;font-size:var(--font-body);border-radius:var(--radius-l)}
.btn-sm{padding:6px 14px;font-size:var(--font-caption)}
.btn-icon{width:36px;height:36px;padding:0;border-radius:var(--radius-m)}

/* --- CARDS --- */
.card{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:var(--space-xl);transition:all var(--duration-normal) var(--ease-fluent)}
.card:hover{box-shadow:var(--shadow-16);transform:translateY(-2px)}
.card-acrylic{background:var(--acrylic-bg);backdrop-filter:blur(var(--acrylic-blur));-webkit-backdrop-filter:blur(var(--acrylic-blur));border:1px solid var(--acrylic-border)}
.card-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-l);background:var(--primary-light);color:var(--primary);margin-bottom:var(--space-m);font-size:24px}
.card-title{font-size:var(--font-h4);font-weight:600;margin-bottom:var(--space-s);color:var(--text-primary)}
.card-text{font-size:var(--font-body-sm);color:var(--text-secondary);line-height:var(--lh-body)}

/* --- FEATURE CARDS --- */
.feature-card{text-align:center;padding:var(--space-2xl) var(--space-xl)}
.feature-card .card-icon{margin:0 auto var(--space-m)}
[dir="rtl"] .feature-card .card-icon{margin:0 auto var(--space-m)}

/* --- PRICING CARDS --- */
.pricing-card{position:relative;text-align:center;padding:var(--space-2xl);border-radius:var(--radius-xl);overflow:hidden}
.pricing-card.featured{border:2px solid var(--primary);box-shadow:var(--shadow-28)}
.pricing-card.featured::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary),var(--ms-blue))}
.pricing-badge{display:inline-block;padding:var(--space-xs) var(--space-m);background:var(--primary);color:var(--text-on-primary);border-radius:var(--radius-full);font-size:var(--font-caption);font-weight:600;margin-bottom:var(--space-m)}
.pricing-name{font-size:var(--font-h3);font-weight:700;margin-bottom:var(--space-s)}
.pricing-price{font-size:var(--font-display);font-weight:800;color:var(--primary);line-height:1.1;margin-bottom:var(--space-xs)}
.pricing-price .currency{font-size:var(--font-h2);vertical-align:super}
.pricing-price .period{font-size:var(--font-body);color:var(--text-secondary);font-weight:400}
.pricing-old-price{font-size:var(--font-body-lg);color:var(--text-tertiary);text-decoration:line-through;margin-bottom:var(--space-m)}
.pricing-features{list-style:none;padding:0;margin:var(--space-l) 0;text-align:start}
.pricing-features li{padding:var(--space-s) 0;font-size:var(--font-body-sm);color:var(--text-secondary);display:flex;align-items:center;gap:var(--space-s)}
.pricing-features li::before{content:'✓';color:var(--text-success);font-weight:700;font-size:16px;flex-shrink:0}

/* --- TESTIMONIAL CARDS --- */
.testimonial-card{padding:var(--space-xl);position:relative}
.testimonial-card::before{content:'"';position:absolute;top:var(--space-m);font-size:60px;color:var(--primary);opacity:0.15;font-family:Georgia,serif;line-height:1}
[dir="ltr"] .testimonial-card::before{left:var(--space-l)}
[dir="rtl"] .testimonial-card::before{right:var(--space-l)}
.testimonial-text{font-size:var(--font-body);color:var(--text-secondary);margin-bottom:var(--space-m);font-style:italic;line-height:var(--lh-body);position:relative;z-index:1}
.testimonial-author{display:flex;align-items:center;gap:var(--space-m)}
.testimonial-avatar{width:44px;height:44px;border-radius:var(--radius-full);background:var(--primary-light);display:flex;align-items:center;justify-content:center;font-size:var(--font-body-lg);font-weight:700;color:var(--primary);flex-shrink:0}
.testimonial-name{font-size:var(--font-body-sm);font-weight:600;color:var(--text-primary)}
.testimonial-role{font-size:var(--font-caption);color:var(--text-tertiary)}

/* --- FAQ ACCORDION --- */
.faq-item{border:1px solid var(--border-default);border-radius:var(--radius-l);margin-bottom:var(--space-s);overflow:hidden;transition:all var(--duration-normal) var(--ease-fluent)}
.faq-item:hover{border-color:var(--border-strong)}
.faq-item.active{border-color:var(--primary);box-shadow:var(--shadow-4)}
.faq-question{display:flex;align-items:center;justify-content:space-between;padding:var(--space-m) var(--space-l);cursor:pointer;font-size:var(--font-body);font-weight:500;color:var(--text-primary);background:transparent;width:100%;text-align:inherit;gap:var(--space-m)}
.faq-question:hover{background:rgba(0,0,0,0.02)}
.faq-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;transition:transform var(--duration-normal) var(--ease-fluent);flex-shrink:0;font-size:18px;color:var(--text-tertiary)}
.faq-item.active .faq-icon{transform:rotate(180deg);color:var(--primary)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height var(--duration-slow) var(--ease-fluent)}
.faq-answer-inner{padding:0 var(--space-l) var(--space-l);font-size:var(--font-body-sm);color:var(--text-secondary);line-height:var(--lh-body)}

/* --- STEP CARDS --- */
.step-card{text-align:center;position:relative;padding:var(--space-xl)}
.step-number{width:56px;height:56px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--primary),var(--ms-blue));color:var(--text-on-primary);font-size:var(--font-h3);font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-m)}
.step-title{font-size:var(--font-h4);font-weight:600;margin-bottom:var(--space-s)}
.step-text{font-size:var(--font-body-sm);color:var(--text-secondary)}

/* --- PLATFORM ICONS GRID --- */
.platform-icon{display:flex;flex-direction:column;align-items:center;gap:var(--space-s);padding:var(--space-m);border-radius:var(--radius-l);transition:all var(--duration-normal) var(--ease-fluent)}
.platform-icon:hover{background:rgba(0,0,0,0.03);transform:scale(1.05)}
.platform-icon svg,.platform-icon img{width:40px;height:40px}
.platform-icon span{font-size:var(--font-caption);color:var(--text-secondary)}

/* --- COUNTDOWN TIMER --- */
.countdown{display:flex;gap:var(--space-m);justify-content:center;flex-wrap:wrap}
.countdown-item{display:flex;flex-direction:column;align-items:center;min-width:72px}
.countdown-value{font-size:var(--font-h1);font-weight:800;color:var(--primary);line-height:1;font-variant-numeric:tabular-nums}
.countdown-label{font-size:var(--font-caption);color:var(--text-secondary);margin-top:var(--space-xs)}
.countdown-separator{font-size:var(--font-h2);color:var(--text-tertiary);font-weight:300;display:flex;align-items:center;padding-bottom:var(--space-m)}

/* --- FOOTER --- */
.footer{background:var(--surface-secondary);border-top:1px solid var(--border-default);padding:var(--space-3xl) 0 var(--space-xl);    display: flex;
    justify-content: center;}
.footer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-xl);margin-bottom:var(--space-2xl)}
.footer-col-title{font-size:var(--font-body-sm);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-m)}
.footer-col a{display:block;font-size:var(--font-caption);color:var(--text-secondary);padding:var(--space-xs) 0;transition:color var(--duration-fast) var(--ease-fluent);text-decoration:none}
.footer-col a:hover{color:var(--text-primary)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:var(--space-l);border-top:1px solid var(--border-default);flex-wrap:wrap;gap:var(--space-m)}
.footer-bottom-links{display:flex;gap:var(--space-m);flex-wrap:wrap}
.footer-bottom-links a{font-size:var(--font-caption);color:var(--text-secondary)}
.footer-copyright{font-size:var(--font-caption);color:var(--text-tertiary)}

/* --- SECTION TITLES --- */
.section-label{font-size:var(--font-caption);font-weight:600;color:var(--primary);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:var(--space-s)}
.section-title{font-size:var(--font-h2);font-weight:700;margin-bottom:var(--space-s);color:var(--text-primary)}
.section-subtitle{font-size:var(--font-body-lg);color:var(--text-secondary);max-width:640px;margin:0 auto}

/* --- PRICE TAG --- */
.price-tag{display:inline-flex;align-items:baseline;gap:var(--space-xs)}
.price-tag-old{font-size:var(--font-body-lg);color:var(--text-tertiary);text-decoration:line-through}
.price-tag-new{font-size:var(--font-h1);font-weight:800;color:var(--primary)}
.price-tag-period{font-size:var(--font-body-sm);color:var(--text-secondary)}

/* --- BADGE --- */
.badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-m);border-radius:var(--radius-full);font-size:var(--font-caption);font-weight:600}
.badge-primary{background:var(--primary);color:var(--text-on-primary)}
.badge-danger{background:var(--text-danger);color:var(--text-on-primary)}
.badge-success{background:var(--text-success);color:var(--text-on-primary)}

/* --- BRAND LOGO COLORS --- */
.brand-vid{color:#F25C05;font-weight:700}
.brand-quarry{color:#0078D4;font-weight:700}

/* --- HERO WIDGET (positioned at page edge, behind text) --- */
.hero-widget{position:absolute;z-index:0;top:100%;transform:translateY(-50%);pointer-events:none}
html[dir="rtl"] .hero-widget{right:30px}
html[dir="ltr"] .hero-widget{left:30px}
.hero-widget-img{max-width:500px;width:100%;height:auto;opacity:1;filter:drop-shadow(0 20px 60px rgba(0,0,0,0.15));animation:widgetFloat 4s ease-in-out infinite}
@keyframes widgetFloat{0%,100%{transform:translateY(0) translateY(-50%)}50%{transform:translateY(-12px) translateY(-50%)}}

/* --- PLATFORM COUNT (1400+) --- */
.platform-count{font-size:28px;font-weight:800;color:var(--primary);line-height:1}

/* --- FLUENT 2 DIALOG-STYLE BORDERS (Microsoft popup aesthetic) --- */
.card,.faq-item,.step-card,.pricing-card,.testimonial-card{
  background:var(--surface-primary);
  border:1px solid var(--border-default);
  border-radius:var(--radius-xl);
  box-shadow:0 0 0 0.5px rgba(0,0,0,0.05),var(--shadow-4);
  transition:all var(--duration-normal) var(--ease-fluent)
}
.card:hover,.faq-item:hover,.step-card:hover,.testimonial-card:hover{
  box-shadow:0 0 0 0.5px rgba(0,0,0,0.08),var(--shadow-16);
  border-color:var(--border-strong)
}
.step-card{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:var(--space-xl)}
.pricing-card{background:var(--surface-primary);border:1px solid var(--border-default)}
.pricing-card.featured{border:2px solid var(--primary);box-shadow:0 0 0 1px rgba(0,120,212,0.12),var(--shadow-28)}

/* --- GLOBAL PRICING NOTICE (Fluent 2 InfoBar) --- */
.pricing-global-notice {
  display: flex;
  align-items: flex-start;
  gap: var(--space-m);
  margin: 0 auto var(--space-xl);
  padding: var(--space-m) var(--space-l);
  background: rgba(0, 120, 212, 0.05);
  border: 1px solid rgba(0, 120, 212, 0.15);
  border-radius: var(--radius-l);
  text-align: left;
}
[dir="rtl"] .pricing-global-notice {
  text-align: right;
  flex-direction: row;
}
.pricing-global-notice .notice-icon {
  font-size: 20px;
  color: var(--primary);
  flex-shrink: 0;
}
.pricing-global-notice .notice-content {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.pricing-global-notice .notice-content h4 {
  font-size: var(--font-body-sm);
  font-weight: 600;
  color: var(--text-primary);
  margin: 0;
}
.pricing-global-notice .notice-content p {
  font-size: var(--font-caption);
  color: var(--text-secondary);
  line-height: 1.5;
  margin: 0;
}

/* --- COOKIE CONSENT BANNER (Fluent 2 Dialog) --- */
.cookie-consent {
  position: fixed;
  bottom: var(--space-l);
  inset-inline-end: var(--space-l);
  max-width: 420px;
  width: calc(100% - var(--space-xl));
  background: var(--surface-primary);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-xl);
  box-shadow: 0 0 0 0.5px rgba(0,0,0,0.08), var(--shadow-56);
  padding: var(--space-l);
  z-index: 1000;
  transform: translateY(120%);
  opacity: 0;
  transition: transform 0.4s var(--ease-fluent), opacity 0.4s var(--ease-fluent);
  display: flex;
  flex-direction: column;
  gap: var(--space-m);
}
.cookie-consent.show {
  transform: translateY(0);
  opacity: 1;
}
.cookie-consent-header {
  display: flex;
  align-items: center;
  gap: var(--space-s);
  font-weight: 600;
  font-size: var(--font-body);
  color: var(--text-primary);
}
[dir="rtl"] .cookie-consent-header {
  flex-direction: row;
}
.cookie-consent-icon {
  font-size: 24px;
}
.cookie-consent-text {
  font-size: var(--font-body-sm);
  color: var(--text-secondary);
  line-height: 1.5;
  text-align: left;
}
[dir="rtl"] .cookie-consent-text {
  text-align: right;
}
.cookie-consent-text a {
  color: var(--primary);
  text-decoration: none;
  font-weight: 500;
}
.cookie-consent-text a:hover {
  text-decoration: underline;
}
.cookie-consent-actions {
  display: flex;
  justify-content: flex-end;
  gap: var(--space-s);
}
[dir="rtl"] .cookie-consent-actions {
  flex-direction: row-reverse;
}
.cookie-consent-btn {
  padding: var(--space-s) var(--space-l);
  font-size: var(--font-caption);
  font-weight: 600;
  border-radius: var(--radius-m);
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-fluent);
  border: none;
  line-height: 1.2;
}
.cookie-consent-btn.accept {
  background: var(--primary);
  color: var(--text-on-primary);
}
.cookie-consent-btn.accept:hover {
  background: var(--primary-hover);
}
.cookie-consent-btn.decline {
  background: transparent;
  color: var(--text-primary);
  border: 1px solid var(--border-strong);
}
.cookie-consent-btn.decline:hover {
  background: rgba(0,0,0,0.04);
}

@media (max-width: 576px) {
  .cookie-consent {
    inset-inline-start: var(--space-m);
    inset-inline-end: var(--space-m);
    bottom: var(--space-m);
    width: auto;
    max-width: none;
  }
}

/* --- DOWNLOAD MODAL & AIRDROP ANIMATION --- */
.download-modal-overlay {
  position: fixed;
  inset: 0;
  background: var(--smoke-bg);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  z-index: var(--z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--duration-normal) var(--ease-fluent);
}

.download-modal-overlay.show {
  opacity: 1;
  pointer-events: auto;
}

.download-modal-card {
  width: 100%;
  max-width: 440px;
  background: var(--acrylic-bg);
  backdrop-filter: blur(var(--acrylic-blur));
  -webkit-backdrop-filter: blur(var(--acrylic-blur));
  border: 1px solid var(--acrylic-border);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-64);
  padding: var(--space-xl);
  position: relative;
  text-align: center;
  overflow: hidden;
  transform: scale(0.9) translateY(20px);
  transition: transform var(--duration-normal) var(--ease-fluent);
}

.download-modal-overlay.show .download-modal-card {
  transform: scale(1) translateY(0);
}

.download-modal-close {
  position: absolute;
  top: var(--space-m);
  inset-inline-end: var(--space-m);
  font-size: 24px;
  font-weight: 300;
  color: var(--text-secondary);
  cursor: pointer;
  z-index: 10;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-full);
  transition: background var(--duration-fast) var(--ease-fluent), color var(--duration-fast) var(--ease-fluent);
}

.download-modal-close:hover {
  background: rgba(0, 0, 0, 0.04);
  color: var(--text-primary);
}

.airdrop-animation-container {
  height: 220px;
  position: relative;
  background: linear-gradient(180deg, rgba(0, 120, 212, 0.02) 0%, rgba(0, 120, 212, 0.08) 100%);
  border-radius: var(--radius-xl);
  margin-bottom: var(--space-l);
  overflow: hidden;
  border: 1px solid var(--border-subtle);
}

.airdrop-parachute-system {
  position: absolute;
  left: 50%;
  transform: translateX(-50%) translateY(-150px);
  width: 100px;
  display: flex;
  flex-direction: column;
  align-items: center;
  transition: transform 2.5s cubic-bezier(0.25, 1, 0.5, 1);
  z-index: 5;
}

.airdrop-parachute-system.falling {
  transform: translateX(-50%) translateY(85px); /* Landed position based on container height */
}

.airdrop-parachute {
  width: 80px;
  height: 60px;
  transform-origin: bottom center;
  animation: parachuteSway 1.5s ease-in-out infinite alternate;
}

.airdrop-parachute-system.landed .airdrop-parachute {
  animation: parachuteCollapse 0.5s ease-out forwards;
}

.airdrop-crate {
  width: 42px;
  height: 42px;
  background: linear-gradient(135deg, #e3a857 0%, #c6893f 100%);
  border: 2px solid #8c5828;
  border-radius: var(--radius-m);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 16px rgba(0,0,0,0.12), inset 0 2px 4px rgba(255,255,255,0.2);
  margin-top: -6px;
  position: relative;
  z-index: 2;
  transform-origin: bottom center;
}

.crate-brand-icon {
  font-size: 20px;
  filter: drop-shadow(0 1px 2px rgba(0,0,0,0.2));
}

.airdrop-parachute-system.landed .airdrop-crate {
  animation: crateBounce 0.5s ease-out forwards;
}

.airdrop-landing-pad {
  position: absolute;
  bottom: 12px;
  left: 50%;
  transform: translateX(-50%);
  width: 120px;
  height: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
}

.landing-target {
  width: 100px;
  height: 10px;
  border: 2px dashed rgba(0, 120, 212, 0.3);
  border-radius: var(--radius-full);
  position: relative;
  background: rgba(0, 120, 212, 0.02);
}

.landing-target::before {
  content: '🎯';
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 16px;
  opacity: 0.5;
  animation: pulseTarget 2s infinite ease-in-out;
}

/* Clouds floating up during fall */
.airdrop-cloud {
  position: absolute;
  font-size: 28px;
  opacity: 0.2;
  filter: blur(1px);
  pointer-events: none;
}

.cloud-1 {
  left: 10%;
  top: 20px;
  animation: floatCloudUp 4s linear infinite;
}

.cloud-2 {
  right: 10%;
  top: 100px;
  animation: floatCloudUp 4s linear infinite 2s;
}

.download-modal-content {
  margin-top: var(--space-m);
}

.download-modal-title {
  font-size: var(--font-body-lg);
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: var(--space-xs);
}

.download-modal-subtitle {
  font-size: var(--font-body-sm);
  color: var(--text-secondary);
  margin-bottom: var(--space-l);
}

.download-progress-bar {
  width: 100%;
  height: 4px;
  background: var(--border-default);
  border-radius: var(--radius-full);
  overflow: hidden;
}

.download-progress-fill {
  width: 0%;
  height: 100%;
  background: var(--primary);
  border-radius: var(--radius-full);
  transition: width 0.1s linear;
}

/* ANIMATIONS */
@keyframes parachuteSway {
  0% { transform: rotate(-5deg) translateX(-3px); }
  100% { transform: rotate(5deg) translateX(3px); }
}

@keyframes parachuteCollapse {
  0% { transform: scaleY(1) translateY(0); opacity: 1; filter: blur(0); }
  100% { transform: scaleY(0.1) translateY(20px); opacity: 0; filter: blur(2px); }
}

@keyframes crateBounce {
  0% { transform: scaleY(1) scaleX(1) translateY(0); }
  25% { transform: scaleY(0.65) scaleX(1.3) translateY(4px); }
  50% { transform: scaleY(1.15) scaleX(0.85) translateY(-6px); }
  75% { transform: scaleY(0.9) scaleX(1.05) translateY(1px); }
  100% { transform: scaleY(1) scaleX(1) translateY(0); }
}

@keyframes floatCloudUp {
  0% { transform: translateY(220px); opacity: 0; }
  10% { opacity: 0.35; }
  90% { opacity: 0.35; }
  100% { transform: translateY(-60px); opacity: 0; }
}

@keyframes pulseTarget {
  0%, 100% { transform: translateX(-50%) scale(1); opacity: 0.3; }
  50% { transform: translateX(-50%) scale(1.15); opacity: 0.6; }
}

/* --- NAVBAR DOWNLOAD DROPDOWN --- */
.nav-download-wrapper {
  position: relative;
  display: inline-block;
}

.nav-download-trigger {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  cursor: pointer;
}

.nav-download-chevron {
  width: 10px;
  height: 10px;
  margin-left: 2px;
  flex-shrink: 0;
  transition: transform var(--duration-fast) var(--ease-fluent);
}

[dir="rtl"] .nav-download-chevron {
  margin-left: 0;
  margin-right: 2px;
}

.nav-download-wrapper.open .nav-download-chevron {
  transform: rotate(180deg);
}

.nav-download-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  inset-inline-end: 0;
  min-width: 160px;
  background: var(--acrylic-bg);
  backdrop-filter: blur(var(--acrylic-blur));
  -webkit-backdrop-filter: blur(var(--acrylic-blur));
  border: 1px solid var(--acrylic-border);
  border-radius: var(--radius-l);
  box-shadow: var(--shadow-16);
  padding: 4px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: all var(--duration-fast) var(--ease-fluent);
  z-index: var(--z-dropdown);
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.nav-download-wrapper.open .nav-download-dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.nav-dropdown-item {
  display: flex;
  align-items: center;
  gap: var(--space-s);
  width: 100%;
  padding: 8px 12px;
  font-size: var(--font-body-sm);
  color: var(--text-primary);
  border-radius: var(--radius-m);
  cursor: pointer;
  background: transparent;
  transition: background var(--duration-fast) var(--ease-fluent);
  text-align: inherit;
}

[dir="rtl"] .nav-dropdown-item {
  flex-direction: row;
}

.nav-dropdown-item:hover {
  background: rgba(0, 0, 0, 0.04);
}

.nav-dropdown-icon {
  width: 16px;
  height: 16px;
  color: var(--text-secondary);
  flex-shrink: 0;
}

.nav-dropdown-item:hover .nav-dropdown-icon {
  color: var(--primary);
}

/* --- SUPPORT MODAL --- */
.support-modal-overlay {
  position: fixed;
  inset: 0;
  background: var(--smoke-bg);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  z-index: var(--z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--duration-normal) var(--ease-fluent);
}

.support-modal-overlay.show {
  opacity: 1;
  pointer-events: auto;
}

.support-modal-card {
  width: 90%;
  max-width: 500px;
  background: var(--acrylic-bg);
  backdrop-filter: blur(var(--acrylic-blur));
  -webkit-backdrop-filter: blur(var(--acrylic-blur));
  border: 1px solid var(--acrylic-border);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-64);
  padding: var(--space-xl);
  position: relative;
  overflow: hidden;
  transform: scale(0.9) translateY(20px);
  transition: transform var(--duration-normal) var(--ease-fluent);
}

.support-modal-overlay.show .support-modal-card {
  transform: scale(1) translateY(0);
}

.support-modal-header {
  margin-bottom: var(--space-l);
  text-align: center;
}

.support-modal-header h2 {
  font-size: var(--font-h3);
  font-weight: 700;
  color: var(--text-primary);
  margin: 0;
}

.support-modal-header p {
  color: var(--text-secondary);
  font-size: var(--font-sm);
  margin: 4px 0 0 0;
}

/* Custom form spacing for popup */
.support-modal-card .form-group {
  margin-bottom: var(--space-m);
  text-align: start;
}

.support-modal-card .form-label {
  display: block;
  font-weight: 600;
  font-size: var(--font-sm);
  margin-bottom: 6px;
  color: var(--text-primary);
}

.support-modal-card .required {
  color: var(--danger);
}

.support-modal-card .form-input,
.support-modal-card .form-select,
.support-modal-card .form-textarea {
  width: 100%;
  padding: 10px 14px;
  background: rgba(255, 255, 255, 0.6);
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: var(--radius-m);
  font-family: inherit;
  font-size: var(--font-sm);
  color: var(--text-primary);
  box-sizing: border-box;
  transition: border-color var(--duration-fast), background var(--duration-fast);
}

.support-modal-card .form-input:focus,
.support-modal-card .form-select:focus,
.support-modal-card .form-textarea:focus {
  outline: none;
  background: #fff;
  border-color: var(--primary);
}

.support-modal-card .form-error-msg {
  display: none;
  color: var(--danger);
  font-size: 12px;
  margin-top: 4px;
}

.support-modal-card .form-group.invalid .form-error-msg {
  display: block;
}

.support-modal-card .form-group.invalid .form-input,
.support-modal-card .form-group.invalid .form-select,
.support-modal-card .form-group.invalid .form-textarea {
  border-color: var(--danger);
}

.support-modal-card .form-alert {
  margin-top: var(--space-m);
  padding: var(--space-m);
  border-radius: var(--radius-m);
  font-size: var(--font-sm);
  display: none;
  align-items: center;
  gap: var(--space-s);
  text-align: start;
}

.support-modal-card .form-alert.success {
  background: rgba(16, 124, 65, 0.08);
  border: 1px solid rgba(16, 124, 65, 0.2);
  color: #107c41;
}

.support-modal-card .form-alert.error-alert {
  background: rgba(168, 0, 0, 0.08);
  border: 1px solid rgba(168, 0, 0, 0.2);
  color: #a80000;
}

