/* ═══════════════════════════════════════
   framarketing · style.css
   ═══════════════════════════════════════ */

:root {
  --orange:  #FC7A1B;
  --red:     #F9422F;
  --magenta: #CD289C;
  --purple:  #8F2BD0;
  --dark:    #040404;
  --dark2:   #0f0f0f;
  --dark3:   #181818;
  --gray:    #6E6E6E;
  --light:   #D9D0D3;
  --grad:      linear-gradient(90deg, #FC7A1B, #F9422F, #CD289C, #8F2BD0);
  --grad-diag: linear-gradient(135deg, #FC7A1B, #F9422F, #CD289C, #8F2BD0);
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  background: var(--dark);
  color: #fff;
  font-family: 'DM Sans', sans-serif;
  overflow-x: hidden;
  opacity: 0;
  transition: opacity 0.4s ease;
}
body.loaded { opacity: 1; }

body::before {
  content: ''; position: fixed; inset: 0; pointer-events: none; z-index: 0; opacity: 0.35;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");
}

/* ── LINKS: eliminar colores de visitado y activo ── */
a { text-decoration: none; color: inherit; }
a:visited { color: inherit; }
a:active { color: inherit; }
a:visited .grad-text,
a:active .grad-text,
a:hover .grad-text {
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── NAVBAR ── */
nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.2rem 4rem;
  background: rgba(4,4,4,0.88); backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  transition: background 0.3s, box-shadow 0.3s;
}
nav.scrolled {
  background: rgba(4,4,4,0.98);
  box-shadow: 0 4px 30px rgba(0,0,0,0.4);
}
.nav-logo { display: flex; align-items: center; gap: .6rem; text-decoration: none; }
.nav-logo:visited, .nav-logo:active, .nav-logo:hover { color: inherit; }
.nav-logo img { height: 38px; width: auto; }
.nav-logo-text {
  font-family: 'Syne', sans-serif; font-weight: 800; font-size: 1.35rem;
  background: var(--grad); -webkit-background-clip: text;
  -webkit-text-fill-color: transparent; background-clip: text;
}

.nav-logo h2 {
  width: 100%;
}
.nav-links { display: flex; align-items: center; gap: 2.2rem; list-style: none; }
.nav-links a { color: var(--light); text-decoration: none; font-size: .88rem; font-weight: 500; transition: color .2s; }
.nav-links a:hover { color: #fff; }
.btn-nav {
  background: var(--grad); color: #fff !important; padding: .5rem 1.3rem;
  border-radius: 50px; font-weight: 600 !important; transition: opacity .2s, transform .2s !important;
}
.btn-nav:hover { opacity: .85; transform: translateY(-1px); }

/* ── HERO ── */
.hero {
  position: relative; min-height: 100vh;
  display: flex; align-items: center;
  padding: 8rem 4rem 5rem; overflow: hidden;
}
.hero-visual {
  position: absolute; inset: 0; z-index: 0; height: 100%;
  border-radius: 0; overflow: hidden;
}
.hero-img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: right center;
  filter: brightness(0.9) saturate(1.3);
  transition: transform 0.4s ease;
}
.hero-visual::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(
    to right,
    rgba(4,4,4,0.95) 0%,
    rgba(4,4,4,0.85) 35%,
    rgba(4,4,4,0.2) 55%,
    rgba(4,4,4,0.0) 100%
  );
}
.hero-content { position: relative; z-index: 2; max-width: 600px; }

.badge {
  display: inline-flex; align-items: center; gap: .5rem;
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1);
  border-radius: 50px; padding: .38rem 1rem; font-size: .78rem;
  color: var(--light); margin-bottom: 1.8rem; letter-spacing: .05em;
  animation: fadeUp .6s ease both;
}
.dot { width: 8px; height: 8px; border-radius: 50%; background: var(--grad); animation: pulse 2s infinite; }
@keyframes pulse { 0%,100%{transform:scale(1);opacity:1;} 50%{transform:scale(1.5);opacity:.6;} }

.hero h1 {
  font-family: 'Syne', sans-serif;
  font-size: clamp(2.4rem, 4.5vw, 4.2rem);
  font-weight: 800; line-height: 1.08; margin-bottom: 1.4rem;
  animation: fadeUp .7s .1s ease both;
}

.grad-text {
  background: var(--grad); -webkit-background-clip: text;
  -webkit-text-fill-color: transparent; background-clip: text;
}
.hero p {
  font-size: 1.05rem; color: var(--light); line-height: 1.72;
  max-width: 460px; margin-bottom: 2.4rem; font-weight: 300;
  animation: fadeUp .7s .2s ease both;
}
.ctas { display: flex; gap: 1rem; flex-wrap: wrap; animation: fadeUp .7s .3s ease both; }
.btn-primary {
  background: var(--grad); color: #fff; padding: .88rem 2.1rem; border-radius: 50px;
  font-weight: 600; font-size: .98rem; text-decoration: none;
  transition: transform .2s, box-shadow .2s;
  box-shadow: 0 8px 28px rgba(205,40,156,.3);
}
.btn-primary:hover { transform: translateY(-3px); box-shadow: 0 14px 40px rgba(205,40,156,.45); }
.btn-sec {
  background: transparent; color: #fff; padding: .88rem 2.1rem; border-radius: 50px;
  font-weight: 500; font-size: .98rem; text-decoration: none;
  border: 1px solid rgba(255,255,255,.18); transition: border-color .2s, background .2s;
}
.btn-sec:hover { border-color: rgba(255,255,255,.45); background: rgba(255,255,255,.04); }

.hero-stats-right { display: none; }

.blob { position: absolute; border-radius: 50%; filter: blur(70px); animation: float 9s ease-in-out infinite; z-index: 1; }
.blob1 { top: -5%; right: -5%; width: 650px; height: 650px; background: radial-gradient(circle, rgba(205,40,156,.18), rgba(143,43,208,.1), transparent 70%); }
.blob2 { bottom: -10%; left: -8%; width: 480px; height: 480px; background: radial-gradient(circle, rgba(252,122,27,.12), transparent 70%); animation-duration: 12s; animation-direction: reverse; }
@keyframes float { 0%,100%{transform:translateY(0) scale(1);} 50%{transform:translateY(-28px) scale(1.04);} }

/* ── SCROLL REVEAL ── */
.reveal { opacity: 0; transform: translateY(30px); transition: opacity 0.7s ease, transform 0.7s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ── SECCIONES ── */
section { position: relative; z-index: 1; }
.sec-label { display:inline-block; font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--magenta); font-weight:600; margin-bottom:.9rem; }
.sec-title { font-family:'Syne',sans-serif; font-size:clamp(1.9rem,3.8vw,2.9rem); font-weight:800; line-height:1.1; margin-bottom:.9rem; }
.sec-sub { color:var(--gray); font-size:.96rem; max-width:510px; line-height:1.72; }

/* ── SERVICIOS ── */
#servicios { padding: 8rem 4rem; background: var(--dark2); }
.srv-header { margin-bottom: 3.5rem; }
.srv-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(270px, 1fr)); gap: 1.4rem; }
.srv-card {
  background: var(--dark3); border: 1px solid rgba(255,255,255,.06);
  border-radius: 20px; padding: 1.9rem; position: relative; overflow: hidden;
  transition: transform .3s; display: flex; flex-direction: column;
}
.srv-card::before {
  content: ''; position: absolute; inset: 0; border-radius: 20px; padding: 1px;
  background: var(--grad);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: destination-out; mask-composite: exclude;
  opacity: 0; transition: opacity .3s;
}
.srv-card:hover { transform: translateY(-5px); }
.srv-card:hover::before { opacity: 1; }
.srv-icon { width:48px; height:48px; border-radius:13px; background:rgba(205,40,156,.1); display:flex; align-items:center; justify-content:center; margin-bottom:1.2rem; font-size:1.4rem; }
.srv-card h3 { font-family:'Syne',sans-serif; font-size:1.12rem; font-weight:700; margin-bottom:.6rem; }
.srv-card p { color:var(--gray); font-size:.88rem; line-height:1.68; }
.srv-tag { display:inline-block; margin-top:auto; padding-top:1.1rem; font-size:.73rem; font-weight:600; background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }

/* ── TARIFAS ── */
#tarifas { padding: 8rem 4rem; }
.pricing-section-title { font-family:'Syne',sans-serif; font-size:1rem; font-weight:600; color:var(--gray); letter-spacing:.08em; text-transform:uppercase; margin-bottom:1.5rem; }
.pricing-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(290px, 1fr)); gap: 1.4rem; }
.price-card {
  background: var(--dark3); border: 1px solid rgba(255,255,255,.07);
  border-radius: 22px; padding: 2.2rem; position: relative; overflow: hidden;
  transition: transform .3s; display: flex; flex-direction: column;
}
.price-card:hover { transform: translateY(-4px); }
.price-card.featured {
  border-color: transparent;
  background: linear-gradient(var(--dark3), var(--dark3)) padding-box, var(--grad) border-box;
  border: 2px solid transparent;
}
.featured-badge { position: absolute; top: 1.2rem; right: 1.2rem; background: var(--grad); color: #fff; font-size: .65rem; font-weight: 700; letter-spacing: .08em; padding: .25rem .7rem; border-radius: 50px; text-transform: uppercase; }
.price-icon { font-size: 1.8rem; margin-bottom: 1rem; }
.price-card h3 { font-family:'Syne',sans-serif; font-size:1.1rem; font-weight:700; margin-bottom:.4rem; }
.price-note { color:var(--gray); font-size:.8rem; margin-bottom:1.2rem; font-style: italic; }
.price-amount { font-family: 'Syne', sans-serif; font-size: 2.6rem; font-weight: 800; background: var(--grad); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; line-height: 1; margin-bottom: .3rem; }
.price-period { color: var(--gray); font-size: .82rem; margin-bottom: 1.5rem; }
.price-items { list-style: none; display: flex; flex-direction: column; gap: .6rem; }
.price-items li { display: flex; align-items: flex-start; gap: .6rem; font-size: .88rem; color: var(--light); line-height: 1.5; }
.price-items li::before { content:'✓'; color: var(--magenta); font-weight: 700; flex-shrink:0; margin-top:1px; }
.price-divider { height: 1px; background: rgba(255,255,255,.06); margin: 1.5rem 0; }
.price-cta {
  display: block; text-align: center; margin-top: auto;
  background: var(--grad); color: #fff; padding: .75rem;
  border-radius: 50px; font-weight: 600; font-size: .9rem;
  text-decoration: none; transition: opacity .2s, transform .2s;
}
.price-cta:hover { opacity: .88; transform: translateY(-2px); }
.price-cta.outline { background: transparent; border: 1px solid rgba(255,255,255,.15); color: var(--light); }
.price-cta.outline:hover { border-color: rgba(255,255,255,.4); color: #fff; }

/* ── SERVICIO 360 ── */
.s360-banner { margin-top: 2rem; border-radius: 22px; padding: 2.5rem 3rem; background: var(--grad); display: flex; align-items: center; justify-content: space-between; gap: 2rem; flex-wrap: wrap; }
.s360-banner h3 { font-family:'Syne',sans-serif; font-size:1.6rem; font-weight:800; margin-bottom:.4rem; }
.s360-banner p { font-size:.92rem; opacity:.88; max-width:500px; line-height:1.6; }
.s360-label { font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; opacity:.8; margin-bottom:.5rem; }
.s360-price { text-align: right; flex-shrink: 0; }
.s360-price .big { font-family:'Syne',sans-serif; font-size:3rem; font-weight:800; line-height:1; }
.s360-price small { font-size:.82rem; opacity:.8; }
.btn-white { background:#fff; color:var(--purple); font-weight:700; padding:.75rem 1.8rem; border-radius:50px; text-decoration:none; font-size:.9rem; display:inline-block; margin-top:1rem; transition:transform .2s; }
.btn-white:hover { transform:translateY(-2px); }

/* ── POR QUE ── */
#porque { padding: 8rem 4rem; background: var(--dark2); }
.porque-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; }
.feature { display:flex; align-items:flex-start; gap:1rem; margin-bottom:1.5rem; }
.fcheck { width:28px; height:28px; border-radius:8px; background:var(--grad-diag); display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:.8rem; margin-top:2px; }
.feature h4 { font-family:'Syne',sans-serif; font-size:.98rem; font-weight:700; margin-bottom:.3rem; }
.feature p { color:var(--gray); font-size:.86rem; line-height:1.62; }
.result-card { background:var(--dark3); border:1px solid rgba(255,255,255,.08); border-radius:22px; padding:2.3rem; position:relative; overflow:hidden; }
.result-card::after { content:''; position:absolute; top:-40%; right:-20%; width:280px; height:280px; background:radial-gradient(circle,rgba(205,40,156,.14),transparent 70%); border-radius:50%; }
.result-label { font-family:'Syne',sans-serif; font-size:.72rem; letter-spacing:.1em; color:var(--gray); text-transform:uppercase; margin-bottom:.5rem; }
.result-title { font-family:'Syne',sans-serif; font-weight:700; font-size:1.15rem; margin-bottom:.3rem; }
.result-sub { color:var(--gray); font-size:.84rem; margin-bottom:1.8rem; }
.result-stats { display:flex; gap:2rem; margin-bottom:1.8rem; }
.result-num { font-family:'Syne',sans-serif; font-weight:800; font-size:2rem; }
.result-stat-label { color:var(--gray); font-size:.78rem; }
.result-bar { height:4px; border-radius:2px; background:var(--grad); margin-bottom:.5rem; }
.result-footer { color:var(--gray); font-size:.74rem; }

/* ── PROCESO ── */
#proceso { padding: 8rem 4rem; }
.proceso-head { text-align:center; margin-bottom:4rem; }
.proceso-head .sec-sub { margin:0 auto; }
.steps { display:grid; grid-template-columns:repeat(4,1fr); gap:0; position:relative; }
.steps::before { content:''; position:absolute; top:30px; left:12%; right:12%; height:1px; background:linear-gradient(90deg,transparent,var(--magenta),var(--purple),transparent); }
.step { display:flex; flex-direction:column; align-items:center; text-align:center; padding:0 1.3rem; }
.step-n { width:60px; height:60px; border-radius:50%; background:var(--grad); display:flex; align-items:center; justify-content:center; font-family:'Syne',sans-serif; font-weight:800; font-size:1.05rem; margin-bottom:1.4rem; position:relative; z-index:1; box-shadow:0 0 0 6px var(--dark); }
.step h4 { font-family:'Syne',sans-serif; font-weight:700; margin-bottom:.5rem; }
.step p { color:var(--gray); font-size:.84rem; line-height:1.6; }

/* ── CONTACTO ── */
#contacto { padding: 8rem 4rem; background: var(--dark2); }
.contacto-grid { display:grid; grid-template-columns:1fr 1.2fr; gap:5rem; align-items:start; }
.form-box { background:var(--dark3); border:1px solid rgba(255,255,255,.07); border-radius:22px; padding:2.4rem; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.fg { margin-bottom:1.1rem; }
.fg label { display:block; font-size:.76rem; color:var(--gray); margin-bottom:.45rem; letter-spacing:.05em; }
.fg input, .fg textarea, .fg select { width:100%; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); border-radius:11px; padding:.8rem 1.1rem; color:#fff; font-family:'DM Sans',sans-serif; font-size:.92rem; outline:none; transition:border-color .2s; }
.fg input:focus, .fg textarea:focus, .fg select:focus { border-color:var(--magenta); }
.fg textarea { height:120px; resize:none; }
.fg select option { background:var(--dark3); }
.contact-info { display:flex; flex-direction:column; gap:1rem; margin-top:1.8rem; }
.ci { display:flex; align-items:center; gap:.8rem; color:var(--gray); font-size:.9rem; }
.ci span { font-size:1.1rem; }
.form-note { text-align:center; color:var(--gray); font-size:.76rem; margin-top:.8rem; }

/* ── FOOTER ── */
footer { background:var(--dark); border-top:1px solid rgba(255,255,255,.06); padding:2.5rem 4rem; display:flex; align-items:center; justify-content:space-between; position:relative; z-index:1; }
.fcopy { color:var(--gray); font-size:.82rem; }
.flinks { display:flex; gap:2rem; list-style:none; }
.flinks a { color:var(--gray); text-decoration:none; font-size:.82rem; transition:color .2s; }
.flinks a:hover { color:#fff; }

/* ── ANIMACIONES ── */
@keyframes fadeUp { from{opacity:0;transform:translateY(18px);} to{opacity:1;transform:translateY(0);} }
@keyframes shake { 0%,100%{transform:translateX(0);} 25%{transform:translateX(-8px);} 75%{transform:translateX(8px);} }

/* ── RESPONSIVE ── */
@media(max-width:900px){
  nav { padding:1rem 1.5rem; }
  .nav-links { display:none; }
  .hero { padding:7rem 1.5rem 4rem; }
  .hero-stats-right { display:none; }
  .hero-img { object-position: center center; }
  #servicios, #tarifas, #porque, #proceso, #contacto { padding:5rem 1.5rem; }
  .porque-grid, .contacto-grid { grid-template-columns:1fr; gap:3rem; }
  .steps { grid-template-columns:1fr 1fr; gap:2rem; }
  .steps::before { display:none; }
  .s360-banner { flex-direction:column; }
  .s360-price { text-align:left; }
  footer { flex-direction:column; gap:1rem; text-align:center; }
}

/* ── FAQ ── */
#faq { padding: 8rem 4rem; background: var(--dark2); }
.faq-head { text-align: center; margin-bottom: 3.5rem; }
.faq-head .sec-sub { margin: 0 auto; }
.faq-list { max-width: 780px; margin: 0 auto; display: flex; flex-direction: column; gap: .8rem; }
.faq-item { border: 1px solid rgba(255,255,255,.07); border-radius: 14px; overflow: hidden; background: var(--dark3); }
.faq-btn {
  width: 100%; display: flex; justify-content: space-between; align-items: center;
  padding: 1.3rem 1.6rem; background: transparent; border: none; color: #fff;
  font-family: 'Syne', sans-serif; font-size: 1rem; font-weight: 600;
  cursor: pointer; text-align: left; gap: 1rem; transition: color .2s;
}
.faq-btn:hover { color: var(--magenta); }
.faq-icon {
  font-size: 1.4rem; font-weight: 300; flex-shrink: 0; color: var(--magenta);
  transition: transform .3s;
}
.faq-item.open .faq-icon { transform: rotate(45deg); }
.faq-answer {
  max-height: 0; overflow: hidden;
  transition: max-height .4s ease, padding .3s ease;
}
.faq-item.open .faq-answer { max-height: 300px; }
.faq-answer p {
  padding: 0 1.6rem 1.4rem;
  color: var(--gray); font-size: .92rem; line-height: 1.72;
}
@media(max-width:900px){
  #faq { padding: 5rem 1.5rem; }
}