/* ===== RESET ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0e0e0e;
  --bg2:#141414;
  --bg3:#1a1a1a;
  --surface:#1e1e1e;
  --border:rgba(255,255,255,.06);
  --border-h:rgba(255,255,255,.12);
  --text:#aaa;
  --text2:#666;
  --white:#f0f0f0;
  --radius:16px;
  --max-w:1400px;
}
html{font-size:16px;-webkit-text-size-adjust:100%}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:var(--bg);color:var(--text);line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}
::selection{background:rgba(255,255,255,.1);color:#fff}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.container{max-width:var(--max-w);margin:0 auto;padding:0 clamp(24px,5vw,64px)}
section{padding:clamp(100px,15vw,200px) 0;position:relative}

/* ===== PRELOADER ===== */
.preloader{
  position:fixed;inset:0;z-index:9999;background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:24px;
}
.preloader-logo{
  font-size:clamp(2rem,5vw,3.5rem);font-weight:800;color:var(--white);
  letter-spacing:-.04em;opacity:0;
}
.preloader-logo span{font-weight:300;color:var(--text2)}
.preloader-bar{width:200px;height:1px;background:var(--border);overflow:hidden;opacity:0}
.preloader-bar-inner{width:0;height:100%;background:var(--white)}
.preloader-tagline{
  font-size:clamp(.8rem,1.5vw,1rem);font-weight:300;letter-spacing:.25em;
  text-transform:uppercase;color:var(--text2);opacity:0;
}
.preloader-count{
  font-size:.7rem;font-weight:500;letter-spacing:.2em;
  color:var(--text2);font-variant-numeric:tabular-nums;opacity:0;
}
body.loaded .preloader{pointer-events:none}

/* cursor removed */

/* ===== TYPOGRAPHY ===== */
h1{font-size:clamp(3.5rem,9vw,8rem);font-weight:800;line-height:.95;letter-spacing:-.05em;color:var(--white)}
h2{font-size:clamp(2.2rem,5.5vw,4.5rem);font-weight:700;line-height:1;letter-spacing:-.04em;color:var(--white)}
h3{font-size:clamp(1.1rem,2vw,1.4rem);font-weight:600;line-height:1.3;color:var(--white)}
h1 em,h2 em,.hero h1 em{font-style:italic;font-weight:300;color:var(--text2)}
.eyebrow{
  font-size:.65rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.2em;color:var(--text2);margin-bottom:24px;
  display:flex;align-items:center;gap:16px;
}
.eyebrow::before{display:none}
.lead{font-size:clamp(1rem,1.6vw,1.2rem);color:var(--text2);line-height:1.8;margin-top:16px}

/* Split text */
.split-line{overflow:hidden;display:block}
.split-word{display:inline-block;transform:translateY(110%);opacity:0}
.split-char{display:inline-block;transform:translateY(100%)}

/* ===== NAV ===== */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:24px 0;mix-blend-mode:difference;transition:padding .5s;
}
nav.scrolled{padding:14px 0;mix-blend-mode:normal;background:rgba(14,14,14,.92);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px)}
nav .container{display:flex;align-items:center;justify-content:space-between}
.logo{font-size:1.1rem;font-weight:800;color:#fff;letter-spacing:-.02em}
.logo span{font-weight:300;opacity:.5}
.nav-links{display:flex;align-items:center;gap:40px;list-style:none}
.nav-links a{
  font-size:.7rem;font-weight:500;color:#fff;opacity:.5;
  letter-spacing:.08em;text-transform:uppercase;
  transition:opacity .3s;position:relative;
}
.nav-links a:hover,.nav-links a.active{opacity:1}
.nav-cta{
  padding:10px 28px;border:1px solid rgba(255,255,255,.2);border-radius:99px;
  opacity:1!important;transition:all .3s;
}
.nav-cta:hover{background:#fff;color:#000!important}
.burger{display:none;cursor:pointer;width:32px;height:20px;position:relative;z-index:101}
.burger span{
  position:absolute;left:0;width:100%;height:1.5px;background:#fff;
  transition:all .4s cubic-bezier(.77,0,.18,1);
}
.burger span:nth-child(1){top:0}
.burger span:nth-child(2){top:50%;transform:translateY(-50%)}
.burger span:nth-child(3){bottom:0;width:50%;margin-left:auto;right:0;left:auto}

/* ===== HERO ===== */
.hero{min-height:100vh;display:flex;align-items:flex-end;padding-bottom:clamp(60px,10vw,120px)}
.hero-content{width:100%}
.hero-label{
  font-size:.65rem;font-weight:500;letter-spacing:.2em;
  text-transform:uppercase;color:var(--text2);margin-bottom:40px;
  display:flex;align-items:center;gap:12px;
  opacity:0;transform:translateY(20px);
}
.hero-dot{
  width:6px;height:6px;border-radius:50%;background:#4a4;
  animation:blink 2s infinite;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.hero h1{margin-bottom:32px}
.hero-bottom{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-top:clamp(48px,8vw,80px);padding-top:32px;
}
.hero-desc{
  font-size:clamp(.9rem,1.4vw,1.05rem);color:var(--text);max-width:400px;line-height:1.8;
  opacity:0;transform:translateY(30px);
}
.hero-meta{display:flex;gap:clamp(32px,5vw,64px);opacity:0;transform:translateY(30px)}
.meta-item .num{
  font-size:clamp(2rem,4vw,3.5rem);font-weight:700;color:var(--white);
  line-height:1;font-variant-numeric:tabular-nums;
}
.meta-item .label{
  font-size:.6rem;text-transform:uppercase;letter-spacing:.15em;
  color:var(--text2);margin-top:6px;
}

/* ===== MARQUEE ===== */
.marquee{
  padding:48px 0;
  overflow:hidden;
}
.marquee-track{display:flex;width:max-content;will-change:transform}
.marquee-item{
  font-size:clamp(.65rem,1vw,.8rem);font-weight:500;text-transform:uppercase;
  letter-spacing:.2em;color:var(--text2);padding:0 clamp(24px,4vw,56px);
  white-space:nowrap;display:flex;align-items:center;gap:16px;
}
.marquee-item::before{content:'';width:4px;height:4px;border-radius:50%;background:var(--text2)}

/* ===== SERVICES ===== */
.services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--border);margin-top:80px;
}
.service{
  background:var(--bg);padding:clamp(36px,5vw,64px);
  position:relative;overflow:hidden;
}
.service::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(255,255,255,.03),transparent 60%);
  opacity:0;transition:opacity .4s;pointer-events:none;
}
.service:hover::before{opacity:1}
.service-num{
  font-size:.55rem;font-weight:600;color:var(--text2);
  letter-spacing:.15em;margin-bottom:28px;font-variant-numeric:tabular-nums;
}
.service h3{margin-bottom:12px}
.service p{font-size:.875rem;color:var(--text2);line-height:1.75}
.service-icon{
  width:48px;height:48px;border-radius:14px;
  border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:28px;color:var(--text2);
  transition:border-color .3s,color .3s;
}
.service:hover .service-icon{border-color:var(--border-h);color:var(--text)}

/* ===== PORTFOLIO ===== */
.portfolio{background:var(--bg2)}
.portfolio-grid{
  margin-top:80px;display:grid;
  grid-template-columns:repeat(2,1fr);gap:24px;
}
.project-card{
  position:relative;display:block;
  background:var(--bg3);border-radius:var(--radius);
  padding:16px;transition:background .4s;
}
.project-card:hover{background:var(--surface)}
.project-card img{
  width:100%;height:auto;display:block;
  border-radius:10px;
}
.project-card:hover img{}
.project-card-info{
  padding:14px 4px 4px;display:flex;justify-content:space-between;align-items:center;
}
.project-card-info h3{font-size:1rem;font-weight:600}
.project-card-info span{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text2)}
.project-card.featured{grid-column:span 2}

/* ===== PROJECT TABLE ===== */
.project-table{margin-top:48px}
.project-table-head{
  display:grid;grid-template-columns:2fr 1.5fr .5fr 40px;gap:16px;
  padding:12px 0;font-size:.6rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.15em;color:var(--text2);
  border-bottom:1px solid var(--border-h);
}
.project-table-row{
  display:grid;grid-template-columns:2fr 1.5fr .5fr 40px;gap:16px;
  padding:18px 0;align-items:center;
  border-bottom:1px solid var(--border);
  transition:all .3s;
}
.project-table-row:hover{padding-left:12px;background:rgba(255,255,255,.02)}
.ptr-name{color:var(--white);font-weight:600;font-size:.95rem}
.ptr-cat{color:var(--text2);font-size:.85rem}
.ptr-year{color:var(--text2);font-size:.85rem;font-variant-numeric:tabular-nums}
.ptr-arrow{color:var(--text2);transition:transform .3s,color .3s;display:flex}
.project-table-row:hover .ptr-arrow{transform:translate(3px,-3px);color:var(--white)}
@media(max-width:768px){
  .project-table-head{display:none}
  .project-table-row{grid-template-columns:1fr auto auto;gap:8px}
  .ptr-cat{display:none}
}

/* ===== ABOUT ===== */
.about-layout{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(48px,8vw,140px);align-items:start;margin-top:80px;
}
.about-text{position:sticky;top:120px}
.about-text p{color:var(--text);margin-bottom:24px;line-height:1.85;font-size:.95rem}
.about-text strong{color:var(--white);font-weight:600}
.milestone{
  padding:36px 0;
  display:grid;grid-template-columns:80px 1fr;gap:28px;
}
.milestone:first-child{padding-top:0}
.milestone:last-child{}
.milestone-year{
  font-size:.6rem;font-weight:600;color:var(--text2);
  letter-spacing:.15em;padding-top:6px;
}
.milestone h4{color:var(--white);font-size:1.05rem;font-weight:600;margin-bottom:8px}
.milestone p{color:var(--text2);font-size:.875rem;line-height:1.75}

/* ===== CERT PILLS ===== */
.cert-pill{
  padding:6px 14px;border-radius:99px;font-size:.7rem;font-weight:500;
  background:var(--surface);color:var(--text);border:1px solid var(--border);
  white-space:nowrap;
}

/* ===== DOMAINS ===== */
.domains{background:var(--bg2)}
.daas-block{
  margin:64px 0;padding:clamp(40px,6vw,80px);
  border:1px solid var(--border);border-radius:20px;
  position:relative;overflow:hidden;text-align:center;
}
.daas-block::before{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  display:none;
}
.daas-block::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 0%,rgba(255,255,255,.02),transparent 60%);
  pointer-events:none;
}
.daas-block h3{font-size:clamp(1.4rem,3vw,2rem);margin-bottom:20px;position:relative;z-index:1}
.daas-block p{color:var(--text2);max-width:500px;margin:0 auto 8px;line-height:1.8;position:relative;z-index:1}
.daas-block em{color:var(--white);font-style:normal;font-weight:500}
.daas-block .highlight{color:var(--text);font-style:italic}
.domains-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.domain-card{
  border:1px solid var(--border);border-radius:14px;overflow:hidden;
  background:var(--bg);transition:all .5s cubic-bezier(.22,1,.36,1);
}
.domain-card:hover{border-color:var(--border-h);transform:translateY(-6px)}
.domain-card img{
  width:100%;aspect-ratio:16/10;object-fit:cover;
  filter:brightness(1);transition:filter .5s,transform .8s cubic-bezier(.22,1,.36,1);
}
.domain-card:hover img{filter:brightness(1.08);transform:scale(1.03)}
.domain-card h4{
  padding:16px 20px;font-size:.9rem;font-weight:600;color:var(--white);
  display:flex;align-items:center;justify-content:space-between;
}
.domain-card h4 svg{width:14px;height:14px;color:var(--text2);transition:all .3s}
.domain-card:hover h4 svg{transform:translate(3px,-3px);color:var(--white)}

/* ===== CONTACT ===== */
.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:clamp(48px,8vw,120px);margin-top:80px;align-items:start}
.contact-left h3{font-size:clamp(1.5rem,3.5vw,2.5rem);color:var(--white);margin-bottom:20px;line-height:1.15}
.contact-left p{color:var(--text2);line-height:1.85;margin-bottom:40px}
.contact-item{
  display:flex;align-items:center;gap:20px;
  padding:20px 24px;border:1px solid var(--border);border-radius:14px;
  margin-bottom:12px;transition:all .4s cubic-bezier(.22,1,.36,1);
}
.contact-item:hover{border-color:var(--border-h);background:var(--bg2);transform:translateX(8px)}
.contact-item-icon{
  width:44px;height:44px;border-radius:12px;background:var(--surface);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.contact-item-icon svg{width:18px;height:18px;color:var(--text2)}
.contact-item-text{font-size:.9rem;color:var(--text)}
.contact-item-label{font-size:.6rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text2);margin-bottom:2px}
.contact-form{
  padding:clamp(32px,4vw,56px);border:1px solid var(--border);
  border-radius:20px;background:var(--bg2);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{margin-bottom:20px}
.field label{display:block;font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--text2);margin-bottom:8px}
.field input,.field textarea{
  width:100%;padding:16px 20px;background:var(--bg);
  border:1px solid var(--border);border-radius:12px;
  color:var(--white);font-family:inherit;font-size:.9rem;
  transition:border-color .3s;outline:none;
}
.field input::placeholder,.field textarea::placeholder{color:#444}
.field input:focus,.field textarea:focus{border-color:rgba(255,255,255,.2)}
.field textarea{resize:vertical;min-height:140px}
.form-btn{
  width:100%;padding:18px;background:var(--white);color:var(--bg);
  border:none;border-radius:99px;font-size:.75rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  transition:all .4s cubic-bezier(.22,1,.36,1);position:relative;overflow:hidden;
}
.form-btn:hover{letter-spacing:.12em}

/* ===== MAGNETIC BUTTON ===== */
.btn-magnetic{
  display:inline-flex;align-items:center;gap:12px;position:relative;
  padding:20px 44px;border-radius:99px;
  font-size:.75rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  transition:letter-spacing .4s;overflow:hidden;
}
.btn-magnetic.fill{background:var(--white);color:var(--bg)}
.btn-magnetic.outline{border:1px solid var(--border-h);color:var(--white)}
.btn-magnetic:hover{letter-spacing:.12em}
.btn-magnetic .btn-text{position:relative;z-index:1;display:flex;align-items:center;gap:10px}
.btn-magnetic svg,.btn-magnetic .btn-text svg{width:14px;height:14px;flex-shrink:0;transition:transform .3s}
.btn-magnetic:hover svg{transform:translateX(4px)}
.btn-magnetic .btn-bg{
  position:absolute;inset:0;border-radius:99px;
  transform:scale(0);opacity:0;transition:all .5s cubic-bezier(.22,1,.36,1);
}
.btn-magnetic.fill .btn-bg{background:var(--text)}
.btn-magnetic.outline .btn-bg{background:rgba(255,255,255,.06)}
.btn-magnetic:hover .btn-bg{transform:scale(1);opacity:1}

/* ===== PAGE HERO ===== */
.page-hero{padding:clamp(160px,22vw,260px) 0 clamp(60px,8vw,100px)}
.page-hero h1{margin-bottom:20px}

/* ===== TECH GRID ===== */
.tech-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--border);border-radius:var(--radius);overflow:hidden;margin-top:64px;
}
.tech-item{
  background:var(--bg2);padding:28px 32px;font-size:.8rem;
  font-weight:500;color:var(--text2);text-align:center;
  transition:all .4s cubic-bezier(.22,1,.36,1);
}
.tech-item:hover{background:var(--bg3);color:var(--white)}

/* ===== SCROLL PROGRESS ===== */
.scroll-progress{
  position:fixed;top:0;left:0;height:2px;background:var(--white);display:none;
  z-index:101;transform-origin:left;transform:scaleX(0);will-change:transform;
}

/* ===== FOOTER ===== */
footer{padding:80px 0 32px}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;
  padding-bottom:64px;margin-bottom:32px;
}
.footer-brand p{color:var(--text2);font-size:.85rem;margin-top:16px;max-width:280px;line-height:1.75}
.footer-col h5{font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.15em;color:var(--text2);margin-bottom:20px}
.footer-col a{display:block;font-size:.85rem;color:var(--text2);margin-bottom:12px;transition:color .3s}
.footer-col a:hover{color:var(--white)}
.footer-bottom{display:flex;justify-content:space-between;font-size:.7rem;color:var(--text2)}
.footer-cta{text-align:center;padding:clamp(80px,12vw,160px) 0 0}
.footer-cta h2{margin-bottom:32px}
.footer-cta .lead{margin:0 auto 40px}

/* ===== NOISE ===== */
body::after{
  content:'';position:fixed;inset:0;z-index:9997;pointer-events:none;opacity:.02;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.7' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-repeat:repeat;background-size:256px;
}

/* ===== REVEAL ===== */
.reveal{opacity:0;transform:translateY(60px);transition:none}
.reveal.visible{opacity:1;transform:none;transition:all 1s cubic-bezier(.22,1,.36,1)}
.reveal-delay-1{transition-delay:.12s!important}
.reveal-delay-2{transition-delay:.24s!important}
.reveal-delay-3{transition-delay:.36s!important}
.reveal-delay-4{transition-delay:.48s!important}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .portfolio-grid{grid-template-columns:repeat(2,1fr)}
  .project-card.featured{grid-column:span 2}
  .domains-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:2fr 1fr 1fr}
  .tech-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:768px){
  .nav-links{
    position:fixed;inset:0;background:rgba(14,14,14,.98);
    flex-direction:column;justify-content:center;align-items:center;
    gap:32px;opacity:0;pointer-events:none;
    transition:opacity .4s;z-index:99;
  }
  .nav-links.open{opacity:1;pointer-events:auto}
  .nav-links a{font-size:1.5rem;letter-spacing:.02em;text-transform:none;opacity:1!important;color:#fff!important}
  .burger{display:block;z-index:100}
  .hero-bottom{flex-direction:column;gap:40px;align-items:flex-start}
  .hero-meta{flex-wrap:wrap}
  .services-grid{grid-template-columns:1fr}
  .portfolio-grid{grid-template-columns:1fr}
  .project-card.featured{grid-column:span 1}
  .about-layout,.contact-layout{grid-template-columns:1fr}
  .about-text{position:static}
  .domains-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .form-row{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center}
  .tech-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:480px){.domains-grid,.tech-grid{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr}}
