/* =============== RESET =============== */
* { margin: 0; padding: 0; box-sizing: border-box; }
img { display: block; max-width: 100%; height: auto; }

:root{
  --bg-0:#0a0f1a; --bg-1:#0b1220;
  --text-0:#e6f0ff; --text-1:#b7c6e3; --text-2:#91a4c2;
  --accent:#60a5fa; --accent2:#22d3ee;
  --border: rgba(148,163,184,.18);
  --shadow: 0 12px 34px rgba(2,8,23,.42);
}

*{box-sizing:border-box}
img{display:block;max-width:100%;height:auto}
.container{ width:min(1200px, 92vw); margin-inline:auto; }
.consult-page{
  background:
    radial-gradient(1200px 700px at 20% 10%, rgba(59,130,246,.09), transparent 60%),
    radial-gradient(900px 540px at 80% 0%, rgba(34,211,238,.08), transparent 55%),
    linear-gradient(180deg, var(--bg-1), var(--bg-0));
  color: var(--text-1);
}

/* ===== HERO ===== */
.hero-neo{ position:relative; overflow:hidden; isolation:isolate; }
.hero-neo{ height: 440px; }

.hero-shell{ display:grid; grid-template-columns: 1.2fr 1fr; align-items:center; height:100%; gap: 1.2rem; }

.hero-copy h1{
  font-family:'Orbitron',sans-serif;
  color:var(--text-0);
  font-size: clamp(1.9rem, 4vw, 2.8rem);
}
.hero-copy .kicker{ color:#dbeafe; margin-top:.5rem; line-height:1.65; }
.hero-cta{ margin-top:1.1rem; display:flex; gap:.7rem; flex-wrap:wrap; }

.btn-primary{
  display:inline-block; padding:.9rem 1.6rem; border-radius:12px;
  background: linear-gradient(135deg, #1e40af, #2563eb); color:#fff; text-decoration:none; font-weight:700;
  box-shadow: 0 12px 28px rgba(37,99,235,.45); transition: transform .25s, box-shadow .25s, filter .25s;
}
.btn-primary:hover{ transform: translateY(-3px); box-shadow: 0 18px 38px rgba(37,99,235,.6); filter: brightness(1.03); }

.btn-ghost{
  display:inline-block; padding:.9rem 1.2rem; border-radius:12px; text-decoration:none; font-weight:700;
  color:var(--text-0); border:1px solid var(--border);
  background: linear-gradient(160deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  box-shadow: var(--shadow); transition: transform .25s, box-shadow .25s, border-color .25s;
}
.btn-ghost:hover{ transform: translateY(-3px); border-color: rgba(56,189,248,.35); box-shadow: 0 16px 36px rgba(34,211,238,.18), var(--shadow); }

/* Hero visual */
.hero-visual{ position:relative; height:100%; display:grid; place-items:center; }
.orb{
  position:absolute; border-radius:50%;
  filter: blur(6px); opacity:.75; pointer-events:none;
  background: radial-gradient(circle at 30% 30%, rgba(96,165,250,.85), rgba(34,211,238,.35) 60%, transparent 70%);
  animation: float 9s ease-in-out infinite;
}
.orb-big{ width:260px; height:260px; top:18%; right:12%; animation-delay: .2s; }
.orb-small{ width:160px; height:160px; bottom:14%; left:8%; animation-delay: .9s; }
@keyframes float{
  0%,100%{ transform: translateY(0) translateX(0); }
  50%{ transform: translateY(-12px) translateX(8px); }
}

.diagram{
  width:min(320px, 80%); aspect-ratio:1.2/1; position:relative;
  border-radius:16px; border:1px solid var(--border);
  background: linear-gradient(160deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  box-shadow: var(--shadow);
  overflow:hidden;
}
.diagram span{
  position:absolute; width:10px; height:10px; border-radius:50%;
  background: radial-gradient(circle, var(--accent), var(--accent2));
  box-shadow: 0 0 12px rgba(34,211,238,.6);
  animation: blink 2.8s ease-in-out infinite;
}
.diagram span:nth-child(1){ top:18%; left:22%; }
.diagram span:nth-child(2){ top:58%; left:44%; animation-delay:.7s; }
.diagram span:nth-child(3){ top:28%; right:18%; animation-delay:1.3s; }
.diagram span::after{
  content: attr(data-label);
  position:absolute; transform: translateY(-180%);
  left:50%; translate: -50% 0;
  padding:.18rem .45rem; font-size:.78rem; color:var(--text-0);
  background: rgba(15,23,42,.6); border:1px solid var(--border); border-radius:999px;
}
@keyframes blink{ 0%,100%{ opacity:.9; } 50%{ opacity:.4; } }

/* Aurora layers & iso grid */
.aurora{ position:absolute; inset:-20% -10%; z-index:-1; pointer-events:none; }
.a1{
  background: radial-gradient(1100px 600px at 20% 20%, rgba(59,130,246,.18), transparent 60%),
              radial-gradient(900px 540px at 80% 10%, rgba(34,211,238,.15), transparent 60%);
  animation: drift 18s ease-in-out infinite alternate;
}
.a2{
  background: radial-gradient(1200px 700px at 10% 80%, rgba(59,130,246,.10), transparent 60%),
              radial-gradient(900px 540px at 90% 80%, rgba(34,211,238,.10), transparent 60%);
  mix-blend-mode: screen;
  animation: drift2 22s ease-in-out infinite alternate;
}
@keyframes drift{ from{ transform: translateX(-2%) translateY(1%);} to{ transform: translateX(2%) translateY(-1%);} }
@keyframes drift2{ from{ transform: translateX(2%) translateY(0);} to{ transform: translateX(-1%) translateY(2%);} }

.grid-iso{
  position:absolute; inset:0; background-image:
    linear-gradient(rgba(148,163,184,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(148,163,184,.06) 1px, transparent 1px);
  background-size: 40px 40px; mask-image: linear-gradient(to bottom, transparent 0%, #000 20%, #000 70%, transparent 100%);
  z-index:-1;
}

/* ===== VALUE STRIP ===== */
.value-strip{ display:grid; grid-template-columns: repeat(4, 1fr); gap: .9rem; padding: 36px 0 8px; }
.v-item{
  background: linear-gradient(160deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border:1px solid var(--border); border-radius:16px; padding: .9rem .95rem;
  box-shadow: var(--shadow); text-align:left; transition: transform .2s, border-color .2s, box-shadow .2s;
}
.v-item:hover{ transform: translateY(-3px); border-color: rgba(56,189,248,.35); box-shadow: 0 16px 36px rgba(34,211,238,.18), var(--shadow); }
.v-ico{ font-size:1.4rem; margin-bottom:.35rem; }
.v-item h3{ color:var(--text-0); font-family:'Orbitron',sans-serif; font-size:1.02rem; }
.v-item p{ color:var(--text-2); font-size:.98rem; }

/* ===== TRACKS (TABS) ===== */
.tracks{ padding: 22px 0; }
.tracks h2{
  font-family:'Orbitron',sans-serif; color:var(--text-0); margin-bottom:.6rem;
  font-size: clamp(1.3rem, 2.6vw, 1.7rem);
}
.tabs{ display:flex; gap:.5rem; flex-wrap:wrap; }
.tab{
  padding:.6rem 1rem; border-radius:999px; border:1px solid var(--border);
  background: linear-gradient(160deg, rgba(255,255,255,.05), rgba(255,255,255,.03));
  color:var(--text-1); cursor:pointer; font-weight:700;
  transition: transform .15s, border-color .2s, color .2s;
}
.tab:hover{ transform: translateY(-2px); border-color: rgba(56,189,248,.35); color:var(--text-0); }
.tab.active{ color:#0c1220; background: linear-gradient(135deg, #60a5fa, #22d3ee); border-color: transparent; }

.panels{ margin-top:1rem; }
.panel{ display:none; }
.panel.active{ display:block; }
.panel-grid{ display:grid; grid-template-columns: 1.1fr 1fr; gap:1.2rem; align-items:center; }
.panel-copy h3{ color:var(--accent); font-family:'Orbitron',sans-serif; margin:.2rem 0 .5rem; }
.panel-copy p{ color:var(--text-2); line-height:1.8; }
.check{ list-style:none; padding-left:0; margin-top:.5rem; }
.check li{ position:relative; padding-left:1.25rem; margin:.3rem 0; color:var(--text-2); }
.check li::before{
  content:""; position:absolute; left:0; top:.45rem; width:.65rem; height:.65rem; border-radius:50%;
  background: radial-gradient(circle, var(--accent), var(--accent2)); box-shadow: 0 0 10px rgba(34,211,238,.6);
}
.card-tilt{
  background: linear-gradient(160deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border:1px solid var(--border); border-radius:16px; padding:.6rem;
  box-shadow: var(--shadow); transform-style: preserve-3d; transition: transform .12s ease-out;
}
.card-tilt img{ border-radius:10px; }

/* ===== PACKS ===== */
.packs{ padding: 18px 0 8px; }
.packs h2{
  font-family:'Orbitron',sans-serif; color:var(--text-0); margin-bottom:.7rem;
  font-size: clamp(1.3rem, 2.6vw, 1.7rem);
}
.pack-grid{ display:grid; gap:1rem; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); }
.pack{
  background: linear-gradient(160deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border:1px solid var(--border); border-radius:16px; padding:1rem;
  box-shadow: var(--shadow); transition: transform .2s, box-shadow .2s, border-color .2s;
}
.pack:hover{ transform: translateY(-3px); border-color: rgba(56,189,248,.35); box-shadow: 0 16px 36px rgba(34,211,238,.18), var(--shadow); }
.pack h3{ color:var(--accent); font-family:'Orbitron',sans-serif; font-size:1.05rem; margin-bottom:.3rem; }
.pack p{ color:var(--text-2); }
.dots{ margin:.55rem 0 0 .95rem; color:var(--text-2); }
.dots li{ margin:.18rem 0; }

/* ===== PROCESS ===== */
.process{
  padding: 24px 0 10px;
}

.process h2{
  font-family:'Orbitron',sans-serif;
  color:var(--text-0);
  font-size: clamp(1.3rem, 2.6vw, 1.7rem);
  margin-bottom:.7rem;
}

.rail{
  position:relative;
  display:grid;
  gap:.8rem;

  /* alinieri */
  --step-offset: 1.2rem;   /* margin-left la .step */
  --badge-left: -1.6rem;   /* left la .badge */
  --badge-size: 24px;      /* diametru badge */
  --badge-top: .6rem;      /* top la .badge (IMPORTANT) */
  --rail-w: 3px;           /* grosime linie */

  /* centrul badge-ului pe verticală (față de fiecare .step) */
  --badge-center-y: calc(var(--badge-top) + (var(--badge-size) / 2));
}

/* linia statică: începe în centrul badge 1 și se termină în centrul ultimului badge */
.rail::before{
  content:"";
  position:absolute;
  top: var(--badge-center-y);
  bottom: var(--badge-center-y);
  width: var(--rail-w);
  border-radius:3px;
  background: rgba(148,163,184,.25);

  /* centru exact pe badge */
  left: calc(
    var(--step-offset)
    + var(--badge-left)
    + (var(--badge-size) / 2)
    - (var(--rail-w) / 2)
  );
}

/* linia animată: aceeași geometrie ca linia statică */
.rail-fill{
  position:absolute;
  top: var(--badge-center-y);
  width: var(--rail-w);
  height: 0;
  border-radius:3px;
  background: linear-gradient(180deg, #60a5fa, #22d3ee);
  transition: height .8s ease;

  left: calc(
    var(--step-offset)
    + var(--badge-left)
    + (var(--badge-size) / 2)
    - (var(--rail-w) / 2)
  );
}

.step{
  position:relative;
  margin-left: var(--step-offset);
  padding:.6rem .8rem;
  background: linear-gradient(160deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border:1px solid var(--border);
  border-radius:12px;
  box-shadow: var(--shadow);
}

.badge{
  position:absolute;
  left: var(--badge-left);
  top: 50%;
  transform: translateY(-50%);

  width: var(--badge-size);
  height: var(--badge-size);
  border-radius:50%;
  display:grid;
  place-items:center;

  color:#0b1220;
  font-weight:800;
  font-size:.9rem;
  background: linear-gradient(135deg, #60a5fa, #22d3ee);
  box-shadow: 0 0 10px rgba(34,211,238,.6);
}

.step h4{
  color:var(--text-0);
  margin:0 0 .18rem;
}

.step p{
  color:var(--text-2);
  margin:0;
}



/* ===== CTA ===== */
.cta{ padding: 34px 0 70px; }
.cta-box{
  text-align:center; padding:1.4rem;
  background: linear-gradient(145deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border:1px solid var(--border); border-radius:16px; box-shadow: var(--shadow);
}
.cta-box h3{ color:var(--text-0); font-family:'Orbitron',sans-serif; margin-bottom:.3rem; }
.cta-box p{ color:var(--text-2); margin-bottom:.9rem; }

/* ===== Reveal Animations ===== */
.reveal{ opacity:0; transform: translateY(18px); transition: opacity .6s ease, transform .6s ease; }
.reveal.is-visible{ opacity:1; transform: translateY(0); }

/* ===== Reduced Motion ===== */
@media (prefers-reduced-motion: reduce){
  .aurora, .orb, .diagram span{ animation: none !important; }
  .reveal{ transition: none; opacity:1; transform:none; }
  .card-tilt{ transition: none; }
}

/* ===== Responsive ===== */
@media (max-width: 1024px){
  .hero-neo{ height: 380px; }
  .hero-shell{ grid-template-columns: 1fr; gap: 2rem; padding: 2rem 0; }
  .hero-visual{ display:none; }
  .value-strip{ grid-template-columns: repeat(2, 1fr); }
  .panel-grid{ grid-template-columns: 1fr; }
}
@media (max-width: 640px){
  .value-strip{ grid-template-columns: 1fr; }
  .hero-neo{ height: 320px; }
}
