/* ============================================================
   Sunset Creative Solutions — Crepúsculo
   Noche editorial · Fraunces + Inter · horizonte mango→coral→violeta
   ============================================================ */
:root{
  --paper:#0E1420;
  --paper-2:#141C2B;
  --ink:#F2EEE4;
  --ink-soft:#C3BFB2;
  --mute:#7E8598;
  --line:rgba(242,238,228,.14);
  --g1:#FFA94D; --g2:#FF5D73; --g3:#B845ED;
  --grad:linear-gradient(90deg,var(--g1),var(--g2) 55%,var(--g3));
  --disp:'Fraunces',Georgia,serif;
  --body:'Inter',system-ui,sans-serif;
  --max:1140px;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--body);
  background:var(--paper);
  color:var(--ink);
  font-size:16px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px;}

/* ---------- defensiva obligatoria ---------- */
.reveal[data-split]{opacity:1;transform:none;}

/* ---------- reveals (solo cuando hay JS) ---------- */
html.js .reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease;}
html.js .reveal.is-visible{opacity:1;transform:none;}

/* ---------- progress meridiano ---------- */
.progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:60;background:transparent;}
.progress span{display:block;height:100%;width:0;background:var(--grad);}

/* ---------- nav ---------- */
.nav{position:fixed;top:3px;left:0;right:0;z-index:50;transition:background .3s ease,box-shadow .3s ease;}
.nav.solid{background:rgba(14,20,32,.9);backdrop-filter:blur(10px);box-shadow:0 1px 0 var(--line);}
.nav-in{display:flex;align-items:center;justify-content:space-between;gap:18px;height:68px;}
.brand{text-decoration:none;}
.brand-word{font-family:var(--disp);font-weight:700;font-size:26px;letter-spacing:.2px;}
.brand-word .dot{display:inline-block;width:.42em;height:.42em;border-radius:50%;background:var(--grad);margin-left:2px;transform:translateY(.02em);}
.brand-word-s{font-size:22px;}
.links{display:flex;gap:26px;}
.links a{text-decoration:none;font-size:14px;font-weight:500;color:var(--ink-soft);position:relative;padding-bottom:3px;}
.links a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--grad);transition:width .3s ease;}
.links a:hover::after,.links a:focus-visible::after{width:100%;}
.nav-actions{display:flex;align-items:center;gap:12px;}
.lang{font-family:var(--body);font-size:13px;font-weight:600;letter-spacing:.08em;background:none;border:1px solid var(--line);border-radius:99px;padding:7px 14px;cursor:pointer;color:var(--ink-soft);transition:border-color .25s,color .25s;}
.lang:hover{border-color:var(--ink);color:var(--ink);}
@media(max-width:860px){.links{display:none;}}

/* ---------- burger + menú móvil ---------- */
.burger{display:none;background:none;border:0;cursor:pointer;width:40px;height:40px;padding:9px 8px;flex-direction:column;justify-content:space-between;}
.burger span{display:block;height:2.5px;border-radius:2px;background:var(--ink);transition:transform .3s ease,opacity .3s ease;}
@media(max-width:860px){.burger{display:flex;}}
.menu-open .burger span:nth-child(1){transform:translateY(9.5px) rotate(45deg);}
.menu-open .burger span:nth-child(2){opacity:0;}
.menu-open .burger span:nth-child(3){transform:translateY(-9.5px) rotate(-45deg);}
.menu{position:fixed;inset:0;z-index:40;background:var(--paper);display:flex;flex-direction:column;justify-content:center;padding:0 28px;opacity:0;pointer-events:none;transition:opacity .3s ease;}
.menu-open .menu{opacity:1;pointer-events:auto;}
.menu nav{display:flex;flex-direction:column;gap:6px;}
.menu a{font-family:var(--disp);font-weight:600;font-size:34px;color:var(--ink);text-decoration:none;padding:10px 0;border-bottom:1px solid var(--line);}
.menu-meridian{height:5px;border-radius:3px;background:var(--grad);width:64%;margin-top:34px;}
.menu-open{overflow:hidden;}

/* ---------- botones ---------- */
.btn{display:inline-block;text-decoration:none;font-weight:600;font-size:15px;padding:14px 26px;border-radius:99px;transition:transform .25s ease,box-shadow .25s ease,background .25s ease,color .25s ease;border:1px solid transparent;}
.btn-s{padding:10px 18px;font-size:13.5px;}
.btn-ink{background:var(--ink);color:var(--paper);}
.btn-ink:hover{transform:translateY(-2px);box-shadow:0 10px 24px -10px rgba(0,0,0,.6);}
.btn-ghost{border-color:var(--ink);color:var(--ink);background:transparent;}
.btn-ghost:hover{background:var(--ink);color:var(--paper);transform:translateY(-2px);}
.btn:focus-visible,.lang:focus-visible,.links a:focus-visible{outline:2px solid var(--g2);outline-offset:3px;}

/* ---------- tipografía base ---------- */
.kicker{font-size:12px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);margin-bottom:18px;}
.kicker-light{color:#6B7284;}
h1,h2,h3{font-family:var(--disp);line-height:1.08;font-weight:600;}
h2{font-size:clamp(26px,3.6vw,40px);margin-bottom:22px;letter-spacing:-.01em;}
.sec-title{max-width:640px;}
.sec-note{color:var(--mute);font-size:14.5px;margin-top:-10px;margin-bottom:34px;}

/* ---------- hero ---------- */
.hero{padding:178px 0 96px;}
.hero-title{font-size:clamp(40px,7vw,84px);font-weight:700;letter-spacing:-.015em;max-width:14ch;}
.hero-title em{font-style:italic;font-weight:600;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;}
.meridian{height:6px;border-radius:3px;background:var(--grad);width:min(520px,72%);margin:36px 0;transform-origin:left center;transform:scaleX(0);animation:draw 1.1s cubic-bezier(.7,0,.2,1) .35s forwards;}
@keyframes draw{to{transform:scaleX(1);}}
.hero-sub{font-size:clamp(16px,2vw,19px);color:var(--ink-soft);max-width:600px;}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px;}
.hero-tags{margin-top:42px;font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--mute);}

/* ---------- bloques ---------- */
.block{padding:96px 0;}
.block-paper2{background:var(--paper-2);}
.two-col{display:grid;grid-template-columns:260px 1fr;gap:36px;}
@media(max-width:780px){.two-col{grid-template-columns:1fr;}}
.col-r p{margin-top:16px;color:var(--ink-soft);max-width:620px;}

/* ---------- marquee ---------- */
.marquee{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:18px 0;background:var(--paper);}
.marquee-track{display:flex;align-items:center;gap:34px;width:max-content;animation:tick 36s linear infinite;}
.marquee-track span{font-family:var(--disp);font-style:italic;font-size:19px;color:var(--ink-soft);white-space:nowrap;}
.marquee-track i{width:9px;height:9px;border-radius:50%;background:var(--grad);flex:none;}
@keyframes tick{to{transform:translateX(-50%);}}

/* ---------- servicios ---------- */
.serv-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:14px;}
@media(max-width:820px){.serv-grid{grid-template-columns:1fr;}}
.serv{background:#171F30;border:1px solid var(--line);border-radius:16px;padding:34px 30px 30px;position:relative;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease;}
.serv::before{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .45s cubic-bezier(.7,0,.2,1);}
.serv:hover{transform:translateY(-4px);box-shadow:0 18px 38px -18px rgba(0,0,0,.6);}
.serv:hover::before{transform:scaleX(1);}
.serv-num{font-family:var(--disp);font-style:italic;font-size:15px;color:var(--mute);}
.serv h3{font-size:23px;margin:10px 0 8px;}
.serv>p{color:var(--ink-soft);font-size:15px;margin-bottom:16px;}
.serv ul{list-style:none;}
.serv li{font-size:14.5px;color:var(--ink-soft);padding:7px 0 7px 22px;border-top:1px solid var(--line);position:relative;}
.serv li::before{content:"";position:absolute;left:2px;top:14px;width:8px;height:2.5px;border-radius:2px;background:var(--grad);}
.serv-plus{background:var(--ink);border-color:var(--ink);color:var(--paper);}
.serv-plus h3{color:var(--paper);}
.serv-plus>p,.serv-plus li{color:#4B4A43;}
.serv-plus li{border-top-color:rgba(14,20,32,.16);}
.serv-badge{display:inline-block;font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;background:var(--grad);color:#fff;border-radius:99px;padding:6px 13px;margin-bottom:14px;}

/* ---------- paquetes ---------- */
.paq-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
@media(max-width:880px){.paq-grid{grid-template-columns:1fr;}}
.paq{background:#171F30;border:1px solid var(--line);border-radius:16px;padding:32px 28px;display:flex;flex-direction:column;transition:transform .3s ease,box-shadow .3s ease;}
.paq:hover{transform:translateY(-4px);box-shadow:0 18px 38px -18px rgba(0,0,0,.55);}
.paq-mid{border-color:var(--g2);box-shadow:0 14px 34px -18px rgba(255,93,115,.35);}
.paq h3{font-size:21px;}
.price{font-family:var(--disp);font-style:italic;font-size:30px;margin:10px 0 16px;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;}
.paq ul{list-style:none;margin-bottom:24px;flex:1;}
.paq li{font-size:14.5px;color:var(--ink-soft);padding:7px 0;border-top:1px solid var(--line);}
.paq .btn{align-self:flex-start;}

/* ---------- portafolio ---------- */
.port-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:230px;gap:14px;}
@media(max-width:820px){.port-grid{grid-template-columns:1fr 1fr;grid-auto-rows:200px;}}
@media(max-width:560px){.port-grid{grid-template-columns:1fr;}}
.ph{position:relative;border-radius:14px;overflow:hidden;background:
  linear-gradient(135deg,rgba(255,169,77,.22),rgba(184,69,237,.2)),var(--paper-2);}
.ph-tall{grid-row:span 2;}
@media(max-width:560px){.ph-tall{grid-row:span 1;}}
.ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;}
.ph:hover img{transform:scale(1.04);}
.ph figcaption{position:absolute;left:14px;bottom:12px;font-size:12.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);background:rgba(14,20,32,.78);backdrop-filter:blur(4px);padding:6px 12px;border-radius:99px;}

/* ---------- para quién ---------- */
.block-ink{background:var(--ink);color:var(--paper);}
.block-ink h2{color:var(--paper);}
.chips{list-style:none;display:flex;flex-wrap:wrap;gap:12px;}
.chips li{border:1px solid rgba(14,20,32,.28);border-radius:99px;padding:11px 20px;font-size:14.5px;color:#3E3D37;transition:border-color .25s ease,background .25s ease;}
.chips li:hover{border-color:var(--g3);background:rgba(184,69,237,.08);}

/* ---------- sobre ---------- */
.sobre-grid{display:grid;grid-template-columns:380px 1fr;gap:48px;align-items:center;}
@media(max-width:820px){.sobre-grid{grid-template-columns:1fr;}}
.ph-sobre{height:440px;border-radius:16px;}
.sobre-txt p{margin-top:16px;color:var(--ink-soft);max-width:560px;}

/* ---------- cta final ---------- */
.block-cta{padding:120px 0;background:var(--paper-2);}
.cta-in{text-align:center;max-width:720px;}
.meridian-cta{margin:0 auto 38px;width:min(360px,70%);animation:none;transform:scaleX(1);}
.block-cta h2{font-size:clamp(30px,4.4vw,48px);}
.block-cta .hero-ctas{justify-content:center;}
.block-cta p{color:var(--ink-soft);}
.cta-mail{margin-top:30px;font-size:14.5px;}
.cta-mail a{color:var(--ink-soft);text-decoration:none;border-bottom:1px solid var(--line);}
.cta-mail a:hover{border-bottom-color:var(--g2);}

/* ---------- footer ---------- */
.foot{border-top:1px solid var(--line);padding:44px 0 56px;}
.foot-in{display:flex;flex-direction:column;gap:8px;}
.foot p{font-size:14px;color:var(--ink-soft);}
.foot-meta{color:var(--mute);font-size:13px;}

/* ---------- motion reducida: solo lo intrusivo ---------- */
@media (prefers-reduced-motion: reduce){
  .marquee-track{animation-duration:90s;}
}
