/* ===========================================================
   Pulse — Marketing Online
   Shared stylesheet (modern & bold)
   Schimbă numele brandului "Pulse" în fișierele .html.
   Culori de brand: editează variabilele din :root de mai jos.
   =========================================================== */

:root {
  --bg:        #0a0a12;
  --bg-soft:   #12121f;
  --card:      #16162a;
  --text:      #f4f4fb;
  --muted:     #a2a2c0;
  --line:      rgba(255,255,255,.09);

  --brand:     #7c3aed;   /* violet */
  --brand-2:   #ec4899;   /* magenta */
  --accent:    #22d3ee;   /* cyan */
  --grad: linear-gradient(120deg, #7c3aed 0%, #ec4899 55%, #f59e0b 100%);
  --grad-2: linear-gradient(120deg, #22d3ee, #7c3aed);

  --radius: 20px;
  --maxw: 1160px;
  --font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
a { color:inherit; text-decoration:none; }
img { max-width:100%; display:block; }

.container { max-width:var(--maxw); margin:0 auto; padding:0 24px; }
.section { padding:100px 0; position:relative; }
.section-sm { padding:64px 0; }

/* ---------- Typography ---------- */
h1,h2,h3 { line-height:1.12; font-weight:800; letter-spacing:-.02em; }
h1 { font-size:clamp(2.4rem, 6vw, 4.4rem); }
h2 { font-size:clamp(1.9rem, 4vw, 3rem); }
h3 { font-size:1.3rem; }
.lead { font-size:1.18rem; color:var(--muted); max-width:620px; }
.eyebrow {
  display:inline-block; font-size:.8rem; font-weight:700;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--accent); margin-bottom:18px;
}
.grad-text {
  background:var(--grad); -webkit-background-clip:text;
  background-clip:text; color:transparent;
}
.center { text-align:center; }
.center .lead { margin-left:auto; margin-right:auto; }

/* ---------- Buttons ---------- */
.btn {
  display:inline-flex; align-items:center; gap:9px;
  padding:15px 30px; border-radius:100px; font-weight:700;
  font-size:.98rem; cursor:pointer; border:none;
  transition:transform .2s ease, box-shadow .2s ease; white-space:nowrap;
}
.btn-primary { background:var(--grad); color:#fff; box-shadow:0 10px 30px rgba(124,58,237,.35); }
.btn-primary:hover { transform:translateY(-3px); box-shadow:0 16px 40px rgba(236,72,153,.45); }
.btn-ghost { background:transparent; color:var(--text); border:1.5px solid var(--line); }
.btn-ghost:hover { border-color:var(--accent); color:var(--accent); transform:translateY(-3px); }

/* ---------- Navbar ---------- */
.nav {
  position:sticky; top:0; z-index:50;
  background:rgba(10,10,18,.7); backdrop-filter:blur(16px);
  border-bottom:1px solid var(--line);
}
.nav-inner { display:flex; align-items:center; justify-content:space-between; height:74px; }
.logo { display:inline-block; font-family:'Great Vibes', cursive; font-weight:400; font-size:2.1rem; line-height:1; letter-spacing:0; color:var(--text); }
.logo-mark {
  width:34px; height:34px; border-radius:10px; display:block;
  box-shadow:0 6px 18px rgba(124,58,237,.4);
}
.nav-links { display:flex; align-items:center; gap:34px; list-style:none; }
.nav-links a { color:var(--muted); font-weight:600; font-size:.96rem; transition:color .2s; }
.nav-links a:hover, .nav-links a.active { color:var(--text); }
.nav-cta { display:flex; align-items:center; gap:16px; }
.burger { display:none; background:none; border:none; color:var(--text); cursor:pointer; font-size:1.6rem; }

@media (max-width:860px){
  .nav-links {
    position:absolute; top:74px; left:0; right:0; flex-direction:column;
    gap:0; background:var(--bg-soft); border-bottom:1px solid var(--line);
    max-height:0; overflow:hidden; transition:max-height .35s ease;
  }
  .nav-links.open { max-height:340px; }
  .nav-links li { width:100%; text-align:center; }
  .nav-links a { display:block; padding:16px; border-top:1px solid var(--line); }
  .nav-cta .btn { display:none; }
  .burger { display:block; }
}

/* ---------- Hero ---------- */
.hero { position:relative; padding:120px 0 90px; overflow:hidden; }
.hero .container { position:relative; z-index:2; }
.blob {
  position:absolute; border-radius:50%; filter:blur(90px); opacity:.5; z-index:0;
}
.blob-1 { width:520px; height:520px; background:var(--brand); top:-160px; right:-120px; }
.blob-2 { width:420px; height:420px; background:var(--brand-2); bottom:-180px; left:-100px; opacity:.35; }
.hero h1 { max-width:14ch; }
.hero .lead { margin-top:22px; }
.hero-actions { margin-top:38px; display:flex; gap:16px; flex-wrap:wrap; }
.hero-stats { margin-top:64px; display:flex; gap:48px; flex-wrap:wrap; }
.hero-stats .num { font-size:2.3rem; font-weight:800; }
.hero-stats .lbl { color:var(--muted); font-size:.92rem; }

/* ---------- Cards / grid ---------- */
.grid { display:grid; gap:24px; }
.grid-2 { grid-template-columns:repeat(2,1fr); }
.grid-3 { grid-template-columns:repeat(3,1fr); }
.grid-4 { grid-template-columns:repeat(4,1fr); }
@media (max-width:920px){ .grid-3,.grid-4 { grid-template-columns:repeat(2,1fr); } }
@media (max-width:640px){ .grid-2,.grid-3,.grid-4 { grid-template-columns:1fr; } }

.card {
  background:var(--card); border:1px solid var(--line); border-radius:var(--radius);
  padding:34px 30px; transition:transform .25s ease, border-color .25s ease;
}
.card:hover { transform:translateY(-6px); border-color:rgba(124,58,237,.5); }
.card .ico {
  width:54px; height:54px; border-radius:14px; display:grid; place-items:center;
  font-size:1.5rem; margin-bottom:20px; background:rgba(124,58,237,.15);
}
.card h3 { margin-bottom:10px; }
.card p { color:var(--muted); font-size:.98rem; }

.pill {
  display:inline-block; padding:5px 14px; border-radius:100px; font-size:.82rem;
  font-weight:600; background:rgba(34,211,238,.12); color:var(--accent); margin:4px 6px 4px 0;
}

/* ---------- Feature split ---------- */
.split { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
@media (max-width:860px){ .split { grid-template-columns:1fr; gap:36px; } }
.media-box {
  border-radius:var(--radius); background:var(--grad); min-height:340px;
  display:grid; place-items:center; font-size:5rem; box-shadow:0 30px 60px rgba(124,58,237,.3);
}
.check-list { list-style:none; margin-top:22px; display:grid; gap:14px; }
.check-list li { display:flex; gap:12px; align-items:flex-start; color:var(--muted); }
.check-list li::before { content:'✓'; color:var(--accent); font-weight:800; }

/* ---------- Stats band ---------- */
.band { background:var(--bg-soft); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.stat-num { font-size:2.8rem; font-weight:800; }
.stat-num.grad-text { display:inline-block; }

/* ---------- Pricing ---------- */
.price-card { position:relative; }
.price-card.featured { border-color:var(--brand); box-shadow:0 30px 60px rgba(124,58,237,.25); }
.badge-top {
  position:absolute; top:-13px; left:50%; transform:translateX(-50%);
  background:var(--grad); color:#fff; padding:5px 16px; border-radius:100px;
  font-size:.78rem; font-weight:700;
}
.price { font-size:2.6rem; font-weight:800; margin:14px 0 4px; }
.price small { font-size:1rem; color:var(--muted); font-weight:500; }

/* ---------- Steps ---------- */
.step-num {
  width:46px; height:46px; border-radius:12px; background:var(--grad-2);
  display:grid; place-items:center; font-weight:800; margin-bottom:16px;
}

/* ---------- CTA band ---------- */
.cta-band {
  background:var(--grad); border-radius:28px; padding:64px 48px; text-align:center;
  box-shadow:0 30px 70px rgba(124,58,237,.35);
}
.cta-band h2 { color:#fff; }
.cta-band p { color:rgba(255,255,255,.9); max-width:560px; margin:14px auto 30px; }
.cta-band .btn-primary { background:#fff; color:#12121f; }

/* ---------- Forms ---------- */
.field { margin-bottom:20px; }
.field label { display:block; font-weight:600; font-size:.92rem; margin-bottom:8px; }
.field input, .field textarea, .field select {
  width:100%; padding:14px 16px; border-radius:12px; border:1px solid var(--line);
  background:var(--bg-soft); color:var(--text); font-family:inherit; font-size:.98rem;
}
.field input:focus, .field textarea:focus, .field select:focus {
  outline:none; border-color:var(--brand);
}
.field textarea { resize:vertical; min-height:130px; }

/* ---------- FAQ ---------- */
.faq-item { border:1px solid var(--line); border-radius:14px; padding:22px 24px; background:var(--card); cursor:pointer; }
.faq-item + .faq-item { margin-top:14px; }
.faq-item summary { font-weight:700; list-style:none; display:flex; justify-content:space-between; align-items:center; }
.faq-item summary::-webkit-details-marker { display:none; }
.faq-item summary::after { content:'+'; color:var(--accent); font-size:1.5rem; }
.faq-item[open] summary::after { content:'–'; }
.faq-item p { color:var(--muted); margin-top:14px; }

/* ---------- Footer ---------- */
.footer { background:var(--bg-soft); border-top:1px solid var(--line); padding:64px 0 32px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:40px; }
@media (max-width:760px){ .footer-grid { grid-template-columns:1fr 1fr; gap:32px; } }
.footer h4 { font-size:.85rem; text-transform:uppercase; letter-spacing:.12em; color:var(--muted); margin-bottom:18px; }
.footer ul { list-style:none; display:grid; gap:11px; }
.footer ul a { color:var(--muted); font-size:.95rem; transition:color .2s; }
.footer ul a:hover { color:var(--text); }
.footer-bottom {
  margin-top:48px; padding-top:24px; border-top:1px solid var(--line);
  display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap;
  color:var(--muted); font-size:.88rem;
}

/* ---------- Reveal animation (CSS-only, no JS needed) ---------- */
/* Conținutul e vizibil implicit; animația e doar un bonus la încărcare. */
.reveal { animation: revealIn .7s ease both; }
@keyframes revealIn {
  from { opacity:0; transform:translateY(24px); }
  to   { opacity:1; transform:none; }
}
/* Dacă JS-ul rulează totuși, clasa .in nu strică nimic. */
.reveal.in { opacity:1; transform:none; }
