/* ================================
   21VIBES STUDIO WEBSITE STYLES
   Change colors here if needed.
================================ */
:root{
  --green:#00ff7b;
  --green-2:#13c95d;
  --green-soft:rgba(0,255,123,.16);
  --black:#020604;
  --black-2:#07120b;
  --black-3:#0b1b10;
  --white:#effff4;
  --muted:rgba(239,255,244,.68);
  --muted-2:rgba(239,255,244,.45);
  --line:rgba(0,255,123,.18);
  --shadow:0 24px 90px rgba(0,0,0,.45);
  --radius:26px;
  --font-head:'Space Grotesk', system-ui, sans-serif;
  --font-display:'Anton', Impact, sans-serif;
  --font-body:'Inter', system-ui, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{
  scroll-behavior:smooth;
  scrollbar-gutter:stable;
}
body{
  min-height:100vh;
  background:var(--black);
  color:var(--white);
  font-family:var(--font-body);
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img,video{max-width:100%;display:block}
button,input,select,textarea{font:inherit}
::selection{background:var(--green);color:#001806}

/* Scrollbars */
*{
  scrollbar-width:thin;
  scrollbar-color:rgba(0,255,123,.62) rgba(255,255,255,.05);
}
*::-webkit-scrollbar{
  width:14px;
  height:14px;
}
*::-webkit-scrollbar-track{
  background:linear-gradient(180deg,rgba(2,6,4,.96),rgba(7,18,11,.96));
}
*::-webkit-scrollbar-thumb{
  background:linear-gradient(180deg,rgba(0,255,123,.86),rgba(19,201,93,.48));
  border:3px solid rgba(2,6,4,.94);
  border-radius:999px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.08),0 0 18px rgba(0,255,123,.16);
}
*::-webkit-scrollbar-thumb:hover{
  background:linear-gradient(180deg,rgba(54,255,154,.96),rgba(19,201,93,.62));
}
*::-webkit-scrollbar-corner{
  background:rgba(2,6,4,.96);
}

.page-noise{
  position:fixed;inset:0;pointer-events:none;z-index:1000;opacity:.06;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.7'/%3E%3C/svg%3E");
}
.cursor-glow{
  position:fixed;width:360px;height:360px;border-radius:50%;pointer-events:none;z-index:1;
  background:radial-gradient(circle,rgba(0,255,123,.16),transparent 64%);
  transform:translate(-50%,-50%);filter:blur(8px);opacity:.9;
}
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--green),#d8ff7a);z-index:9999}

/* Loader */
.loader{position:fixed;inset:0;background:radial-gradient(circle at center,#0d331a 0%,#010302 72%);z-index:99999;display:grid;place-items:center;transition:opacity .6s ease,visibility .6s ease}
.loader.hidden{opacity:0;visibility:hidden}
.loader-card{text-align:center;width:min(330px,90vw);padding:36px;border:1px solid var(--line);border-radius:32px;background:rgba(5,18,10,.7);box-shadow:var(--shadow);backdrop-filter:blur(20px)}
.loader-logo{width:130px;margin:0 auto 24px;filter:drop-shadow(0 0 28px rgba(0,255,123,.35))}
.loader-line{height:4px;background:rgba(255,255,255,.08);border-radius:99px;overflow:hidden;margin-bottom:16px}
.loader-line span{display:block;height:100%;width:45%;background:var(--green);border-radius:99px;animation:loadbar 1.1s ease-in-out infinite}
.loader p{color:var(--muted);letter-spacing:.04em;font-size:.92rem}
@keyframes loadbar{0%{transform:translateX(-120%)}100%{transform:translateX(240%)}}

/* Header */
.site-header{position:fixed;top:16px;left:50%;transform:translateX(-50%);width:min(1180px,calc(100% - 32px));height:72px;z-index:999;display:flex;align-items:center;justify-content:space-between;padding:10px 12px 10px 18px;border:1px solid rgba(255,255,255,.09);border-radius:999px;background:rgba(2,6,4,.58);backdrop-filter:blur(22px);box-shadow:0 18px 60px rgba(0,0,0,.28);transition:all .3s ease}
.site-header.scrolled{height:62px;background:rgba(2,6,4,.86);border-color:var(--line)}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--font-head);font-weight:800;letter-spacing:.02em}
.brand img{width:42px;height:42px;object-fit:contain;border-radius:50%}
.brand span{font-size:1rem}.brand em{font-style:normal;color:var(--green)}
.nav{display:flex;align-items:center;gap:26px;color:var(--muted);font-size:.86rem;font-weight:700}
.nav a{transition:.25s ease}.nav a:hover{color:var(--green)}
.nav-cta{padding:13px 22px;border-radius:999px;background:var(--green);color:#041006;font-weight:900;font-size:.86rem;box-shadow:0 0 30px rgba(0,255,123,.18);transition:.25s ease}
.nav-cta:hover,.btn.primary:hover{transform:translateY(-2px);box-shadow:0 18px 44px rgba(0,255,123,.22)}
.menu-toggle{display:none;background:none;border:0;width:44px;height:44px;align-items:center;justify-content:center;gap:5px;flex-direction:column}
.menu-toggle span{width:22px;height:2px;background:var(--white);border-radius:4px}

/* Hero */
.hero{min-height:100svh;position:relative;display:grid;grid-template-columns:minmax(0,1.15fr) minmax(290px,.55fr);gap:40px;align-items:end;padding:160px max(24px,calc((100vw - 1180px)/2)) 80px;overflow:hidden}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.32;filter:saturate(1.15) contrast(1.08)}
.hero-overlay{position:absolute;inset:0;background:radial-gradient(circle at 70% 25%,rgba(0,255,123,.20),transparent 28%),linear-gradient(90deg,rgba(2,6,4,.94) 0%,rgba(2,6,4,.7) 48%,rgba(2,6,4,.88) 100%),linear-gradient(to top,var(--black),transparent 45%)}
.hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(0,255,123,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(0,255,123,.055) 1px,transparent 1px);background-size:74px 74px;mask-image:radial-gradient(circle at center,black,transparent 75%);opacity:.55}
.hero-orbit{position:absolute;right:9%;top:18%;width:330px;height:330px;border:1px solid var(--line);border-radius:50%;box-shadow:inset 0 0 60px rgba(0,255,123,.09);animation:spin 18s linear infinite}.hero-orbit::before,.hero-orbit::after{content:"";position:absolute;border-radius:50%;background:var(--green);box-shadow:0 0 26px var(--green)}.hero-orbit::before{width:10px;height:10px;top:40px;left:40px}.hero-orbit::after{width:6px;height:6px;bottom:60px;right:28px}@keyframes spin{to{transform:rotate(360deg)}}
.hero-content,.hero-panel{position:relative;z-index:2}.eyebrow{display:flex;align-items:center;gap:12px;color:var(--green);font-size:.78rem;text-transform:uppercase;letter-spacing:.18em;font-weight:900;margin-bottom:18px}.eyebrow span{width:32px;height:1px;background:var(--green);display:inline-block}
.hero h1{font-family:var(--font-display);font-size:clamp(4.8rem,11vw,10.6rem);line-height:.91;letter-spacing:.01em;max-width:900px;text-transform:uppercase;text-shadow:0 20px 80px rgba(0,0,0,.55)}
.hero h1 strong{color:var(--green);font-weight:400;text-shadow:0 0 46px rgba(0,255,123,.2)}
.hero-copy{max-width:650px;color:var(--muted);font-size:1.08rem;line-height:1.85;margin-top:24px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:54px;padding:0 24px;border-radius:999px;font-weight:900;border:1px solid transparent;transition:.25s ease;cursor:pointer}.btn.primary{background:var(--green);color:#041006}.btn.ghost{border-color:var(--line);color:var(--white);background:rgba(255,255,255,.04)}.btn.ghost:hover{border-color:var(--green);background:var(--green-soft)}
.hero-panel{align-self:center;border:1px solid var(--line);border-radius:34px;background:linear-gradient(180deg,rgba(0,255,123,.14),rgba(255,255,255,.035));padding:30px;box-shadow:var(--shadow);backdrop-filter:blur(18px)}.hero-panel img{width:190px;margin:0 auto 18px;filter:drop-shadow(0 0 30px rgba(0,255,123,.32))}.hero-panel p{text-align:center;color:var(--muted);font-weight:800;letter-spacing:.06em}.mini-tags{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-top:18px}.mini-tags span{font-size:.74rem;border:1px solid var(--line);background:rgba(0,0,0,.2);border-radius:999px;padding:8px 10px;color:var(--muted)}
.card-icon {
  width: 54px;
  height: 54px;
  border: 1px solid rgba(0, 230, 118, 0.25);
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--green);
  background: rgba(0, 230, 118, 0.08);
  margin-bottom: 22px;
}

.card-icon svg {
  width: 26px;
  height: 26px;
  stroke: currentColor;
  stroke-width: 1.8;
  fill: none;
}

/* Stats */
.stats-section{position:relative;z-index:5;width:min(1180px,calc(100% - 32px));margin:-38px auto 0;display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--line);border-radius:32px;background:rgba(7,18,11,.84);backdrop-filter:blur(22px);box-shadow:var(--shadow);overflow:hidden}.stat-card{padding:34px 28px;border-right:1px solid var(--line)}.stat-card:last-child{border-right:0}.stat-card strong,.stat-card span{font-family:var(--font-display);font-size:clamp(2.4rem,4vw,4.3rem);line-height:1;color:var(--green)}.stat-card p{color:var(--muted);font-weight:800;margin-top:10px;font-size:.94rem}
.marquee{overflow:hidden;padding:20px 0;border-block:1px solid rgba(255,255,255,.06);background:#061009}.marquee div{display:flex;width:max-content;gap:34px;animation:marquee 26s linear infinite}.marquee span{font-family:var(--font-head);font-weight:900;text-transform:uppercase;letter-spacing:.16em;color:var(--muted-2);white-space:nowrap}.marquee span::after{content:" ✦";color:var(--green);margin-left:34px}@keyframes marquee{to{transform:translateX(-50%)}}

/* General sections */
.section,.it-section,.request-section{width:min(1180px,calc(100% - 32px));margin:0 auto;padding:110px 0}.section-head{display:grid;grid-template-columns:.8fr 1.2fr;gap:40px;align-items:end;margin-bottom:42px}.section-head h2,.it-copy h2,.request-copy h2{font-family:var(--font-head);font-size:clamp(2.4rem,5vw,5rem);line-height:.98;letter-spacing:-.055em}.section-head h2 em,.it-copy h2 em{color:var(--green);font-style:normal}.section-head>p:last-child,.it-copy p,.request-copy p{color:var(--muted);line-height:1.8;font-size:1rem}

.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.service-card{position:relative;min-height:390px;padding:30px;border:1px solid rgba(255,255,255,.075);border-radius:var(--radius);background:linear-gradient(145deg,rgba(255,255,255,.055),rgba(255,255,255,.02));overflow:hidden;transition:.3s ease}.service-card::before{content:"";position:absolute;inset:-1px;background:radial-gradient(circle at 20% 0,rgba(0,255,123,.22),transparent 35%);opacity:0;transition:.3s ease}.service-card:hover{transform:translateY(-7px);border-color:var(--line);box-shadow:0 22px 70px rgba(0,0,0,.28)}.service-card:hover::before{opacity:1}.service-card>*{position:relative}.featured-card{background:linear-gradient(145deg,rgba(0,255,123,.17),rgba(255,255,255,.03));border-color:var(--line)}.card-icon{width:54px;height:54px;border-radius:18px;background:var(--green-soft);border:1px solid var(--line);display:grid;place-items:center;color:var(--green);font-size:1.4rem;margin-bottom:24px}.service-card h3{font-family:var(--font-head);font-size:1.5rem;line-height:1.1;margin-bottom:12px}.service-card p{color:var(--muted);line-height:1.7;margin-bottom:22px}.service-card ul{list-style:none;display:grid;gap:12px;color:var(--muted)}.service-card li{display:flex;gap:10px;align-items:flex-start}.service-card li::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green);margin-top:8px;box-shadow:0 0 14px var(--green)}

/* IT */
.it-section{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center}.skill-cloud{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px}.skill-cloud span{border:1px solid var(--line);background:rgba(0,255,123,.06);color:var(--white);padding:10px 14px;border-radius:999px;font-size:.9rem;font-weight:800}.terminal-card{border:1px solid var(--line);border-radius:32px;background:linear-gradient(145deg,#061009,#010302);box-shadow:var(--shadow);overflow:hidden}.terminal-top{height:54px;border-bottom:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:8px;padding:0 20px}.terminal-top span{width:12px;height:12px;border-radius:50%;background:rgba(255,255,255,.25)}.terminal-top span:first-child{background:var(--green)}pre{white-space:pre-wrap;padding:28px;color:#bfffd8;font-size:.95rem;line-height:1.8}

/* Projects */
.projects {
  padding-top: 80px;
}

.project-grid {
  display: grid;
  grid-template-columns: 1.1fr .7fr .7fr;
  grid-auto-rows: minmax(290px, auto);
  gap: 16px;
}

.project-card {
  position: relative;
  border: 1px solid rgba(255,255,255,.075);
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--black-2);
  min-height: 310px;
}

.project-card.big {
  grid-row: span 2;
}

.project-media {
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.project-media video,
.project-media img {
  width: 100%;
  height: 100%;
  min-height: 260px;
  object-fit: cover;
  position: absolute;
  inset: 0;
  display: block;
}

/* IMPORTANT: video is visible immediately */
.project-media video {
  z-index: 2;
  opacity: 1;
  transition: transform .7s ease;
}

.project-media video.fit-contain {
  object-fit: contain;
  background:
    radial-gradient(circle at top, rgba(0,255,123,.14), transparent 42%),
    linear-gradient(180deg, rgba(2,6,4,.98), rgba(7,18,11,.98));
}

/* Optional: keep small zoom effect only, no play/pause behavior */
.project-card:hover .project-media video {
  transform: scale(1.05);
}

/* Hide backup image when video is available */
.project-media img {
  display: none;
}

.project-media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(2,6,4,.94),
    rgba(2,6,4,.18),
    transparent
  );
  z-index: 3;
}

.project-info {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 26px;
  z-index: 4;
}

.project-info span {
  color: var(--green);
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: .72rem;
  font-weight: 900;
}

.project-info h3 {
  font-family: var(--font-head);
  font-size: 1.5rem;
  margin: 8px 0;
}

.project-info p {
  color: var(--muted);
  line-height: 1.65;
}
/* Process */
.process{padding-top:90px}.process-grid{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--line);border-radius:32px;overflow:hidden}.process-step{padding:32px;border-right:1px solid var(--line);background:rgba(255,255,255,.025)}.process-step:last-child{border-right:0}.process-step strong{font-family:var(--font-display);font-size:3.5rem;color:rgba(0,255,123,.22);font-weight:400}.process-step h3{font-family:var(--font-head);font-size:1.3rem;margin:12px 0}.process-step p{color:var(--muted);line-height:1.75}

/* Form */
.request-section{display:grid;grid-template-columns:.86fr 1.14fr;gap:44px;align-items:start}.request-form{border:1px solid var(--line);background:rgba(255,255,255,.035);padding:28px;border-radius:32px;box-shadow:var(--shadow)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}label{display:grid;gap:9px;color:var(--white);font-weight:900;font-size:.9rem;margin-bottom:14px}input,select,textarea{width:100%;border:1px solid rgba(255,255,255,.1);background:rgba(0,0,0,.28);color:var(--white);border-radius:16px;padding:15px 16px;outline:none;transition:.25s ease}select option{color:#0b1b10}input:focus,select:focus,textarea:focus{border-color:var(--green);box-shadow:0 0 0 4px rgba(0,255,123,.1)}textarea{resize:vertical}.form-btn{width:100%;border:0;margin-top:8px}

/* Footer */
.footer{width:min(1180px,calc(100% - 32px));margin:0 auto;padding:36px 0 44px;border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:24px;color:var(--muted)}.footer img{width:82px;margin-bottom:10px}.footer-links{display:flex;gap:18px;font-weight:900}.footer-links a:hover{color:var(--green)}.copyright{font-size:.9rem;text-align:right}.floating-whatsapp{position:fixed;right:22px;bottom:22px;z-index:888;width:60px;height:60px;border-radius:50%;display:grid;place-items:center;background:var(--green);color:#041006;font-size:1.35rem;font-weight:900;box-shadow:0 18px 44px rgba(0,255,123,.28);animation:float 2.4s ease-in-out infinite}@keyframes float{50%{transform:translateY(-8px)}}

/* Reveal animation */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .75s ease,transform .75s ease}.reveal.visible{opacity:1;transform:translateY(0)}.delay-1{transition-delay:.12s}.delay-2{transition-delay:.22s}.delay-3{transition-delay:.32s}

/* Responsive */
@media(max-width:980px){
  .cursor-glow{display:none}.site-header{top:10px;width:calc(100% - 20px)}.menu-toggle{display:flex}.nav{position:absolute;top:74px;left:0;right:0;display:grid;gap:0;background:rgba(2,6,4,.96);border:1px solid var(--line);border-radius:24px;padding:10px;opacity:0;pointer-events:none;transform:translateY(-10px);transition:.25s ease}.nav.open{opacity:1;pointer-events:auto;transform:translateY(0)}.nav a{padding:14px 16px;border-radius:14px}.nav a:hover{background:var(--green-soft)}.nav-cta{display:none}.hero{grid-template-columns:1fr;padding-top:150px}.hero-panel{max-width:430px}.stats-section{grid-template-columns:repeat(2,1fr);margin-top:0}.stat-card:nth-child(2){border-right:0}.stat-card:nth-child(1),.stat-card:nth-child(2){border-bottom:1px solid var(--line)}.section-head,.it-section,.request-section{grid-template-columns:1fr}.service-grid,.project-grid{grid-template-columns:1fr 1fr}.project-card.big{grid-row:span 1}.process-grid{grid-template-columns:1fr 1fr}.footer{flex-direction:column;text-align:center}.copyright{text-align:center}
}
@media(max-width:640px){
  .hero h1{font-size:4.1rem}.hero-copy{font-size:.98rem}.hero-actions,.form-row{grid-template-columns:1fr;display:grid}.btn{width:100%}.stats-section,.service-grid,.project-grid,.process-grid{grid-template-columns:1fr}.stat-card{border-right:0;border-bottom:1px solid var(--line)}.stat-card:last-child{border-bottom:0}.section,.it-section,.request-section{padding:72px 0}.section-head h2,.it-copy h2,.request-copy h2{font-size:2.5rem}.footer-links{flex-wrap:wrap;justify-content:center}.floating-whatsapp{right:16px;bottom:16px}
}
