:root{
  --black:#050505;
  --dark:#0c0c0c;
  --card:#111111;
  --yellow:#f4d000;
  --yellow2:#ffe45c;
  --white:#f7f7f7;
  --muted:#bdbdbd;
  --line:rgba(244,208,0,.28);
  --shadow:0 24px 80px rgba(0,0,0,.55);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;
  color:var(--white);
  background:radial-gradient(circle at top left,rgba(244,208,0,.18),transparent 28%),linear-gradient(180deg,#050505,#0c0c0c 42%,#050505);
  overflow-x:hidden;
}
body.modal-open{overflow:hidden}
button{font:inherit;color:inherit}
.noise{position:fixed;inset:0;pointer-events:none;opacity:.065;background-image:linear-gradient(45deg,rgba(255,255,255,.16) 1px,transparent 1px);background-size:18px 18px;z-index:-1}
.site-header{position:fixed;top:0;left:0;right:0;z-index:30;display:flex;align-items:center;justify-content:space-between;padding:18px clamp(18px,5vw,72px);background:rgba(5,5,5,.72);backdrop-filter:blur(18px);border-bottom:1px solid rgba(255,255,255,.08)}
.brand{display:flex;align-items:center;gap:12px;color:var(--white);text-decoration:none;font-weight:900;letter-spacing:.02em}
.brand img{height:42px;max-width:160px;object-fit:contain;filter:drop-shadow(0 0 18px rgba(244,208,0,.25))}
.nav{display:flex;gap:26px}
.nav a{color:var(--muted);text-decoration:none;font-weight:700;font-size:.95rem;transition:.25s}
.nav a:hover{color:var(--yellow)}
.menu-toggle{display:none;background:var(--yellow);color:#000;border:0;border-radius:10px;padding:8px 11px;font-size:1.2rem}
.section{padding:110px clamp(18px,6vw,92px)}
.hero{min-height:100vh;display:grid;grid-template-columns:1.25fr .75fr;align-items:center;gap:54px;position:relative;padding-top:150px}
.hero:before{content:"";position:absolute;right:-15%;top:12%;width:520px;height:520px;border:1px solid var(--line);border-radius:50%;box-shadow:inset 0 0 90px rgba(244,208,0,.08),0 0 80px rgba(244,208,0,.08);animation:spin 18s linear infinite;z-index:-1}
.eyebrow{display:inline-flex;color:#0a0a0a;background:var(--yellow);font-weight:900;text-transform:uppercase;letter-spacing:.12em;font-size:.75rem;padding:8px 12px;border-radius:999px;margin-bottom:18px}
.eyebrow.mini{font-size:.68rem;margin-bottom:12px}
h1{font-size:clamp(2.6rem,7vw,6.8rem);line-height:.92;letter-spacing:-.07em;max-width:980px}
h2{font-size:clamp(2rem,4vw,4rem);line-height:1;letter-spacing:-.05em;margin-bottom:20px}
h3{font-size:1.25rem;margin-bottom:12px}
p{color:var(--muted);line-height:1.75}
.hero-text{font-size:1.2rem;max-width:720px;margin:24px 0 34px}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}
.btn{padding:15px 22px;border-radius:999px;text-decoration:none;font-weight:900;transition:.28s}
.btn.primary{background:var(--yellow);color:#050505;box-shadow:0 0 30px rgba(244,208,0,.3)}
.btn.ghost{border:1px solid var(--line);color:var(--white)}
.btn:hover{transform:translateY(-4px)}
.hero-card{position:relative;padding:34px;background:linear-gradient(145deg,rgba(244,208,0,.14),rgba(255,255,255,.04));border:1px solid var(--line);border-radius:30px;box-shadow:var(--shadow);overflow:hidden}
.hero-card h2{font-size:2rem}
.hero-card ul{list-style:none;display:grid;gap:13px}
.hero-card li{padding:14px 16px;border-radius:16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.06);font-weight:800}
.orb{position:absolute;width:160px;height:160px;right:-50px;top:-50px;background:var(--yellow);filter:blur(16px);opacity:.45;border-radius:50%}
.section-head{max-width:850px;margin-bottom:38px}
.compact-head{max-width:1020px}
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.service-tile{padding:28px;min-height:178px;background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.025));border:1px solid rgba(255,255,255,.08);border-radius:26px;transition:.35s;position:relative;overflow:hidden;text-align:left;cursor:pointer}
.service-tile:before{content:"";position:absolute;inset:auto -30% -55% -30%;height:130px;background:var(--yellow);filter:blur(48px);opacity:0;transition:.35s}
.service-tile:after{content:"↗";position:absolute;right:24px;top:22px;width:38px;height:38px;display:grid;place-items:center;border-radius:999px;background:rgba(244,208,0,.1);border:1px solid var(--line);color:var(--yellow);opacity:.55;transition:.35s}
.service-tile:hover,.service-tile:focus-visible{transform:translateY(-8px);border-color:var(--line);outline:none}
.service-tile:hover:before,.service-tile:focus-visible:before{opacity:.28}
.service-tile:hover:after,.service-tile:focus-visible:after{opacity:1;transform:rotate(45deg)}
.service-tile span{display:inline-block;color:var(--yellow);font-weight:900;margin-bottom:48px}
.service-tile h3{font-size:1.35rem;line-height:1.15;max-width:260px}
.service-tile.featured{border-color:var(--line);background:linear-gradient(145deg,rgba(244,208,0,.18),rgba(255,255,255,.04))}
.split{display:grid;grid-template-columns:1fr 1fr;gap:42px;align-items:start}
.split p{margin-bottom:18px}
.mission-box{padding:36px;border-radius:30px;background:#0f0f0f;border:1px solid var(--line);box-shadow:var(--shadow)}
.mission-box h3{color:var(--yellow);font-size:1.45rem;margin-top:12px}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding-top:30px;padding-bottom:30px}
.stats div{padding:26px;border-radius:24px;border:1px solid var(--line);background:rgba(244,208,0,.08);text-align:center}
.stats strong{display:block;font-size:1.7rem;color:var(--yellow);margin-bottom:6px}
.stats span{color:var(--muted)}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.portfolio-tile{min-height:280px;position:relative;border:1px solid rgba(255,255,255,.1);border-radius:28px;background:#101010;overflow:hidden;text-align:left;cursor:pointer;box-shadow:var(--shadow);transition:.35s}
.portfolio-tile:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,5,5,.12),rgba(5,5,5,.86)),var(--bg) center/cover no-repeat;filter:saturate(.92) contrast(1.05);transition:.55s}
.portfolio-tile:after{content:"";position:absolute;inset:18px;border:1px solid rgba(244,208,0,.25);border-radius:22px;opacity:.55}
.portfolio-tile span,.portfolio-tile h3{position:relative;z-index:1}
.portfolio-tile span{display:inline-block;margin:26px 0 0 26px;color:#050505;background:var(--yellow);padding:7px 12px;border-radius:999px;font-weight:900;font-size:.8rem}
.portfolio-tile h3{position:absolute;left:26px;right:26px;bottom:25px;font-size:clamp(1.5rem,2.4vw,2.4rem);letter-spacing:-.05em;line-height:1;color:#fff;text-shadow:0 12px 24px rgba(0,0,0,.55)}
.portfolio-tile:hover,.portfolio-tile:focus-visible{transform:translateY(-8px);border-color:var(--yellow);outline:none}
.portfolio-tile:hover:before,.portfolio-tile:focus-visible:before{transform:scale(1.08);filter:saturate(1.05) contrast(1.08)}
.contact{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:center}
.contact-card{padding:32px;border:1px solid var(--line);border-radius:28px;background:linear-gradient(145deg,rgba(244,208,0,.16),rgba(255,255,255,.04));box-shadow:var(--shadow)}
.contact-card p{margin-bottom:16px}
.contact-card strong{color:var(--yellow)}
footer{padding:28px;text-align:center;border-top:1px solid rgba(255,255,255,.08);background:#050505}
.reveal{opacity:0;transform:translateY(44px);transition:opacity .75s ease,transform .75s ease}
.reveal.visible{opacity:1;transform:none}
@keyframes spin{to{transform:rotate(360deg)}}

/* Modales */
.modal{width:min(1180px,calc(100vw - 36px));max-height:calc(100vh - 36px);margin:auto;padding:0;border:1px solid rgba(244,208,0,.42);border-radius:30px;background:linear-gradient(145deg,rgba(18,18,18,.98),rgba(3,3,3,.98));box-shadow:0 30px 120px rgba(0,0,0,.85);color:var(--white);overflow:hidden}
.modal::backdrop{background:rgba(0,0,0,.72);backdrop-filter:blur(10px)}
.close-modal{position:absolute;right:18px;top:18px;z-index:20;width:46px;height:46px;border:1px solid rgba(244,208,0,.35);background:#050505;color:var(--yellow);border-radius:999px;font-size:1.6rem;font-weight:800;cursor:pointer;transition:.25s}
.close-modal:hover{background:var(--yellow);color:#050505;transform:rotate(90deg)}
.modal-arrow{position:absolute;top:50%;z-index:18;width:48px;height:72px;border:1px solid rgba(244,208,0,.32);background:rgba(5,5,5,.72);color:var(--yellow);border-radius:999px;font-size:3rem;line-height:.7;cursor:pointer;display:grid;place-items:center;transition:.25s;backdrop-filter:blur(8px)}
.modal-arrow:hover{background:var(--yellow);color:#050505;transform:translateY(-50%) scale(1.06)}
.modal-arrow-left{left:14px;transform:translateY(-50%)}
.modal-arrow-right{right:14px;transform:translateY(-50%)}
.service-modal-grid{display:grid;grid-template-columns:1fr .92fr;gap:28px;padding:48px 66px}
.modal-copy{padding:18px 0}
.modal-copy h2{font-size:clamp(2.5rem,6vw,5.2rem);margin-bottom:24px}
.modal-copy p{font-size:1.05rem;max-width:660px}
.modal-copy ul{list-style:none;display:grid;gap:13px;margin-top:24px}
.modal-copy li{position:relative;padding:14px 18px 14px 40px;border-radius:16px;background:rgba(255,255,255,.045);border:1px solid rgba(244,208,0,.16);color:#d8d8d8}
.modal-copy li:before{content:"";position:absolute;left:18px;top:23px;width:6px;height:6px;background:var(--yellow);border-radius:50%}
.service-visual{min-height:520px;border-radius:26px;overflow:hidden;border:1px solid rgba(244,208,0,.22);background:radial-gradient(circle at center,rgba(244,208,0,.16),rgba(255,255,255,.035));box-shadow:inset 0 0 0 1px rgba(255,255,255,.03)}
.service-visual img{width:100%;height:100%;min-height:520px;object-fit:cover;display:block}

.service-visual.contain-panel{
  display:grid;
  place-items:center;
  padding:26px;
  background:
    radial-gradient(circle at 24% 22%,rgba(244,208,0,.18),transparent 34%),
    radial-gradient(circle at 76% 72%,rgba(244,208,0,.10),transparent 36%),
    linear-gradient(135deg,rgba(244,208,0,.08),rgba(255,255,255,.03));
}
.service-visual.contain-panel img{
  width:100%;
  height:100%;
  min-height:0;
  object-fit:contain;
  border-radius:22px;
  background:#0e0f12;
  box-shadow:0 20px 60px rgba(0,0,0,.35);
}

.service-visual.logo-panel{
  display:grid;
  place-items:center;
  padding:46px;
  background:
    radial-gradient(circle at 30% 20%,rgba(244,208,0,.24),transparent 35%),
    radial-gradient(circle at 70% 80%,rgba(244,208,0,.12),transparent 35%),
    linear-gradient(145deg,rgba(244,208,0,.12),rgba(255,255,255,.035));
}
.service-visual.logo-panel img{
  width:min(78%,420px);
  height:auto;
  min-height:0;
  object-fit:contain;
  padding:54px;
  border-radius:28px;
  border:1px solid rgba(244,208,0,.28);
  background:rgba(5,5,5,.55);
  box-shadow:0 24px 70px rgba(0,0,0,.45), 0 0 40px rgba(244,208,0,.10);
}

.service-visual.no-image{
  display:grid;
  place-items:center;
  position:relative;
  min-height:520px;
  background:
    radial-gradient(circle at 24% 22%,rgba(244,208,0,.24),transparent 34%),
    radial-gradient(circle at 76% 72%,rgba(244,208,0,.12),transparent 36%),
    linear-gradient(135deg,rgba(244,208,0,.12),rgba(255,255,255,.035));
}
.service-visual.no-image img{display:none!important}
.service-visual.no-image .software-mark{
  width:82%;
  min-height:360px;
  display:grid;
  place-items:center;
  position:relative;
  border-radius:28px;
  border:1px solid rgba(244,208,0,.25);
  background:linear-gradient(145deg,rgba(5,5,5,.55),rgba(244,208,0,.07));
  overflow:hidden;
}
.service-visual.no-image .software-mark:before{
  content:"AST";
  position:absolute;
  top:28px;
  left:50%;
  transform:translateX(-50%);
  font-weight:900;
  font-size:clamp(5rem,12vw,10rem);
  letter-spacing:-.12em;
  color:rgba(244,208,0,.24);
}
.service-visual.no-image .software-mark:after{
  content:"Software a la medida";
  position:absolute;
  left:24px;
  right:24px;
  bottom:24px;
  padding:16px 18px;
  border-radius:18px;
  background:rgba(5,5,5,.72);
  border:1px solid var(--line);
  color:var(--yellow);
  font-weight:900;
}

/* Carrusel */
.project-modal{width:min(1240px,calc(100vw - 28px));height:min(780px,calc(100vh - 28px));padding:34px 24px 28px}
.project-modal-head{text-align:center;padding-right:42px}
.project-modal-head h2{font-size:clamp(2rem,4vw,4.3rem);margin-bottom:0}
.carousel-stage{height:calc(100% - 130px);min-height:430px;display:grid;place-items:center;perspective:2100px;overflow:hidden;cursor:grab;user-select:none;touch-action:pan-y}
.carousel-stage:active{cursor:grabbing}
.carousel-ring{position:relative;width:390px;height:255px;transform-style:preserve-3d;transition:transform .08s linear}
.carousel-item{position:absolute;left:50%;top:50%;width:360px;height:238px;margin-left:-180px;margin-top:-119px;border-radius:20px;overflow:hidden;border:1px solid rgba(244,208,0,.38);box-shadow:0 18px 42px rgba(0,0,0,.55);background:#111;backface-visibility:hidden}
.carousel-item img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(.96) contrast(1.06)}

@media(max-width:1050px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .hero,.split,.contact,.service-modal-grid{grid-template-columns:1fr}
  .portfolio-grid{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr)}
  .service-modal-grid{padding:44px 56px}
  .service-visual,.service-visual img,.service-visual.no-image{min-height:360px}
  .modal{overflow:auto}
  .project-modal{height:min(720px,calc(100vh - 28px))}
  .carousel-item{width:300px;height:200px;margin-left:-150px;margin-top:-100px}
  .carousel-ring{width:330px;height:220px}
}
@media(max-width:720px){
  .site-header{padding:14px 18px}
  .brand span{display:none}
  .menu-toggle{display:block}
  .nav{position:absolute;top:72px;left:18px;right:18px;display:none;flex-direction:column;padding:18px;background:#0b0b0b;border:1px solid var(--line);border-radius:18px}
  .nav.open{display:flex}
  .section{padding:86px 18px}
  .hero{padding-top:130px}
  .services-grid,.portfolio-grid,.stats{grid-template-columns:1fr}
  h1{font-size:3.1rem}
  .hero-card{padding:24px}
  .service-tile{min-height:150px}
  .portfolio-tile{min-height:220px}
  .modal{width:calc(100vw - 18px);border-radius:22px}
  .service-modal-grid{padding:24px 18px 82px}
  .close-modal{right:12px;top:12px;width:42px;height:42px}
  .modal-arrow{top:auto;bottom:16px;width:54px;height:46px;font-size:2.4rem}
  .modal-arrow-left{left:calc(50% - 66px);transform:none}
  .modal-arrow-right{right:calc(50% - 66px);transform:none}
  .modal-arrow:hover{transform:scale(1.05)}
  .service-visual,.service-visual img,.service-visual.no-image{min-height:280px}
  .project-modal{padding:26px 12px;height:min(650px,calc(100vh - 18px))}
  .project-modal-head{padding-right:34px}
  .carousel-stage{height:calc(100% - 110px);min-height:350px}
  .carousel-item{width:245px;height:165px;margin-left:-122.5px;margin-top:-82.5px}
  .carousel-ring{width:260px;height:180px}
}

@media(max-width:720px){
  
.service-visual.contain-panel{
  display:grid;
  place-items:center;
  padding:26px;
  background:
    radial-gradient(circle at 24% 22%,rgba(244,208,0,.18),transparent 34%),
    radial-gradient(circle at 76% 72%,rgba(244,208,0,.10),transparent 36%),
    linear-gradient(135deg,rgba(244,208,0,.08),rgba(255,255,255,.03));
}
.service-visual.contain-panel img{
  width:100%;
  height:100%;
  min-height:0;
  object-fit:contain;
  border-radius:22px;
  background:#0e0f12;
  box-shadow:0 20px 60px rgba(0,0,0,.35);
}

.service-visual.logo-panel{padding:24px}
  .service-visual.logo-panel img{padding:34px;width:min(88%,360px)}
}


@media(max-width:720px){
  .service-visual.contain-panel{padding:16px}
}
