:root{
  --bg:#120519;
  --bg2:#241034;
  --gold:#f4c86a;
  --rose:#d85df4;
  --violet:#8b38ff;
  --text:#fff7eb;
  --muted:#d8c8e4;
  --card:rgba(255,255,255,.08);
  --line:rgba(244,200,106,.28);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}

body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;
  background:radial-gradient(circle at top,#3a1454 0,#160720 45%,#08030d 100%);
  color:var(--text);
  line-height:1.6;
  padding-bottom:82px;
}

a{color:inherit}

.stars{
  position:fixed;
  inset:0;
  pointer-events:none;
  background-image:radial-gradient(#fff 1px,transparent 1px),radial-gradient(var(--gold) 1px,transparent 1px);
  background-size:44px 44px,78px 78px;
  opacity:.15;
  z-index:-1;
}

.hero{
  padding:22px 16px 30px;
  text-align:center;
  max-width:760px;
  margin:auto;
}

.badge{
  display:inline-block;
  padding:8px 14px;
  border:1px solid var(--line);
  border-radius:999px;
  color:var(--gold);
  background:rgba(0,0,0,.25);
  font-weight:800;
  font-size:.9rem;
  margin-bottom:14px;
}

.portrait-wrap{
  width:min(72vw,310px);
  aspect-ratio:3/4;
  margin:0 auto 12px;
  border-radius:28px;
  padding:5px;
  background:linear-gradient(145deg,var(--gold),var(--rose),var(--violet));
  box-shadow:0 18px 60px rgba(216,93,244,.35);
}

.portrait{
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:24px;
  background:#2d163b;
}

.phone-main,
.phone-big{
  display:block;
  font-family:Cinzel,serif;
  color:var(--gold);
  font-size:2rem;
  text-decoration:none;
  font-weight:700;
  letter-spacing:.5px;
  text-shadow:0 0 18px rgba(244,200,106,.5);
  margin:8px 0;
}

h1,h2{
  font-family:Cinzel,serif;
  line-height:1.12;
  margin:10px 0;
  color:#fff;
}

h1{font-size:clamp(2rem,10vw,4.3rem)}
h2{font-size:clamp(1.55rem,7vw,2.6rem)}

.subtitle{
  font-weight:800;
  color:var(--gold);
  margin:0 0 10px;
}

.intro{
  color:var(--muted);
  font-size:1.03rem;
}

.cta-row{
  display:flex;
  gap:10px;
  justify-content:center;
  flex-wrap:wrap;
  margin-top:18px;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:52px;
  padding:14px 18px;
  border-radius:16px;
  text-decoration:none;
  font-weight:900;
  box-shadow:0 12px 25px rgba(0,0,0,.28);
  flex:1 1 145px;
  max-width:240px;
}

.btn-whatsapp{
  background:#18c55f;
  color:#06140b;
}

.btn-call{
  background:linear-gradient(145deg,var(--gold),#ff9d42);
  color:#211000;
}

main{
  width:min(100%,920px);
  margin:auto;
  padding:0 14px;
}

.card,
.final-cta{
  background:linear-gradient(160deg,rgba(255,255,255,.1),rgba(255,255,255,.045));
  border:1px solid var(--line);
  border-radius:26px;
  padding:22px;
  margin:18px 0;
  box-shadow:0 12px 45px rgba(0,0,0,.25);
  backdrop-filter:blur(8px);
}

.glow{box-shadow:0 0 45px rgba(139,56,255,.18)}

.dark{
  background:linear-gradient(160deg,rgba(0,0,0,.38),rgba(68,20,88,.32));
}

.eyebrow{
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.75rem;
  color:var(--gold);
  font-weight:900;
  margin:0 0 4px;
}

.service-list{padding-left:18px}
.service-list li{margin:8px 0}

.media-card{
  margin:18px 0;
  border-radius:24px;
  overflow:hidden;
  border:1px solid var(--line);
  background:rgba(0,0,0,.32);
  box-shadow:0 12px 35px rgba(0,0,0,.22);
}

.media-card img{
  display:block;
  width:100%;
  height:auto;
  min-height:260px;
  object-fit:cover;
  background:#281337;
}

.media-card figcaption{
  font-size:.86rem;
  color:var(--muted);
  padding:10px 14px;
}

/* VIDEO PORTRAIT / VERTICAL */
.video-box{
  border-radius:20px;
  overflow:hidden;
  background:#000;
  border:1px solid var(--line);
  display:flex;
  justify-content:center;
  align-items:center;
  padding:0;
}

video{
  display:block;
  width:100%;
  max-width:420px;
  aspect-ratio:9/16;
  object-fit:cover;
  background:#000;
  margin:auto;
  border-radius:20px;
}

.note,
.small-print{
  font-size:.9rem;
  color:var(--muted);
}

.reviews{
  display:grid;
  gap:12px;
}

.reviews article{
  padding:15px;
  border-radius:18px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.09);
}

.reviews strong{
  display:block;
  color:var(--gold);
  margin-bottom:5px;
}

.reviews span{color:var(--muted)}

.social-links{
  display:grid;
  gap:10px;
}

.social-links a{
  padding:14px;
  border-radius:16px;
  background:rgba(244,200,106,.12);
  border:1px solid var(--line);
  text-decoration:none;
  font-weight:800;
}

.final-cta{
  text-align:center;
  background:radial-gradient(circle at top,var(--violet),#18051f 62%);
}

.bottom-bar{
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  z-index:20;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  padding:10px 12px;
  background:rgba(8,3,13,.86);
  backdrop-filter:blur(14px);
  border-top:1px solid var(--line);
}

.bottom-bar a{
  text-align:center;
  text-decoration:none;
  font-weight:900;
  border-radius:15px;
  padding:14px 10px;
}

.bottom-bar a:first-child{
  background:#18c55f;
  color:#06140b;
}

.bottom-bar a:last-child{
  background:var(--gold);
  color:#211000;
}

/* Actualizări CTA mobile */
.btn-call,
.phone-main,
.phone-big,
.bottom-bar a:last-child{
  animation:call-vibrate 1.15s ease-in-out infinite;
  transform-origin:center;
}

@keyframes call-vibrate{
  0%,48%,100%{transform:translate3d(0,0,0) rotate(0)}
  52%{transform:translate3d(-1px,0,0) rotate(-1deg)}
  56%{transform:translate3d(2px,0,0) rotate(1deg)}
  60%{transform:translate3d(-2px,0,0) rotate(-1deg)}
  64%{transform:translate3d(2px,0,0) rotate(1deg)}
  68%{transform:translate3d(0,0,0) rotate(0)}
}

.service-grid{
  display:grid;
  gap:12px;
  margin-top:18px;
}

.service-grid article{
  padding:16px;
  border-radius:18px;
  background:rgba(255,255,255,.075);
  border:1px solid rgba(244,200,106,.22);
}

.service-grid h3{
  margin:0 0 6px;
  font-family:Cinzel,serif;
  color:var(--gold);
  font-size:1.12rem;
  line-height:1.25;
}

.service-grid p{
  margin:0;
  color:var(--muted);
}

.two-cols{columns:1}

.sticky-tiktok{
  position:fixed;
  right:14px;
  bottom:92px;
  z-index:25;
  width:64px;
  height:64px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  font-weight:900;
  font-size:.9rem;
  letter-spacing:-.02em;
  background:linear-gradient(145deg,#111,#ff2f7d 48%,#22f5ef);
  color:white;
  border:2px solid rgba(255,255,255,.45);
  box-shadow:0 12px 35px rgba(0,0,0,.45),0 0 25px rgba(216,93,244,.45);
  animation:tiktok-pulse 1.8s ease-in-out infinite;
}

@keyframes tiktok-pulse{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.08)}
}

@media(min-width:760px){
  body{padding-bottom:0}

  .bottom-bar{display:none}

  .card,
  .final-cta{
    padding:34px;
  }

  .reviews{
    grid-template-columns:repeat(2,1fr);
  }

  .media-card{
    max-width:720px;
  }

  .media-card.left{margin-right:auto}
  .media-card.right{margin-left:auto}

  .sticky-mobile-top{position:static}

  .btn{
    flex:0 0 auto;
    min-width:210px;
  }

  .service-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .two-cols{columns:2}

  .sticky-tiktok{
    bottom:24px;
    right:24px;
    width:74px;
    height:74px;
  }
}