@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

* { margin: 0; padding: 0; box-sizing: border-box; }
:root {
  --bg1: #0a0a0f;
  --grad1: #e83ecf;
  --grad2: #4f46e5;
  --accent1: #8b45f4;
  --accent2: #3b82f6;
  --glass: rgba(255,255,255,0.1);
  --glass-2: rgba(255,255,255,0.2);
  --white-70: rgba(255,255,255,0.7);
  --white-60: rgba(255,255,255,0.6);
}

body {
  font-family: 'Inter', sans-serif;
  background: var(--bg1);
  color: #fff;
  overflow-x: hidden;
  min-height: 100vh;
}

/* Background */
.background-container {
  position: fixed; inset: 0; z-index: -2;
  background: radial-gradient(ellipse at center, #1a1a2e 0%, #0a0a0f 70%);
}
.animated-bg {
  position: absolute; inset: 0;
  background:
    linear-gradient(45deg, transparent 30%, rgba(139, 69, 244, 0.08) 50%, transparent 70%),
    linear-gradient(-45deg, transparent 30%, rgba(59, 130, 246, 0.08) 50%, transparent 70%);
  animation: bgMove 20s ease-in-out infinite;
}
.particles { position: absolute; inset: 0; overflow: hidden; }
.particle {
  position: absolute; width: 2px; height: 2px;
  background: linear-gradient(45deg, var(--accent1), var(--accent2));
  border-radius: 50%; animation: float 15s infinite linear; opacity: 0;
}

/* Loading */
.loading-screen {
  position: fixed; inset: 0; background: var(--bg1);
  z-index: 1000; display: flex; align-items: center; justify-content: center;
  transition: all 1s ease-in-out;
}
.loading-wolf { display: flex; flex-direction: column; align-items: center; }
.loading-logo { width: 80px; height: 80px; margin-bottom: 1rem; animation: logoPulse 2s ease-in-out infinite; filter: drop-shadow(0 0 10px rgba(139,69,244,.5)); }
.loading-text { font-size: clamp(14px, 2vw, 20px); font-weight: 600; margin-bottom: .5rem; letter-spacing: 2px; color: var(--accent1); }
.loading-subtext { font-size: clamp(12px, 1.5vw, 16px); color: var(--white-70); letter-spacing: 1px; text-align: center; }

/* Main container */
.main-container {
  opacity: 0; transform: translateY(50px);
  transition: all 1.5s ease-out;
  min-height: 100vh; display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 2rem; position: relative; z-index: 10;
}
.main-container.loaded { opacity: 1; transform: translateY(0); }

/* Logo */
.logo-section {
  text-align: center; margin-bottom: 3rem; transform: translateY(100px); opacity: 0;
  animation: slideUpFade 1s ease-out 1s forwards;
}
.main-logo { width: 120px; height: 120px; margin: 0 auto 1rem; cursor: pointer; transition: transform .3s ease; }
.main-logo:hover { transform: scale(1.06) rotate(3deg); }
.brand-subtitle { font-size: 1.2rem; font-weight: 300; opacity: .85; letter-spacing: .1em; text-transform: uppercase; }

/* Hero */
.hero-content {
  max-width: 900px; text-align: center; margin-bottom: 3rem; transform: translateY(100px); opacity: 0;
  animation: slideUpFade 1s ease-out 1.5s forwards;
}
.hero-title {
  font-size: clamp(2.2rem, 6vw, 4rem); font-weight: 800; line-height: 1.1; margin-bottom: 1.25rem;
  background: linear-gradient(90deg, var(--grad1) 0%, var(--accent1) 50%, var(--grad2) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  letter-spacing: -0.02em; animation: gradientShift 5s ease-in-out infinite;
}
.hero-description { font-size: 1.1rem; line-height: 1.7; opacity: .9; }

/* Features */
.features-container {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1.5rem;
  width: min(1100px, 100%); margin: 3rem auto; transform: translateY(100px); opacity: 0;
  animation: slideUpFade 1s ease-out 2s forwards;
}
.feature-card {
  background: linear-gradient(135deg, rgba(139, 69, 244, .12) 0%, rgba(59, 130, 246, .06) 100%);
  backdrop-filter: blur(18px);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 22px; padding: 2rem 1.5rem; text-align: center;
  transition: all .35s ease; position: relative; overflow: hidden;
}
.feature-card::before {
  content: ''; position: absolute; inset: 0; transform: translateX(-100%);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.12), transparent);
  transition: transform .5s;
}
.feature-card:hover { transform: translateY(-6px); border-color: rgba(139,69,244,.28); box-shadow: 0 18px 50px rgba(139, 69, 244, .16); }
.feature-card:hover::before { transform: translateX(100%); }
.feature-icon { font-size: 2.2rem; margin-bottom: 1rem; background: linear-gradient(45deg, var(--grad1), var(--grad2)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.feature-title { font-size: 1.2rem; font-weight: 700; margin-bottom: .5rem; }
.feature-desc { opacity: .85; line-height: 1.5; }

/* CTA card */
.cta-section {
  background: linear-gradient(135deg, rgba(139,69,244,.22) 0%, rgba(59,130,246,.12) 100%);
  backdrop-filter: blur(28px);
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 28px; padding: 3rem 2rem; text-align: center;
  width: min(900px, 100%); margin: 0 auto; position: relative; overflow: hidden;
  transform: translateY(100px); opacity: 0; animation: slideUpFade 1s ease-out 2.5s forwards;
}
.cta-section::before {
  content: ''; position: absolute; top: -50%; left: -50%; width: 200%; height: 200%;
  background: conic-gradient(transparent, rgba(139, 69, 244, .12), transparent);
  animation: rotate 8s linear infinite;
}
.cta-content { position: relative; z-index: 2; }
.cta-title {
  font-size: clamp(1.8rem, 4vw, 2.4rem); font-weight: 800; margin-bottom: 1rem;
  background: linear-gradient(45deg, var(--grad1), var(--grad2));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.cta-subtitle { font-size: 1.05rem; opacity: .95; margin-bottom: 2rem; line-height: 1.65; }

/* Form */
.form-row {
  display: flex; flex-direction: column; gap: 1rem; align-items: stretch; width: 100%;
}
.name-input, .phone-input-container { width: 100%; max-width: 520px; margin: 0 auto; }

.name-input {
  background: var(--glass); border: 2px solid var(--glass-2); border-radius: 60px;
  color: #fff; font-size: 1rem; padding: 1.1rem 1.4rem; outline: none; backdrop-filter: blur(10px);
  transition: all .3s ease;
}
.name-input::placeholder, .mobile-input::placeholder { color: var(--white-60); }
.name-input:focus { border-color: var(--accent1); box-shadow: 0 0 0 4px rgba(139,69,244,.18); }

.phone-input-container {
  display: flex; background: var(--glass); border: 2px solid var(--glass-2);
  border-radius: 60px; overflow: hidden; backdrop-filter: blur(10px); transition: all .3s ease; position: relative;
}
.phone-input-container:focus-within { border-color: var(--accent1); box-shadow: 0 0 0 4px rgba(139,69,244,.18); }
.country-dropdown { position: relative; min-width: 120px; background: rgba(255,255,255,.06); border-right: 1px solid var(--glass-2); }
.country-select {
  appearance: none; background: transparent; border: none; color: #fff;
  font-size: .95rem; font-weight: 500; padding: 1.1rem 2rem 1.1rem 1rem; cursor: pointer; outline: none; width: 100%;
}
.country-select option { background: #1a1a2e; color: #fff; }
.dropdown-arrow {
  position: absolute; right: .8rem; top: 50%; transform: translateY(-50%);
  width: 0; height: 0; border-left: 4px solid transparent; border-right: 4px solid transparent; border-top: 6px solid rgba(255,255,255,.6); pointer-events: none;
}
.mobile-input {
  flex: 1; background: transparent; border: none; color: #fff; font-size: 1rem; padding: 1.1rem 1.4rem; outline: none; min-width: 0;
}

.submit-btn {
  padding: 1.1rem 3rem; background: linear-gradient(45deg, var(--grad1), var(--grad2));
  border: none; border-radius: 60px; color: #fff; font-size: 1rem; font-weight: 700; cursor: pointer;
  transition: all .3s ease; text-transform: uppercase; letter-spacing: .5px; position: relative; overflow: hidden; min-width: 200px; margin: 0 auto;
}
.submit-btn::before {
  content: ''; position: absolute; inset: 0; transform: translateX(-100%);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.2), transparent); transition: transform .5s;
}
.submit-btn:hover { transform: translateY(-2px); box-shadow: 0 10px 30px rgba(139,69,244,.35); }
.submit-btn:hover::before { transform: translateX(100%); }
.submit-btn:disabled { opacity: .7; cursor: not-allowed; transform: none; }

/* Messages */
.success-message, .error-message {
  text-align: center; padding: 1.6rem; border-radius: 18px; margin-top: 1.5rem; animation: slideUpFade .5s ease-out;
}
.success-message { background: linear-gradient(135deg, rgba(16,185,129,.2) 0%, rgba(5,150,105,.1) 100%); border: 1px solid rgba(16,185,129,.32); }
.error-message   { background: linear-gradient(135deg, rgba(239,68,68,.2) 0%, rgba(220,38,38,.1) 100%); border: 1px solid rgba(239,68,68,.32); }
.success-icon, .error-icon { font-size: 2.2rem; margin-bottom: .6rem; }

/* Launch info */
.launch-info { text-align: center; transform: translateY(100px); opacity: 0; animation: slideUpFade 1s ease-out 3s forwards; margin-top: 2rem; }
.launch-date {
  font-size: clamp(2rem, 6vw, 3rem); font-weight: 900;
  background: linear-gradient(45deg, var(--grad1), var(--grad2)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; margin-bottom: .6rem;
}
.launch-text { font-size: 1.05rem; opacity: .75; }

/* Wolves */
.wolves-container { position: fixed; inset: 0; pointer-events: none; z-index: 1; }
.hunting-wolf {
  position: absolute; width: 40px; height: 30px; background: linear-gradient(45deg, var(--grad1), var(--grad2));
  clip-path: polygon(0% 60%, 20% 40%, 40% 45%, 60% 30%, 80% 35%, 100% 25%, 85% 70%, 65% 75%, 40% 80%, 20% 75%);
  opacity: .6; filter: blur(1px);
}
.wolf-1 { top: 15%; animation: huntPath1 25s linear infinite; }
.wolf-2 { top: 80%; animation: huntPath2 30s linear infinite 5s; }
.wolf-3 { top: 45%; animation: huntPath3 35s linear infinite 10s; }

/* Accessibility helper */
.sr-only {
  position: absolute !important; height: 1px; width: 1px; overflow: hidden; clip: rect(1px,1px,1px,1px); white-space: nowrap;
}

/* Responsive */
@media (min-width: 768px) {
  .form-row { flex-direction: row; }
  .name-input, .phone-input-container { flex: 1; max-width: none; margin: 0; }
}
@media (max-width: 768px) {
  .cta-section { padding: 2.5rem 1.5rem; }
  .feature-card { padding: 1.6rem 1.2rem; }
  .phone-input-container { flex-direction: column; border-radius: 20px; }
  .country-dropdown { border-right: none; border-bottom: 1px solid var(--glass-2); min-width: auto; }
  .country-select { padding: 1rem 2rem 1rem 1.2rem; text-align: center; }
  .mobile-input { text-align: center; }
  .submit-btn { width: 100%; }
}

/* Animations */
@keyframes bgMove {
  0%, 100% { transform: translate(0,0); }
  25% { transform: translate(-20px,-20px); }
  50% { transform: translate(20px,20px); }
  75% { transform: translate(-10px,10px); }
}
@keyframes float {
  0% { transform: translateY(100vh) translateX(-10px); opacity: 0; }
  10% { opacity: 1; }
  90% { opacity: 1; }
  100% { transform: translateY(-100px) translateX(10px); opacity: 0; }
}
@keyframes slideUpFade {
  from { transform: translateY(100px); opacity: 0; }
  to   { transform: translateY(0); opacity: 1; }
}
@keyframes logoPulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.05)} }
@keyframes rotate { from{transform:rotate(0)} to{transform:rotate(360deg)} }
@keyframes gradientShift { 0%{background-position:0% 50%} 50%{background-position:100% 50%} 100%{background-position:0% 50%} }
@keyframes huntPath1 { 0%{left:-60px;transform:rotate(0)} 25%{transform:rotate(15deg)} 50%{transform:rotate(-10deg)} 75%{transform:rotate(5deg)} 100%{left:calc(100% + 60px);transform:rotate(0)} }
@keyframes huntPath2 { 0%{right:-60px;transform:rotate(180deg)} 25%{transform:rotate(195deg)} 50%{transform:rotate(170deg)} 75%{transform:rotate(185deg)} 100%{right:calc(100% + 60px);transform:rotate(180deg)} }
@keyframes huntPath3 { 0%{left:-60px;transform:rotate(-20deg) scaleX(-1)} 25%{transform:rotate(-5deg) scaleX(-1)} 50%{transform:rotate(-30deg) scaleX(-1)} 75%{transform:rotate(-15deg) scaleX(-1)} 100%{left:calc(100% + 60px);transform:rotate(-20deg) scaleX(-1)} }
