/*
Theme Name: Solunet
Theme URI: https://solunet.es
Author: Soluciones Internet S.L.
Description: Tema corporativo de Solunet — Tu negocio en internet, en buenas manos.
Version: 1.0.0
License: GPL-2.0-or-later
Text Domain: solunet
*/

:root{
  --navy:#00396f;
  --navy-deep:#002247;
  --navy-2:#0a4f93;
  --magenta:#c2185b;
  --magenta-br:#e6447f;
  --gris:#9b9ba3;
  --ink:#161a22;
  --muted:#59606e;
  --faint:#8b91a0;
  --paper:#ffffff;
  --soft:#f5f6f9;
  --soft-2:#edf0f5;
  --line:#e3e7ee;
  --grad:linear-gradient(110deg,var(--navy) 0%,var(--magenta) 100%);
  --disp:"Sora",sans-serif;
  --sans:"Hanken Grotesk",system-ui,sans-serif;
  --mono:"JetBrains Mono",monospace;
  --word:"Poppins",sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:var(--sans);line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img,svg{display:block}
.wrap{max-width:1300px;margin:0 auto;padding:0 36px}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* LOGO */
.logo{display:flex;align-items:center;gap:11px}
.logo .sym{width:30px;height:30px;flex-shrink:0}
.logo .word{font-family:var(--word);font-weight:800;font-size:27px;letter-spacing:-.01em;line-height:1}
.logo .word .s{color:var(--gris)}
.logo .word .n{color:var(--magenta)}

/* HEADER */
header.site{position:fixed;top:0;left:0;right:0;z-index:100;transition:all .3s}
header.site.scrolled{background:rgba(255,255,255,.85);backdrop-filter:blur(16px);box-shadow:0 1px 0 var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px;gap:20px}
.nav-desktop ul{display:flex;gap:34px;list-style:none}
.nav-desktop a{font-size:15px;color:var(--muted);font-weight:500;transition:color .2s;position:relative}
.nav-desktop a:hover{color:var(--navy)}
.nav-desktop a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--magenta);transition:width .25s}
.nav-desktop a:hover::after{width:100%}
.nav-cta{font-weight:600;font-size:14px;padding:11px 21px;border-radius:100px;background:var(--navy);color:#fff;transition:all .2s}
.nav-cta:hover{background:var(--magenta)}

/* hamburguesa */
.burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;border:none;background:transparent;cursor:pointer;padding:10px;border-radius:10px;transition:background .2s}
.burger:hover{background:var(--soft-2)}
.burger span{display:block;height:2px;width:100%;background:var(--navy);border-radius:2px;transition:transform .28s,opacity .2s}
.site.menu-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.site.menu-open .burger span:nth-child(2){opacity:0}
.site.menu-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* menú móvil — oculto por defecto, solo visible al abrir en móvil */
.mobile-menu{display:none;position:fixed;top:74px;left:0;right:0;bottom:0;background:rgba(255,255,255,.98);backdrop-filter:blur(16px);padding:30px 36px;flex-direction:column;gap:6px;z-index:99;animation:menuIn .3s ease}
@keyframes menuIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}
.mobile-menu ul{list-style:none;display:flex;flex-direction:column}
.mobile-menu a{font-family:var(--disp);font-weight:600;font-size:26px;color:var(--navy);padding:16px 0;border-bottom:1px solid var(--line);letter-spacing:-.02em}
.mobile-menu .mobile-cta{margin-top:24px;justify-content:center}

/* BOTONES */
.btn{font-family:var(--sans);font-weight:600;font-size:15px;padding:16px 28px;border-radius:100px;transition:all .22s;display:inline-flex;align-items:center;gap:9px;cursor:pointer;white-space:nowrap;border:none}
.btn-grad{background:var(--grad);background-size:150% 150%;background-position:0 0;color:#fff;box-shadow:0 12px 28px -12px rgba(194,24,91,.55);transition:background-position .45s,transform .2s,box-shadow .2s}
.btn-grad:hover{background-position:100% 0;transform:translateY(-2px)}
.btn-line{background:#fff;border:1.5px solid var(--line);color:var(--navy)}
.btn-line:hover{border-color:var(--navy)}

/* SECCIONES genéricas */
section{padding:118px 0}
.page-top{padding:150px 0 0}
.head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:54px;flex-wrap:wrap}
.tag{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--magenta);margin-bottom:18px;display:flex;align-items:center;gap:11px}
.tag::before{content:"";width:26px;height:2px;background:var(--magenta)}
.head h2{font-family:var(--disp);font-weight:700;font-size:clamp(32px,4.6vw,58px);line-height:1;letter-spacing:-.035em;max-width:17ch;color:var(--navy)}
.head p{font-size:17px;color:var(--muted);max-width:34ch}

/* HERO */
.hero{padding:132px 0 0;position:relative;overflow:hidden}
.hero .watermark{position:absolute;right:-80px;top:40px;width:520px;height:520px;opacity:.06;pointer-events:none;z-index:0}
.hero .wrap{position:relative;z-index:1}
.hero-meta{display:flex;justify-content:space-between;font-family:var(--mono);font-size:12px;color:var(--faint);text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--line);padding-bottom:18px;flex-wrap:wrap;gap:10px}
.hero-meta .on{color:var(--magenta);display:flex;align-items:center;gap:8px;font-weight:500}
.hero-meta .on::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--magenta);animation:blink 1.8s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}
.hero h1{font-family:var(--disp);font-weight:700;font-size:clamp(46px,8.5vw,118px);line-height:.95;letter-spacing:-.035em;margin:44px 0 0;color:var(--navy)}
.hero h1 .l2{display:block}
.hero-bottom{display:grid;grid-template-columns:1fr auto;gap:50px;align-items:end;margin-top:42px;padding-bottom:54px;border-bottom:1px solid var(--line)}
.hero-lede{font-size:20px;color:var(--muted);max-width:52ch}
.hero-actions{display:flex;gap:13px;flex-wrap:wrap}

/* TICKER */
.ticker{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid var(--line)}
.ticker .m{padding:32px 0;border-right:1px solid var(--line)}
.ticker .m:last-child{border-right:none}
.ticker .m .v{font-family:var(--disp);font-size:clamp(32px,4vw,50px);font-weight:700;letter-spacing:-.03em;line-height:1;color:var(--navy)}
.ticker .m .v.mg{color:var(--magenta)}
.ticker .m .k{font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--faint);margin-top:12px}

/* BENTO */
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(166px,auto);gap:14px}
.cell{background:var(--paper);border:1px solid var(--line);border-radius:20px;padding:28px;display:flex;flex-direction:column;transition:all .28s;position:relative;overflow:hidden}
.cell:hover{transform:translateY(-4px);box-shadow:0 24px 50px -28px rgba(0,57,111,.28);border-color:transparent}
.cell .ic{width:50px;height:50px;border-radius:14px;background:var(--soft-2);color:var(--navy);display:flex;align-items:center;justify-content:center;margin-bottom:auto}
.cell .ic svg{width:24px;height:24px}
.cell h3{font-family:var(--disp);font-size:22px;font-weight:600;letter-spacing:-.02em;margin:20px 0 7px;color:var(--navy)}
.cell p{font-size:14.5px;color:var(--muted)}
.cell .arr{position:absolute;top:30px;right:28px;font-family:var(--mono);color:var(--faint);transition:all .25s}
.cell:hover .arr{color:var(--magenta);transform:translate(3px,-3px)}
.c-wide{grid-column:span 2}
.cell.feat{grid-column:span 2;grid-row:span 2;background:var(--grad);border:none;color:#fff;justify-content:space-between}
.cell.feat::after{content:"";position:absolute;width:360px;height:360px;right:-130px;top:-120px;opacity:.14;z-index:0;background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><clipPath id="c"><circle cx="50" cy="50" r="44"/></clipPath></defs><g clip-path="url(%23c)" stroke="white" stroke-width="7" stroke-linecap="round"><line x1="-31" y1="59" x2="59" y2="-31"/><line x1="-19" y1="71" x2="71" y2="-19"/><line x1="-7" y1="83" x2="83" y2="-7"/><line x1="5" y1="95" x2="95" y2="5"/><line x1="17" y1="107" x2="107" y2="17"/><line x1="29" y1="119" x2="119" y2="29"/></g></svg>') center/contain no-repeat}
.cell.feat>*{position:relative;z-index:1}
.cell.feat .ic{background:rgba(255,255,255,.18);color:#fff}
.cell.feat h3{font-size:33px;margin-top:22px;color:#fff}
.cell.feat p{color:rgba(255,255,255,.92);font-size:16px;max-width:40ch;margin-top:10px}
.cell.feat .badge{font-family:var(--mono);font-size:11px;letter-spacing:.07em;background:rgba(255,255,255,.2);padding:6px 12px;border-radius:100px;align-self:flex-start;position:relative;z-index:1}
.cell.feat .fbtn{margin-top:24px;align-self:flex-start;background:#fff;color:var(--magenta);font-weight:700;padding:13px 24px;border-radius:100px;position:relative;z-index:1;transition:transform .2s}
.cell.feat .fbtn:hover{transform:translateY(-2px)}

/* WHY */
.why{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.why .deco{position:absolute;left:-100px;bottom:-100px;width:440px;height:440px;opacity:.08;pointer-events:none}
.why .wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:80px;position:relative;z-index:1}
.why .tag{color:var(--magenta-br)}
.why .tag::before{background:var(--magenta-br)}
.why h2{font-family:var(--disp);font-weight:700;font-size:clamp(32px,4.4vw,56px);line-height:1.02;letter-spacing:-.035em;color:#fff}
.why .intro{color:#aeb8c7;font-size:18px;margin-top:24px;max-width:40ch}
.why .list{display:flex;flex-direction:column}
.why .it{display:grid;grid-template-columns:auto 1fr;gap:28px;padding:28px 0;border-top:1px solid rgba(255,255,255,.13);align-items:start}
.why .it:last-child{border-bottom:1px solid rgba(255,255,255,.13)}
.why .it .num{font-family:var(--disp);font-size:34px;font-weight:700;line-height:1;color:var(--magenta-br)}
.why .it h4{font-family:var(--disp);font-size:20px;font-weight:600;margin-bottom:7px}
.why .it p{color:#9aa5b5;font-size:15px}

/* STEPS */
.steps{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--line);border-radius:20px;overflow:hidden;background:var(--paper)}
.stp{padding:38px 30px;border-right:1px solid var(--line)}
.stp:last-child{border-right:none}
.stp .n{font-family:var(--mono);font-size:13px;color:var(--magenta);font-weight:600}
.stp h4{font-family:var(--disp);font-size:21px;font-weight:600;margin:16px 0 9px;letter-spacing:-.02em;color:var(--navy)}
.stp p{font-size:14px;color:var(--muted)}

/* QUOTE */
.quote{background:var(--soft)}
.quote .wrap{max-width:1020px;text-align:center}
.quote .sym{width:54px;height:54px;margin:0 auto 28px}
.quote blockquote{font-family:var(--disp);font-weight:600;font-size:clamp(26px,4.2vw,52px);line-height:1.1;letter-spacing:-.03em;color:var(--navy)}
.quote .who{font-family:var(--mono);font-size:13px;color:var(--faint);letter-spacing:.06em;margin-top:32px}

/* CTA */
.cta{padding:0 0 118px}
.cta .box{background:var(--navy);border-radius:30px;padding:86px 48px;text-align:center;position:relative;overflow:hidden}
.cta .box::before{content:"";position:absolute;inset:0;background:radial-gradient(58% 120% at 50% 135%,rgba(194,24,91,.5),transparent 60%),radial-gradient(50% 100% at 18% -25%,rgba(10,79,147,.6),transparent 60%)}
.cta h2{font-family:var(--disp);font-weight:700;font-size:clamp(36px,5.5vw,76px);line-height:.98;letter-spacing:-.04em;color:#fff;position:relative}
.cta p{color:#b6c0cf;font-size:18px;margin:22px auto 36px;max-width:44ch;position:relative}
.cta .hero-actions{justify-content:center;position:relative}
.cta .btn-line{background:transparent;border-color:rgba(255,255,255,.35);color:#fff}
.cta .btn-line:hover{background:#fff;color:var(--navy)}

/* prosa simple para páginas internas */
.prose{max-width:760px}
.prose p{font-size:17px;color:var(--muted);margin-bottom:20px}
.prose h3{font-family:var(--disp);font-weight:700;font-size:26px;color:var(--navy);margin:36px 0 14px;letter-spacing:-.02em}
.prose a{color:var(--magenta);font-weight:500}
.prose.legal p{font-size:16px;line-height:1.7}
.prose.legal b{color:var(--navy)}
.legal-note{display:inline-block;margin-top:6px;font-family:var(--mono);font-size:13px;color:var(--faint);background:var(--soft);padding:4px 10px;border-radius:6px}
.legal-upd{margin-top:40px;font-family:var(--mono);font-size:13px;color:var(--faint)}

/* CONTACTO */
.contact-grid{display:grid;grid-template-columns:1.3fr .9fr;gap:60px;align-items:start}
.contact-aside{background:var(--soft);border:1px solid var(--line);border-radius:20px;padding:34px}
.contact-aside h3{font-family:var(--disp);font-weight:700;font-size:22px;color:var(--navy);margin-bottom:22px;letter-spacing:-.02em}
.contact-line{display:flex;align-items:center;gap:16px;padding:16px 0;border-bottom:1px solid var(--line);color:var(--ink)}
.contact-line:last-child{border-bottom:none}
.contact-line .ci{width:46px;height:46px;border-radius:12px;background:var(--soft-2);color:var(--magenta);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.contact-line b{font-size:16px;color:var(--navy)}
.contact-line small{font-size:13px;color:var(--muted)}
a.contact-line{transition:transform .2s}
a.contact-line:hover{transform:translateX(3px)}
a.contact-line:hover .ci{background:var(--magenta);color:#fff}
.form-status{font-size:14.5px;padding:14px 18px;border-radius:12px;font-weight:500}
.form-status.ok{background:#e7f6ee;color:#0f7a43;border:1px solid #b9e6cd}
.form-status.err{background:#fdecf2;color:var(--magenta);border:1px solid #f6c4d7}

/* FORM */
.form{max-width:620px;display:grid;gap:18px}
.form label{font-size:14px;font-weight:600;color:var(--navy);margin-bottom:7px;display:block}
.form input,.form textarea{width:100%;padding:14px 16px;border:1.5px solid var(--line);border-radius:12px;font-family:var(--sans);font-size:15px;color:var(--ink);background:#fff;transition:border-color .2s}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--navy)}
.form textarea{min-height:140px;resize:vertical}

/* microcopy de confianza bajo el hero */
.hero-note{margin-top:18px;font-family:var(--mono);font-size:12.5px;color:var(--faint);letter-spacing:.02em}
.hero-note b{color:var(--magenta);font-weight:500}

/* PLANES (pricing) */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:stretch}
.plan{background:var(--paper);border:1px solid var(--line);border-radius:22px;padding:34px 30px;display:flex;flex-direction:column;position:relative;transition:all .28s}
.plan:hover{transform:translateY(-4px);box-shadow:0 24px 50px -28px rgba(0,57,111,.25)}
.plan .pname{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--magenta)}
.plan .ptag{font-size:14px;color:var(--muted);margin-top:8px;min-height:42px}
.plan .price{font-family:var(--disp);font-weight:700;font-size:46px;letter-spacing:-.03em;color:var(--navy);margin:18px 0 2px;line-height:1}
.plan .price small{font-family:var(--sans);font-size:15px;font-weight:500;color:var(--faint);letter-spacing:0}
.plan .pnote{font-family:var(--mono);font-size:11px;color:var(--faint);margin-bottom:22px}
.plan ul{list-style:none;display:flex;flex-direction:column;gap:13px;margin-bottom:28px;flex:1}
.plan li{font-size:14.5px;color:var(--ink);display:flex;gap:11px;align-items:flex-start;line-height:1.4}
.plan li svg{width:18px;height:18px;flex-shrink:0;color:var(--magenta);margin-top:2px}
.plan .pbtn{text-align:center;font-weight:600;font-size:15px;padding:14px;border-radius:100px;border:1.5px solid var(--line);color:var(--navy);transition:all .2s}
.plan .pbtn:hover{border-color:var(--navy)}
.plan.featured{background:linear-gradient(160deg,#073463,var(--navy) 55%);border:none;color:#fff}
.plan.featured .ptag{color:#b9c6dd}
.plan.featured .price{color:#fff}
.plan.featured .price small,.plan.featured .pnote{color:#9aa5b5}
.plan.featured li{color:#eef2f8}
.plan.featured li svg{color:var(--magenta-br)}
.plan.featured .pbtn{background:#fff;color:var(--navy);border-color:#fff}
.plan.featured .pbtn:hover{background:var(--magenta);color:#fff;border-color:var(--magenta)}
.plan .pop{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--magenta);color:#fff;font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;padding:6px 14px;border-radius:100px;white-space:nowrap}
.plans-note{margin-top:26px;font-size:14px;color:var(--muted);max-width:70ch}
.plans-note b{color:var(--navy);font-weight:600}

/* mini FAQ */
.faq{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:30px}
.faq .q{border-top:2px solid var(--line);padding-top:18px}
.faq .q h4{font-family:var(--disp);font-size:17px;font-weight:600;color:var(--navy);margin-bottom:8px}
.faq .q p{font-size:14px;color:var(--muted)}

/* FOOTER */
footer.site{padding:62px 0 40px;border-top:1px solid var(--line)}
.foot{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:52px}
.foot .logo{margin-bottom:14px}
.foot>div>p{font-size:14px;color:var(--muted);max-width:30ch}
.foot h5{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:18px}
.foot a{display:block;font-size:14.5px;color:var(--muted);padding:6px 0;transition:color .2s}
.foot a:hover{color:var(--magenta)}
.foot-bot{display:flex;justify-content:space-between;border-top:1px solid var(--line);padding-top:26px;font-family:var(--mono);font-size:12px;color:var(--faint);flex-wrap:wrap;gap:14px}
.legal-links a{color:var(--faint);transition:color .2s}
.legal-links a:hover{color:var(--magenta)}

/* animación de entrada del hero */
@keyframes rise{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.rv{animation:rise .7s both}
.d1{animation-delay:.04s}.d2{animation-delay:.12s}.d3{animation-delay:.22s}.d4{animation-delay:.34s}

/* accesibilidad + micro-pulido */
::selection{background:var(--magenta);color:#fff}
:focus-visible{outline:2px solid var(--magenta);outline-offset:3px;border-radius:4px}
[id]{scroll-margin-top:96px}
.btn:active{transform:translateY(0) scale(.98)}
.cell{will-change:transform}
html{-webkit-text-size-adjust:100%}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .io,.rv{opacity:1!important;transform:none!important}
}

@media(max-width:980px){
  .nav-desktop,.nav-cta-desktop{display:none}
  .burger{display:flex}
  .site.menu-open .mobile-menu{display:flex}
  .hero-bottom{grid-template-columns:1fr;gap:28px}
  .ticker{grid-template-columns:1fr 1fr}
  .ticker .m:nth-child(2){border-right:none}
  .ticker .m:nth-child(1),.ticker .m:nth-child(2){border-bottom:1px solid var(--line)}
  .bento{grid-template-columns:repeat(2,1fr)}
  .cell.feat,.c-wide{grid-column:span 2}
  .cell.feat{grid-row:span 1}
  .why .wrap{grid-template-columns:1fr;gap:44px}
  .steps{grid-template-columns:1fr 1fr}
  .stp:nth-child(2){border-right:none}
  .foot{grid-template-columns:1fr 1fr}
  .plans{grid-template-columns:1fr;max-width:460px;margin:0 auto}
  .faq{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr;gap:40px}
}
@media(max-width:560px){
  .wrap{padding:0 22px}
  .bento,.steps{grid-template-columns:1fr}
  .cell.feat,.c-wide{grid-column:span 1}
  .stp{border-right:none;border-bottom:1px solid var(--line)}
  .foot{grid-template-columns:1fr}
}
