*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --p1:#A78BFA;--p2:#C4B5FD;--p3:#7C3AED;
  --b1:#60A5FA;--b2:#93C5FD;--b3:#1D4ED8;
  --pk:#F472B6;--pk2:#FBCFE8;
  --sl:#CBD5E1;--sl2:#E2E8F0;
  --bg:#04040F;--dark:#080818;--dark2:#0E0E24;--dark3:#14142E;
  --white:#F0EEFF;--muted:#6B7280;--muted2:#9CA3AF;
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--white);font-family:'Inter',sans-serif;font-weight:300;overflow-x:hidden}
#particles{position:fixed;inset:0;z-index:0;pointer-events:none}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:500;display:flex;justify-content:space-between;align-items:center;padding:1.4rem 4rem;transition:all 0.5s}
nav.scrolled{background:rgba(4,4,15,0.93);backdrop-filter:blur(24px);padding:1rem 4rem;border-bottom:1px solid rgba(167,139,250,0.1)}
.nav-logo{display:flex;align-items:center;gap:0.8rem;text-decoration:none}
.nav-logo-img{width:52px;height:52px;border-radius:50%;object-fit:cover;border:1px solid rgba(167,139,250,0.3);box-shadow:0 0 18px rgba(167,139,250,0.25)}
.nav-logo-text{font-family:'Bebas Neue',sans-serif;font-size:1.8rem;letter-spacing:0.12em;background:linear-gradient(135deg,#A78BFA,#60A5FA,#F472B6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.nav-links{display:flex;gap:2.8rem;list-style:none;align-items:center}
.nav-links a{color:#C4B5FD;text-decoration:none;font-size:0.78rem;letter-spacing:0.18em;text-transform:uppercase;transition:color 0.3s}
.nav-links a:hover{color:var(--white)}
.nav-cta{background:transparent !important;color:var(--p1) !important;border:1px solid rgba(167,139,250,0.4) !important;padding:0.6rem 1.6rem;position:relative;overflow:hidden;transition:all 0.4s !important;border-radius:2px}
.nav-cta::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(167,139,250,0.2),rgba(96,165,250,0.2));transform:translateX(-101%);transition:transform 0.4s cubic-bezier(0.4,0,0.2,1)}
.nav-cta:hover::before{transform:translateX(0)}
.nav-cta span{position:relative;z-index:1}

/* HERO */
.hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;align-items:center;position:relative;padding:7rem 4rem 4rem;overflow:hidden;gap:3rem}

/* ANIMATED BG */
.hero-bg{position:absolute;inset:0;overflow:hidden}
.bg-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:0.18;animation:orbFloat 12s ease-in-out infinite}
.bg-orb1{width:600px;height:600px;background:radial-gradient(circle,#7C3AED,transparent);top:-100px;left:-100px;animation-delay:0s}
.bg-orb2{width:500px;height:500px;background:radial-gradient(circle,#1D4ED8,transparent);top:100px;right:-100px;animation-delay:3s}
.bg-orb3{width:400px;height:400px;background:radial-gradient(circle,#BE185D,transparent);bottom:-100px;left:30%;animation-delay:6s}
@keyframes orbFloat{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(30px,-20px) scale(1.05)}66%{transform:translate(-20px,30px) scale(0.95)}}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(167,139,250,0.03) 1px,transparent 1px),linear-gradient(90deg,rgba(167,139,250,0.03) 1px,transparent 1px);background-size:70px 70px;pointer-events:none}
.hero-vline{position:absolute;top:0;bottom:0;left:50%;width:1px;background:linear-gradient(to bottom,transparent,rgba(167,139,250,0.15) 30%,rgba(167,139,250,0.15) 70%,transparent);pointer-events:none}

.hero-left{position:relative;z-index:2}
.eyebrow{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;opacity:0;animation:slideUp 1s ease 0.3s forwards}
.eyebrow-line{width:40px;height:1px;background:linear-gradient(to right,var(--p1),transparent)}
.eyebrow-text{font-size:0.7rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--p1)}
.hero-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(4rem,8vw,7.5rem);line-height:0.9;letter-spacing:0.01em;opacity:0;animation:slideUp 1s ease 0.5s forwards}
.hero-title .grad{background:linear-gradient(135deg,#A78BFA 0%,#60A5FA 50%,#F472B6 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-title .outline{-webkit-text-stroke:1.5px rgba(167,139,250,0.5);color:transparent}
.hero-title .white{color:var(--white)}
.hero-desc{margin-top:2rem;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.2rem;color:#C4B5FD;line-height:1.8;max-width:420px;opacity:0;animation:slideUp 1s ease 0.7s forwards}
.hero-btns{display:flex;gap:1rem;margin-top:2.5rem;flex-wrap:wrap;opacity:0;animation:slideUp 1s ease 0.9s forwards}
.btn-primary{background:linear-gradient(135deg,#7C3AED,#1D4ED8);color:#fff;padding:1rem 2.5rem;border:none;font-family:'Inter',sans-serif;font-size:0.78rem;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;text-decoration:none;cursor:pointer;position:relative;overflow:hidden;transition:transform 0.3s,box-shadow 0.3s;display:inline-block;border-radius:2px}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 20px 50px rgba(124,58,237,0.4)}
.btn-ghost{background:transparent;color:var(--sl);padding:1rem 2.5rem;border:1px solid rgba(167,139,250,0.25);font-family:'Inter',sans-serif;font-size:0.78rem;letter-spacing:0.15em;text-transform:uppercase;text-decoration:none;cursor:pointer;transition:border-color 0.3s,color 0.3s;display:inline-block;border-radius:2px}
.btn-ghost:hover{border-color:rgba(167,139,250,0.6);color:var(--p1)}

/* HERO RIGHT — LOGO */
.hero-right{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;opacity:0;animation:fadeIn 1.5s ease 0.6s forwards}
.logo-showcase{position:relative;width:100%;max-width:420px;aspect-ratio:1;display:flex;align-items:center;justify-content:center}
.logo-ring1{position:absolute;inset:0;border-radius:50%;border:1px solid rgba(167,139,250,0.12);animation:spinRing 20s linear infinite}
.logo-ring2{position:absolute;inset:20px;border-radius:50%;border:1px solid rgba(96,165,250,0.08);animation:spinRing 15s linear infinite reverse}
.logo-ring3{position:absolute;inset:40px;border-radius:50%;border:1px solid rgba(244,114,182,0.06);animation:spinRing 25s linear infinite}
.logo-glow{position:absolute;inset:40px;border-radius:50%;background:radial-gradient(circle,rgba(124,58,237,0.12) 0%,transparent 70%);animation:glowPulse 4s ease-in-out infinite}
.logo-img{width:80%;height:80%;border-radius:50%;object-fit:cover;position:relative;z-index:2;filter:drop-shadow(0 0 30px rgba(167,139,250,0.4)) drop-shadow(0 0 60px rgba(96,165,250,0.2))}
@keyframes spinRing{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes glowPulse{0%,100%{opacity:0.5;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}
.logo-dots{position:absolute;inset:0}
.logo-dot{position:absolute;width:6px;height:6px;border-radius:50%;background:var(--p1);box-shadow:0 0 10px rgba(167,139,250,0.8);animation:dotPulse 3s ease-in-out infinite}
.logo-dot:nth-child(1){top:8%;left:50%;transform:translateX(-50%);animation-delay:0s}
.logo-dot:nth-child(2){top:50%;right:5%;transform:translateY(-50%);animation-delay:0.75s;background:var(--b1);box-shadow:0 0 10px rgba(96,165,250,0.8)}
.logo-dot:nth-child(3){bottom:8%;left:50%;transform:translateX(-50%);animation-delay:1.5s;background:var(--pk);box-shadow:0 0 10px rgba(244,114,182,0.8)}
.logo-dot:nth-child(4){top:50%;left:5%;transform:translateY(-50%);animation-delay:2.25s;background:var(--sl);box-shadow:0 0 10px rgba(203,213,225,0.8)}
@keyframes dotPulse{0%,100%{opacity:0.4;transform:translateX(-50%) scale(1)}50%{opacity:1;transform:translateX(-50%) scale(1.5)}}

/* HERO STATS */
.hero-stats{position:absolute;bottom:2.5rem;left:4rem;display:flex;gap:3rem;z-index:2;opacity:0;animation:slideUp 1s ease 1.1s forwards}
.hstat-num{font-family:'Bebas Neue',sans-serif;font-size:2.5rem;background:linear-gradient(135deg,#A78BFA,#60A5FA);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.hstat-label{font-size:0.65rem;letter-spacing:0.18em;text-transform:uppercase;color:#6B7280;margin-top:0.2rem}

/* MARQUEE */
.marquee-wrap{overflow:hidden;padding:0;position:relative;z-index:2;background:linear-gradient(90deg,#4C1D95,#1E3A8A,#831843,#4C1D95);border-top:1px solid rgba(167,139,250,0.15);border-bottom:1px solid rgba(167,139,250,0.15)}
.marquee-track{display:inline-flex;animation:marquee 30s linear infinite;white-space:nowrap;padding:0.9rem 0}
.mitem{font-family:'Bebas Neue',sans-serif;font-size:1rem;letter-spacing:0.2em;color:rgba(255,255,255,0.75);padding:0 2.5rem;display:inline-flex;align-items:center;gap:2.5rem}
.mdot{width:4px;height:4px;background:rgba(255,255,255,0.4);border-radius:50%;display:inline-block}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* SECTION */
.sec-label{display:inline-flex;align-items:center;gap:0.8rem;font-size:0.7rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--p1);margin-bottom:1.2rem}
.sec-label::before{content:'';display:inline-block;width:28px;height:1px;background:linear-gradient(to right,var(--p1),var(--b1))}
.sec-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.8rem,5vw,4.5rem);line-height:0.92;letter-spacing:0.02em}
.grad-title{background:linear-gradient(135deg,#A78BFA,#60A5FA);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.dim{-webkit-text-stroke:1px rgba(167,139,250,0.2);color:transparent}

/* SERVICES */
.services-section{padding:8rem 4rem;background:var(--dark)}
.svc-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:4.5rem;gap:3rem;flex-wrap:wrap}
.svc-tagline{max-width:280px;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.15rem;color:#C4B5FD;line-height:1.7}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(167,139,250,0.07)}
.svc{background:var(--dark);padding:2.8rem 2.2rem;position:relative;overflow:hidden;transition:background 0.5s}
.svc::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--p1),var(--b1),transparent);transform:scaleX(0);transition:transform 0.5s;transform-origin:center}
.svc:hover{background:var(--dark2)}
.svc:hover::after{transform:scaleX(1)}
.svc-glow-inner{position:absolute;inset:0;background:radial-gradient(circle at var(--mx,50%) var(--my,100%),rgba(124,58,237,0.07) 0%,transparent 55%);opacity:0;transition:opacity 0.5s}
.svc:hover .svc-glow-inner{opacity:1}
.svc-n{font-family:'Bebas Neue',sans-serif;font-size:5rem;background:linear-gradient(135deg,rgba(167,139,250,0.05),rgba(96,165,250,0.05));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:absolute;top:0.5rem;right:1rem;line-height:1;pointer-events:none}
.svc-icon{width:48px;height:48px;margin-bottom:1.8rem;position:relative;z-index:1}
.svc-name{font-family:'Bebas Neue',sans-serif;font-size:1.6rem;letter-spacing:0.04em;position:relative;z-index:1;margin-bottom:0.8rem;color:var(--white)}
.svc-bar{width:28px;height:1.5px;background:linear-gradient(to right,var(--p1),var(--b1));margin-bottom:1.2rem;transition:width 0.4s;position:relative;z-index:1;border-radius:2px}
.svc:hover .svc-bar{width:56px}
.svc-desc{font-size:0.9rem;color:#C4B5FD;line-height:1.78;position:relative;z-index:1}

/* NUMBERS */
.num-band{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(167,139,250,0.07);position:relative}
.num-band::before,.num-band::after{content:'';position:absolute;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,rgba(167,139,250,0.4),rgba(96,165,250,0.4),transparent)}
.num-band::before{top:0}.num-band::after{bottom:0}
.nitem{background:var(--dark2);padding:3.5rem 2.5rem;text-align:center;position:relative;overflow:hidden}
.nitem::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(124,58,237,0.05) 0%,transparent 70%)}
.nnum{font-family:'Bebas Neue',sans-serif;font-size:4.5rem;background:linear-gradient(135deg,#A78BFA,#60A5FA,#F472B6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:0.5rem}
.nlabel{font-size:0.7rem;letter-spacing:0.22em;text-transform:uppercase;color:#9CA3AF}

/* ABOUT */
.about-section{padding:8rem 4rem;background:var(--bg);position:relative;overflow:hidden}
.about-bg-text{position:absolute;font-family:'Bebas Neue',sans-serif;font-size:16rem;background:linear-gradient(135deg,rgba(167,139,250,0.025),rgba(96,165,250,0.025));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;white-space:nowrap;user-select:none}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:8rem;align-items:center;position:relative;z-index:1}
.about-frame-wrap{position:relative}
.about-frame{aspect-ratio:1;border-radius:50%;background:var(--dark2);border:1px solid rgba(167,139,250,0.15);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;transition:border-color 0.5s}
.about-frame:hover{border-color:rgba(167,139,250,0.35)}
.about-logo-big{width:90%;height:90%;border-radius:50%;object-fit:cover;filter:drop-shadow(0 0 40px rgba(167,139,250,0.3))}
.about-frame-glow{position:absolute;bottom:-80px;left:50%;transform:translateX(-50%);width:360px;height:140px;background:rgba(124,58,237,0.08);border-radius:50%;filter:blur(40px);pointer-events:none}
.about-badge{position:absolute;bottom:-1.5rem;right:-1.5rem;background:linear-gradient(135deg,#7C3AED,#1D4ED8);color:#fff;padding:1.5rem 1.8rem;font-family:'Bebas Neue',sans-serif;font-size:0.9rem;letter-spacing:0.08em;line-height:1.5;text-align:center;box-shadow:0 0 40px rgba(124,58,237,0.3);z-index:2;border-radius:2px}
.about-text{font-family:'Cormorant Garamond',serif;font-size:1.15rem;color:#C4B5FD;line-height:1.8;margin-bottom:1.5rem}
.about-text strong{color:var(--white);font-weight:400}
.about-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:0.8rem;margin:2rem 0}
.about-list li{font-size:0.85rem;color:#C4B5FD;letter-spacing:0.04em;display:flex;align-items:center;gap:0.7rem}
.about-list li::before{content:'';width:5px;height:5px;background:linear-gradient(135deg,var(--p1),var(--b1));border-radius:50%;flex-shrink:0;box-shadow:0 0 6px rgba(167,139,250,0.5)}

/* PROCESS */
.process-section{padding:8rem 4rem;background:var(--dark)}
.pheader{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:2rem;margin-bottom:4.5rem}
.ptagline{max-width:270px;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.12rem;color:#C4B5FD;line-height:1.7}
.pgrid{display:grid;grid-template-columns:repeat(4,1fr);position:relative}
.pgrid::before{content:'';position:absolute;top:3rem;left:12.5%;right:12.5%;height:1px;background:linear-gradient(to right,transparent,rgba(167,139,250,0.3) 15%,rgba(96,165,250,0.3) 85%,transparent)}
.pstep{padding:2.5rem 1.5rem;text-align:center}
.pcirc{width:50px;height:50px;border:1px solid rgba(167,139,250,0.25);border-radius:50%;margin:0 auto 2.5rem;display:flex;align-items:center;justify-content:center;background:var(--dark);transition:border-color 0.4s,box-shadow 0.4s}
.pstep:hover .pcirc{border-color:var(--p1);box-shadow:0 0 20px rgba(167,139,250,0.2),0 0 40px rgba(96,165,250,0.1)}
.pn{font-family:'Bebas Neue',sans-serif;font-size:1.1rem;background:linear-gradient(135deg,var(--p1),var(--b1));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.ptitle{font-family:'Bebas Neue',sans-serif;font-size:1.3rem;letter-spacing:0.04em;margin-bottom:0.8rem;color:var(--white)}
.pdesc{font-size:0.88rem;color:#C4B5FD;line-height:1.72}

/* TESTIMONIALS */
.testi-section{padding:8rem 4rem;background:var(--bg)}
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:4.5rem}
.tcard{background:var(--dark);border:1px solid rgba(167,139,250,0.08);padding:2.5rem;position:relative;overflow:hidden;transition:border-color 0.4s,transform 0.4s,box-shadow 0.4s;border-radius:4px}
.tcard::before{content:'"';font-family:'Cormorant Garamond',serif;font-size:7rem;color:rgba(167,139,250,0.1);position:absolute;top:-1.5rem;left:1.5rem;line-height:1}
.tcard:hover{border-color:rgba(167,139,250,0.25);transform:translateY(-7px);box-shadow:0 30px 60px rgba(0,0,0,0.5),0 0 40px rgba(124,58,237,0.06)}
.tstars{font-size:0.8rem;margin-bottom:1.5rem;padding-top:1.5rem;letter-spacing:0.15em;background:linear-gradient(135deg,#A78BFA,#F472B6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.ttext{font-family:'Cormorant Garamond',serif;font-size:1.08rem;color:#C4B5FD;line-height:1.8;font-style:italic;margin-bottom:2rem}
.tauthor{display:flex;align-items:center;gap:1rem;border-top:1px solid rgba(167,139,250,0.08);padding-top:1.5rem}
.tavatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#7C3AED,#1D4ED8);display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:0.95rem;color:#fff;flex-shrink:0;box-shadow:0 0 15px rgba(124,58,237,0.3)}
.tname{font-size:0.88rem;font-weight:500;color:var(--white);margin-bottom:0.2rem}
.trole{font-size:0.72rem;color:var(--p1);letter-spacing:0.05em}

/* CONTACT FORM SECTION */
.contact-section{padding:8rem 4rem;background:var(--dark);position:relative;overflow:hidden}
.contact-bg{position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 50% 50%,rgba(124,58,237,0.05) 0%,transparent 70%);pointer-events:none}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start;position:relative;z-index:1}
.contact-info h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.5rem,4vw,3.8rem);line-height:0.92;letter-spacing:0.02em;margin-bottom:1.5rem}
.contact-info p{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.15rem;color:#C4B5FD;line-height:1.8;margin-bottom:2.5rem}
.contact-links{display:flex;flex-direction:column;gap:1rem}
.clink{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;border:1px solid rgba(167,139,250,0.12);border-radius:3px;text-decoration:none;color:var(--white);transition:all 0.3s;background:var(--dark2)}
.clink:hover{border-color:rgba(167,139,250,0.4);transform:translateX(6px);box-shadow:0 0 20px rgba(124,58,237,0.1)}
.clink-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.2rem}
.clink-icon.email{background:linear-gradient(135deg,rgba(124,58,237,0.3),rgba(29,78,216,0.3));box-shadow:0 0 15px rgba(124,58,237,0.2)}
.clink-icon.wa{background:linear-gradient(135deg,rgba(34,197,94,0.3),rgba(21,128,61,0.3));box-shadow:0 0 15px rgba(34,197,94,0.2)}
.clink-icon.ig{background:linear-gradient(135deg,rgba(244,114,182,0.3),rgba(124,58,237,0.3));box-shadow:0 0 15px rgba(244,114,182,0.2)}
.clink-label{font-size:0.65rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--p1);margin-bottom:0.2rem}
.clink-val{font-size:0.9rem;color:#E2E8F0}
.horario-box{margin-top:2rem;padding:1.2rem 1.5rem;border:1px solid rgba(167,139,250,0.1);border-radius:3px;background:rgba(124,58,237,0.04)}
.horario-label{font-size:0.65rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--p1);margin-bottom:0.4rem}
.horario-val{font-size:0.95rem;color:#E2E8F0}

/* FORM */
.contact-form-wrap{}
.form-title{font-family:'Bebas Neue',sans-serif;font-size:1.8rem;letter-spacing:0.05em;margin-bottom:0.5rem;color:var(--white)}
.form-sub{font-size:0.85rem;color:#9CA3AF;margin-bottom:2rem}
.form{display:flex;flex-direction:column;gap:1rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-group{display:flex;flex-direction:column;gap:0.4rem}
.form-label{font-size:0.7rem;letter-spacing:0.12em;text-transform:uppercase;color:#C4B5FD}
.form-input,.form-select,.form-textarea{background:rgba(167,139,250,0.04);border:1px solid rgba(167,139,250,0.14);color:var(--white);padding:0.85rem 1.1rem;font-family:'Inter',sans-serif;font-size:0.88rem;border-radius:3px;outline:none;transition:border-color 0.3s,box-shadow 0.3s;width:100%}
.form-input::placeholder,.form-textarea::placeholder{color:#4B5563}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:rgba(167,139,250,0.5);box-shadow:0 0 0 3px rgba(124,58,237,0.08)}
.form-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23A78BFA' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}
.form-select option{background:#0E0E24;color:var(--white)}
.form-textarea{resize:vertical;min-height:120px;font-family:'Inter',sans-serif}
.form-submit{background:linear-gradient(135deg,#7C3AED,#1D4ED8);color:#fff;padding:1rem 2rem;border:none;font-family:'Inter',sans-serif;font-size:0.82rem;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;cursor:pointer;border-radius:3px;transition:transform 0.3s,box-shadow 0.3s;position:relative;overflow:hidden}
.form-submit:hover{transform:translateY(-2px);box-shadow:0 15px 40px rgba(124,58,237,0.35)}
.form-submit::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,0.1),transparent);opacity:0;transition:opacity 0.3s}
.form-submit:hover::before{opacity:1}
.form-note{font-size:0.75rem;color:#6B7280;margin-top:0.5rem;text-align:center}
#form-success{display:none;background:rgba(34,197,94,0.08);border:1px solid rgba(34,197,94,0.25);border-radius:3px;padding:1.2rem;text-align:center;color:#86EFAC;font-size:0.9rem;margin-top:0.5rem}

/* CTA SECTION */
.cta-section{padding:10rem 4rem;text-align:center;position:relative;overflow:hidden;background:var(--bg)}
.cta-bg-orbs{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.cta-orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:0.1}
.cta-orb1{width:500px;height:500px;background:#7C3AED;top:50%;left:20%;transform:translate(-50%,-50%)}
.cta-orb2{width:400px;height:400px;background:#1D4ED8;top:50%;right:15%;transform:translate(50%,-50%)}
.cta-orb3{width:300px;height:300px;background:#BE185D;top:50%;left:50%;transform:translate(-50%,-50%)}
.rings{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}
.ring{position:absolute;border-radius:50%;border:1px solid rgba(167,139,250,0.055);top:50%;left:50%;transform:translate(-50%,-50%)}
.ring:nth-child(1){width:250px;height:250px;animation:rp 5s ease-in-out infinite}
.ring:nth-child(2){width:440px;height:440px;animation:rp 5s ease-in-out 1.2s infinite}
.ring:nth-child(3){width:640px;height:640px;animation:rp 5s ease-in-out 2.4s infinite}
@keyframes rp{0%,100%{opacity:0.3;transform:translate(-50%,-50%) scale(1)}50%{opacity:0.8;transform:translate(-50%,-50%) scale(1.04)}}
.cta-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.8rem,6.5vw,6rem);line-height:0.92;max-width:860px;margin:0 auto 1.5rem;position:relative;z-index:1}
.cta-title .hi{background:linear-gradient(135deg,#A78BFA,#60A5FA,#F472B6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.cta-sub{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.2rem;color:#C4B5FD;margin-bottom:3rem;position:relative;z-index:1}
.cta-btns{display:flex;justify-content:center;gap:1.2rem;flex-wrap:wrap;position:relative;z-index:1}

/* FOOTER */
footer{background:var(--dark);border-top:1px solid rgba(167,139,250,0.08);padding:2.8rem 4rem;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:2rem}
.flogo-wrap{display:flex;align-items:center;gap:0.8rem}
.flogo-img{width:40px;height:40px;border-radius:50%;object-fit:cover;border:1px solid rgba(167,139,250,0.2)}
.flogo-text{font-family:'Bebas Neue',sans-serif;font-size:1.6rem;letter-spacing:0.12em;background:linear-gradient(135deg,#A78BFA,#60A5FA);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.fcopy{font-size:0.75rem;color:#6B7280;letter-spacing:0.05em;text-align:center}
.fsocials{display:flex;gap:2rem;justify-content:flex-end}
.fsocials a{color:#9CA3AF;text-decoration:none;font-size:0.72rem;letter-spacing:0.12em;text-transform:uppercase;transition:color 0.3s}
.fsocials a:hover{color:var(--p1)}

/* ANIMATIONS */
@keyframes slideUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.8s ease,transform 0.8s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.d1{transition-delay:0.1s}.d2{transition-delay:0.2s}.d3{transition-delay:0.3s}.d4{transition-delay:0.4s}

@media(max-width:1024px){
  nav,nav.scrolled{padding:1.2rem 2rem}
  .nav-links{display:none}
  .hero{grid-template-columns:1fr;padding:6rem 2rem 5rem;min-height:auto}
  .hero-right{order:-1;margin-bottom:1rem}
  .hero-stats{position:relative;bottom:auto;left:auto;margin-top:2.5rem;padding-bottom:1rem;gap:1.5rem}
  .services-section,.about-section,.process-section,.testi-section,.contact-section,.cta-section,.portfolio-section{padding:5rem 2rem}
  .svc-grid{grid-template-columns:1fr}
  .svc-header{flex-direction:column;align-items:flex-start}
  .about-grid{grid-template-columns:1fr;gap:4rem}
  .about-badge{bottom:-1rem;right:-0.5rem;padding:1.1rem 1.3rem}
  .pgrid{grid-template-columns:1fr 1fr;gap:2rem}
  .pgrid::before{display:none}
  .tgrid{grid-template-columns:1fr}
  .num-band{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr;gap:3rem}
  footer{grid-template-columns:1fr;text-align:center;padding:2.5rem}
  .fsocials{justify-content:center}
  .form-row{grid-template-columns:1fr}
  .logo-showcase{max-width:260px}
  .portfolio-grid{grid-template-columns:repeat(2,1fr)}
  .portfolio-header,.pheader{flex-direction:column;align-items:flex-start}
}

@media(max-width:600px){
  nav,nav.scrolled{padding:1rem 1.2rem}
  .nav-logo-text{font-size:1.5rem}
  .nav-logo-img{width:40px;height:40px}
  .hero{padding:5.5rem 1.2rem 4rem;gap:1.5rem}
  .hero-title{font-size:clamp(3.2rem,14vw,5rem)}
  .hero-desc{font-size:1rem;max-width:100%}
  .hero-btns{flex-direction:column;gap:0.8rem}
  .btn-primary,.btn-ghost{width:100%;text-align:center;padding:0.9rem 1.5rem}
  .hero-stats{flex-wrap:wrap;gap:1.2rem;margin-top:1.5rem}
  .hstat-num{font-size:2rem}
  .logo-showcase{max-width:200px}
  .services-section,.about-section,.process-section,.testi-section,.contact-section,.cta-section,.portfolio-section{padding:4rem 1.2rem}
  .svc{padding:2rem 1.5rem}
  .num-band{grid-template-columns:repeat(2,1fr)}
  .nnum{font-size:3rem}
  .nitem{padding:2.2rem 1rem}
  .pgrid{grid-template-columns:1fr;gap:1.5rem}
  .pstep{padding:1.5rem 1rem}
  .about-grid{gap:2.5rem}
  .about-badge{position:relative;bottom:auto;right:auto;margin-top:1rem;display:inline-block}
  .about-frame-wrap{text-align:center}
  .about-bg-text{font-size:8rem}
  .cta-section{padding:6rem 1.2rem}
  .cta-btns{flex-direction:column;align-items:center}
  .cta-title{font-size:clamp(2.2rem,9vw,4rem)}
  .portfolio-grid{grid-template-columns:1fr}
  .portfolio-filters{gap:0.5rem}
  .pfilter{padding:0.45rem 1.1rem;font-size:0.7rem}
  .contact-grid{gap:2rem}
  .contact-info h2{font-size:clamp(2rem,9vw,3rem)}
  footer{padding:2rem 1.2rem;gap:1.2rem}
  .fcopy{font-size:0.7rem}
  .fsocials{gap:1.2rem;flex-wrap:wrap;justify-content:center}
  .sec-title{font-size:clamp(2.2rem,10vw,3.5rem)}
  .pheader,.svc-header,.portfolio-header{flex-direction:column;align-items:flex-start;gap:1rem;margin-bottom:3rem}
  .ptagline,.svc-tagline,.portfolio-tagline{max-width:100%}
}

/* =============================================
   PORTFOLIO — SECCIÓN CORREGIDA
   - aspect-ratio cambiado de 3/4 a 4/3 (más ancho, menos alto)
   - Las imágenes se ven enteras, mejor posicionadas
   ============================================= */
.portfolio-section{padding:8rem 4rem;background:var(--bg);position:relative;overflow:hidden}
.portfolio-bg{position:absolute;inset:0;background:radial-gradient(ellipse 50% 60% at 80% 40%,rgba(124,58,237,0.05) 0%,transparent 70%),radial-gradient(ellipse 40% 50% at 20% 70%,rgba(29,78,216,0.04) 0%,transparent 70%);pointer-events:none}
.portfolio-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3rem;flex-wrap:wrap;gap:2rem}
.portfolio-tagline{max-width:280px;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.15rem;color:#C4B5FD;line-height:1.7}
.portfolio-filters{display:flex;gap:0.8rem;margin-bottom:3rem;flex-wrap:wrap}
.pfilter{background:transparent;color:#9CA3AF;border:1px solid rgba(167,139,250,0.15);padding:0.55rem 1.6rem;font-family:'Inter',sans-serif;font-size:0.75rem;letter-spacing:0.15em;text-transform:uppercase;cursor:pointer;border-radius:30px;transition:all 0.3s}
.pfilter:hover{border-color:rgba(167,139,250,0.4);color:#C4B5FD}
.pfilter.active{background:linear-gradient(135deg,rgba(124,58,237,0.3),rgba(29,78,216,0.3));border-color:rgba(167,139,250,0.5);color:#E0D7FF}

/* Grid: 3 columnas en desktop */
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-bottom:4rem}

.pcard{position:relative;border-radius:6px;overflow:hidden;cursor:pointer;background:var(--dark2)}
.pcard[data-cat].hidden{display:none}

/* Relación de aspecto 4/3 → más apaisado, se ven mejor las fotos horizontales */
.pcard-img-wrap{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
  background:var(--dark3);
}

/* La imagen ocupa todo el contenedor sin deformarse */
.pcard-img-wrap img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
  transition:transform 0.6s cubic-bezier(0.4,0,0.2,1),filter 0.4s;
}
.pcard:hover .pcard-img-wrap img{transform:scale(1.06);filter:brightness(0.65)}

.pcard-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(4,4,15,0.9) 0%,rgba(4,4,15,0.25) 55%,transparent 100%);opacity:0;transition:opacity 0.4s;display:flex;align-items:flex-end}
.pcard:hover .pcard-overlay{opacity:1}
.pcard-overlay-inner{padding:1.5rem;transform:translateY(8px);transition:transform 0.4s}
.pcard:hover .pcard-overlay-inner{transform:translateY(0)}
.pcard-tag{display:inline-block;background:linear-gradient(135deg,rgba(124,58,237,0.6),rgba(29,78,216,0.6));color:#E0D7FF;font-size:0.65rem;letter-spacing:0.2em;text-transform:uppercase;padding:0.3rem 0.8rem;border-radius:20px;margin-bottom:0.5rem;border:1px solid rgba(167,139,250,0.3)}
.pcard-title{font-family:'Bebas Neue',sans-serif;font-size:1.3rem;letter-spacing:0.04em;color:#fff;margin-bottom:0.25rem;line-height:1.1}
.pcard-desc{font-size:0.78rem;color:#C4B5FD}

.portfolio-cta{text-align:center;padding:2rem 0}
.portfolio-cta-text{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.2rem;color:#C4B5FD;margin-bottom:1.5rem}

@media(max-width:1024px){
  .portfolio-section{padding:5rem 2rem}
  .portfolio-grid{grid-template-columns:repeat(2,1fr)}
  .portfolio-header{flex-direction:column}
}
@media(max-width:600px){
  .portfolio-grid{grid-template-columns:1fr}
  /* En móvil, formato más cuadrado para que se vean bien */
  .pcard-img-wrap{aspect-ratio:3/2}
}
