/* ─── RESET & BASE ─────────────────────────────────────────── */
:root {
  --bg:        #08080e;
  --surface:   #0f0f18;
  --surface-2: #14141f;
  --border:    rgba(255,255,255,0.09);
  --border-h:  rgba(255,255,255,0.18);
  --text:      #f2f2f8;
  --muted:     #8a8aa3;
  --accent:    #6c5ce7;
  --accent-2:  #00cec9;
  --accent-g:  linear-gradient(135deg,#6c5ce7,#a29bfe 60%,#00cec9);
  --radius-lg: 20px;
  --radius-md: 14px;
  --radius-sm: 8px;
  --shadow-sm: 0 4px 18px rgba(0,0,0,0.32);
  --shadow-md: 0 12px 42px rgba(0,0,0,0.48);
  --shadow-lg: 0 28px 70px rgba(0,0,0,0.55);
  --container: min(1140px,92vw);
  --gap:       1.25rem;
}

*,*::before,*::after{box-sizing:border-box;}

html{scroll-behavior:smooth;}

body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:'Inter',sans-serif;
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
p{margin:0;}

/* ─── TYPOGRAPHY ─────────────────────────────────────────── */
h1,h2,h3,h4{
  margin:0;
  font-family:'Sora',sans-serif;
  line-height:1.12;
  letter-spacing:-0.02em;
}

h1{font-size:clamp(2.4rem,5.6vw,4.6rem);}
h2{font-size:clamp(1.9rem,3.8vw,3rem);}
h3{font-size:clamp(1.05rem,1.4vw,1.2rem);}

.eyebrow{
  display:inline-block;
  font-size:.72rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:var(--accent-2);
  margin-bottom:.85rem;
}

.section-lead{
  color:var(--muted);
  font-size:clamp(.98rem,1.3vw,1.1rem);
  max-width:58ch;
  margin-top:.75rem;
}

.body-text{
  color:var(--muted);
  margin-top:1rem;
}

/* ─── LAYOUT HELPERS ─────────────────────────────────────── */
.container{width:var(--container);margin:0 auto;}
.section{padding:clamp(4.5rem,7vw,8rem) 0;}
.section-alt{background:var(--surface);}
.section-head{max-width:640px;margin-bottom:3rem;}

/* ─── ACCESSIBILITY ─────────────────────────────────────── */
.skip-link{
  position:absolute;left:-9999px;top:auto;
  background:#fff;color:#000;padding:.7rem 1rem;border-radius:8px;
  &:focus{left:1rem;top:1rem;z-index:999;}
}

/* ─── REVEAL ANIMATION ───────────────────────────────────── */
.reveal{
  opacity:0;
  transform:translateY(22px);
  transition:opacity .6s ease,transform .6s ease;
}
.reveal.show{opacity:1;transform:translateY(0);}
.delay-1{transition-delay:.12s;}
.delay-2{transition-delay:.24s;}

/* ─── HEADER ────────────────────────────────────────────── */
.header{
  position:sticky;top:0;z-index:90;
  backdrop-filter:blur(16px);
  background:rgba(8,8,14,.82);
  border-bottom:1px solid var(--border);
  transition:box-shadow .3s ease;
}

.header.scrolled{box-shadow:0 4px 32px rgba(0,0,0,.45);}

.nav-wrap{
  display:flex;align-items:center;justify-content:space-between;
  min-height:72px;gap:1rem;
}

.logo{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:'Sora',sans-serif;font-weight:700;font-size:1.05rem;
  letter-spacing:-.01em;
}

.logo-mark{width:1.7rem;height:1.7rem;flex-shrink:0;}

.nav{
  display:flex;align-items:center;gap:1.5rem;
}

.nav a{
  color:var(--muted);font-size:.93rem;font-weight:600;
  transition:color .22s ease;
}
.nav a:hover,.nav a:focus-visible{color:var(--text);}

.nav-cta{
  color:#fff !important;
  background:var(--accent);
  border-radius:999px;
  padding:.52rem 1.05rem;
  font-size:.88rem;
  transition:filter .22s ease,transform .22s ease !important;
}
.nav-cta:hover{filter:brightness(1.12);transform:translateY(-1px);}

.menu-toggle{
  display:none;
  background:none;border:none;
  cursor:pointer;padding:.4rem;
  flex-direction:column;gap:.38rem;
}
.menu-toggle span{
  display:block;width:1.5rem;height:2px;
  background:var(--text);border-radius:2px;
  transition:transform .3s ease,opacity .3s ease;
}

/* ─── BUTTONS ────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.45rem;
  border-radius:999px;
  font-weight:700;font-size:.94rem;
  padding:.8rem 1.5rem;
  border:none;cursor:pointer;
  background:var(--accent-g);
  color:#fff;
  box-shadow:0 8px 28px rgba(108,92,231,.4);
  transition:transform .22s ease,box-shadow .22s ease,filter .22s ease;
  text-decoration:none;
}
.btn:hover,.btn:focus-visible{
  transform:translateY(-2px) scale(1.02);
  box-shadow:0 14px 36px rgba(108,92,231,.55);
  filter:brightness(1.06);
}

.btn-outline{
  background:transparent;
  border:1.5px solid var(--border-h);
  color:var(--text);
  box-shadow:none;
}
.btn-outline:hover,.btn-outline:focus-visible{
  border-color:rgba(108,92,231,.7);
  background:rgba(108,92,231,.08);
  box-shadow:none;
}

.btn-sm{
  padding:.52rem 1rem;font-size:.82rem;
}

/* ─── HERO ───────────────────────────────────────────────── */
.hero{padding:clamp(5rem,8vw,9rem) 0 0;}

.hero-inner{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:clamp(2rem,5vw,4.5rem);
  align-items:center;
}

.badge{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.78rem;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--accent-2);
  background:rgba(0,206,201,.09);
  border:1px solid rgba(0,206,201,.22);
  border-radius:999px;
  padding:.36rem .82rem;
  margin-bottom:1.25rem;
}

.hero-text h1{
  margin-bottom:1.15rem;
  background:linear-gradient(135deg,#fff 40%,#b2b2cf);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

.hero-lead{
  color:var(--muted);
  font-size:clamp(1rem,1.4vw,1.12rem);
  max-width:52ch;
  margin-bottom:1.8rem;
}

.hero-actions{
  display:flex;flex-wrap:wrap;gap:.85rem;
  margin-bottom:2rem;
}

.trust-row{
  display:flex;flex-wrap:wrap;gap:1.1rem;
  list-style:none;margin:0;padding:0;
}
.trust-row li{
  display:inline-flex;align-items:center;gap:.45rem;
  font-size:.84rem;color:var(--muted);
}

/* browser mockup */
.hero-visual{position:relative;}

.browser-mock{
  border-radius:var(--radius-lg);
  overflow:hidden;
  border:1px solid var(--border);
  box-shadow:var(--shadow-lg);
  background:var(--surface);
}

.browser-bar{
  display:flex;align-items:center;gap:.45rem;
  padding:.7rem 1rem;
  background:var(--surface-2);
  border-bottom:1px solid var(--border);
}

.dot{
  width:.6rem;height:.6rem;border-radius:50%;
}
.dot-r{background:#ff5f57;}
.dot-y{background:#febc2e;}
.dot-g{background:#28c840;}

.browser-url{
  margin-left:.4rem;
  font-size:.7rem;color:var(--muted);
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);
  border-radius:999px;
  padding:.18rem .7rem;flex:1;
}

.browser-body{padding:1rem;display:grid;gap:.8rem;}

.mock-hero-strip{
  height:76px;border-radius:10px;
  background:linear-gradient(135deg,rgba(108,92,231,.55),rgba(0,206,201,.35));
}

.mock-row{display:flex;gap:.55rem;}

.mock-card{
  height:50px;border-radius:8px;flex:1;
  border:1px solid var(--border);
  background:rgba(255,255,255,.03);
}
.mc-a{background:linear-gradient(135deg,rgba(108,92,231,.28),rgba(162,155,254,.1));}
.mc-b{background:rgba(255,255,255,.04);}
.mc-c{background:rgba(255,255,255,.02);}

.mt-sm{margin-top:.2rem;}
.mock-bar{
  height:8px;border-radius:99px;
  background:rgba(255,255,255,.1);
}
.w-60{flex:0 0 60%;}
.w-40{flex:0 0 35%;}

.mock-img{
  height:90px;border-radius:10px;
  background:linear-gradient(160deg,rgba(0,206,201,.2),rgba(108,92,231,.15));
  border:1px solid var(--border);
}

.hero-glow{
  position:absolute;
  top:-20%;left:-10%;
  width:70%;height:70%;
  background:radial-gradient(circle,rgba(108,92,231,.22),transparent 65%);
  filter:blur(50px);
  pointer-events:none;
  z-index:-1;
}

/* stats strip */
.stats-strip{
  margin-top:clamp(3rem,5vw,5rem);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:1.8rem 0;
}

.stats-inner{
  display:flex;align-items:center;justify-content:center;
  flex-wrap:wrap;gap:1rem;
}

.stat-item{
  text-align:center;min-width:120px;
}
.stat-item strong{
  display:block;
  font-family:'Sora',sans-serif;
  font-size:clamp(1.8rem,3vw,2.4rem);
  font-weight:800;
  background:var(--accent-g);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  line-height:1;
}
.stat-item span{
  font-weight:700;
  background:var(--accent-g);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  font-size:1.4rem;
}
.stat-item small{
  display:block;
  font-size:.76rem;
  color:var(--muted);
  margin-top:.3rem;
}
.stat-sep{
  width:1px;height:2rem;
  background:var(--border);
}

/* ─── SERVICES ───────────────────────────────────────────── */
.services-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:var(--gap);
}

.service-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  padding:1.4rem;
  transition:border-color .25s ease,transform .25s ease,box-shadow .25s ease;
}
.service-card:hover{
  border-color:rgba(108,92,231,.5);
  transform:translateY(-4px);
  box-shadow:0 18px 44px rgba(0,0,0,.42);
}

.sc-icon{
  width:2.4rem;height:2.4rem;
  display:grid;place-items:center;
  border-radius:var(--radius-sm);
  background:rgba(108,92,231,.18);
  color:#a29bfe;
  margin-bottom:.9rem;
}

.service-card h3{margin-bottom:.5rem;}

.service-card p{
  color:var(--muted);
  font-size:.93rem;
  margin-top:.4rem;
}

.sc-tags{
  display:flex;flex-wrap:wrap;gap:.4rem;
  list-style:none;margin:.9rem 0 0;padding:0;
}
.sc-tags li{
  font-size:.72rem;font-weight:600;
  border:1px solid var(--border);
  border-radius:999px;
  padding:.2rem .55rem;
  color:#c2c2d8;
}

/* ─── PROCESS ────────────────────────────────────────────── */
.process-list{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:var(--gap);
  list-style:none;
  margin:0;padding:0;
  counter-reset:none;
}

.process-step{
  background:var(--surface-2);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  padding:1.4rem;
  position:relative;
}

.ps-num{
  font-family:'Sora',sans-serif;
  font-size:1.9rem;font-weight:800;
  background:var(--accent-g);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  line-height:1;
  margin-bottom:.7rem;
}

.process-step h3{font-size:1rem;margin-bottom:.4rem;}
.process-step p{color:var(--muted);font-size:.88rem;}

/* ─── PROJECTS ───────────────────────────────────────────── */
.project-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:var(--gap);
}

.project-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  overflow:hidden;
  transition:border-color .25s ease,transform .25s ease,box-shadow .25s ease;
}
.project-card:hover{
  border-color:rgba(0,206,201,.45);
  transform:translateY(-5px);
  box-shadow:0 20px 48px rgba(0,0,0,.52);
}

.project-thumb{
  position:relative;
  height:200px;overflow:hidden;
  background:var(--surface-2);
}
.project-thumb img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s ease;
}
.project-card:hover .project-thumb img{transform:scale(1.05);}

.project-overlay{
  position:absolute;inset:0;
  background:rgba(8,8,14,.6);
  display:flex;align-items:center;justify-content:center;
  opacity:0;
  pointer-events:none;
  transition:opacity .3s ease;
}
.project-card:hover .project-overlay,
.project-card:focus-within .project-overlay{
  opacity:1;
  pointer-events:auto;
}

.project-body{padding:1.2rem;}

.project-meta{
  font-size:.72rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;
  color:var(--accent-2);
  margin-bottom:.4rem;
}

.project-body h3{margin-bottom:.45rem;}

.project-body p{
  color:var(--muted);font-size:.9rem;
  margin-top:.4rem;
}

.tech-tags{
  display:flex;flex-wrap:wrap;gap:.4rem;
  list-style:none;margin:.85rem 0 0;padding:0;
}
.tech-tags li{
  font-size:.72rem;border:1px solid var(--border);
  border-radius:999px;padding:.2rem .55rem;color:#c2c2d8;
}

/* ─── ABOUT ──────────────────────────────────────────────── */
.about-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(2rem,4vw,4rem);
  align-items:start;
}

.about-copy h2{margin-bottom:.8rem;}
.about-copy .btn{margin-top:1.8rem;}

.about-values{
  list-style:none;margin:0;padding:0;
  display:grid;gap:1.2rem;
}

.about-values li{
  display:flex;gap:1rem;align-items:flex-start;
}

.av-icon{
  width:2.2rem;height:2.2rem;
  display:grid;place-items:center;flex-shrink:0;
  border-radius:var(--radius-sm);
  background:rgba(108,92,231,.18);
  color:#a29bfe;
  margin-top:.1rem;
}

.about-values strong{
  display:block;font-size:.98rem;margin-bottom:.2rem;
}

.about-values p{
  color:var(--muted);font-size:.88rem;
}

/* ─── FAQ ────────────────────────────────────────────────── */
.faq-layout{
  display:grid;
  grid-template-columns:1fr 2fr;
  gap:clamp(2rem,5vw,5rem);
  align-items:start;
}

.accordion{display:grid;gap:.6rem;}

.accordion-item{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  overflow:clip;
  transition:border-color .22s ease;
}
.accordion-item:has(.accordion-trigger[aria-expanded="true"]){
  border-color:rgba(108,92,231,.45);
}

.accordion-trigger{
  width:100%;text-align:left;
  padding:1rem 1.1rem;border:0;
  background:transparent;
  color:var(--text);
  font-family:'Inter',sans-serif;
  font-size:.97rem;font-weight:600;
  cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;gap:.8rem;
}
.accordion-trigger::after{
  content:"↓";
  flex-shrink:0;
  font-size:.85rem;
  color:var(--muted);
  transition:transform .3s ease,color .3s ease;
}
.accordion-trigger[aria-expanded="true"]::after{
  transform:rotate(180deg);
  color:var(--accent-2);
}

.accordion-panel{
  max-height:0;overflow:hidden;
  transition:max-height .3s ease;
}
.accordion-panel p{
  margin:0;
  padding:.1rem 1.1rem 1rem;
  color:var(--muted);font-size:.9rem;
}

/* ─── CONTACT ────────────────────────────────────────────── */
.contact-layout{
  display:grid;
  grid-template-columns:1fr 1.3fr;
  gap:clamp(2rem,4vw,4rem);
  align-items:start;
}

.contact-copy h2{margin-bottom:.75rem;}

.contact-direct{
  list-style:none;margin:1.6rem 0 0;padding:0;
  display:grid;gap:.9rem;
}
.contact-direct li{
  display:flex;gap:.6rem;align-items:baseline;
}
.cd-label{
  font-size:.76rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.1em;color:var(--accent-2);
  min-width:68px;flex-shrink:0;
}
.contact-direct a{color:var(--text);font-weight:500;}
.contact-direct a:hover{color:var(--accent-2);}

.contact-form{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:1.8rem;
  display:grid;gap:.85rem;
  box-shadow:var(--shadow-md);
}

.contact-form h3{
  font-size:1.15rem;margin-bottom:.2rem;
}

.form-row{
  display:grid;grid-template-columns:1fr 1fr;gap:.85rem;
}

.form-field{display:grid;gap:.38rem;}

.form-field label{
  font-size:.82rem;font-weight:600;color:#c4c4d4;
}

.form-field input,
.form-field textarea{
  background:rgba(255,255,255,.03);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  color:var(--text);
  font:inherit;font-size:.93rem;
  padding:.72rem .85rem;
  transition:border-color .22s ease,box-shadow .22s ease;
  width:100%;
}
.form-field input:focus,
.form-field textarea:focus{
  outline:none;
  border-color:rgba(108,92,231,.6);
  box-shadow:0 0 0 3px rgba(108,92,231,.14);
}
.form-field textarea{resize:vertical;min-height:110px;}

.contact-form .btn{width:100%;}

.form-status{
  min-height:1.4rem;
  font-size:.88rem;font-weight:600;
  color:#80f2ef;
  margin:0;
}

/* contact CTA boxes */
.contact-cta-box{
  display:grid;gap:1rem;
}

.contact-cta-link{
  display:flex;align-items:center;gap:1rem;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  padding:1.2rem 1.4rem;
  transition:border-color .22s ease,transform .22s ease,box-shadow .22s ease;
}
.contact-cta-link:hover{
  border-color:rgba(108,92,231,.55);
  transform:translateY(-3px);
  box-shadow:0 12px 36px rgba(0,0,0,.4);
}

.cta-icon{
  width:2.4rem;height:2.4rem;flex-shrink:0;
  display:grid;place-items:center;
  border-radius:var(--radius-sm);
  background:rgba(108,92,231,.18);
  color:#a29bfe;
}

.cta-label{
  display:block;
  font-size:.75rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;
  color:var(--muted);
  margin-bottom:.2rem;
}

.cta-value{
  display:block;
  font-size:1rem;font-weight:600;
  color:var(--text);
}

/* ─── FOOTER ─────────────────────────────────────────────── */
.footer{
  border-top:1px solid var(--border);
  padding:1.8rem 0;
  background:var(--surface);
}

.footer-inner{
  display:flex;flex-wrap:wrap;align-items:center;
  gap:1rem;justify-content:space-between;
}

.footer-copy{
  font-size:.82rem;color:var(--muted);
}

.footer-nav{display:flex;gap:1.2rem;}
.footer-nav a{
  font-size:.82rem;color:var(--muted);
  transition:color .2s ease;
}
.footer-nav a:hover{color:var(--text);}

/* ─── LEGAL PAGES ────────────────────────────────────────── */
.legal-shell{min-height:calc(100vh - 180px);}
.legal-layout{display:grid;gap:1.5rem;max-width:760px;}
.legal-card{
  padding:1.6rem;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  box-shadow:var(--shadow-sm);
}
.legal-card h2{font-size:1.3rem;margin-bottom:1rem;}
.legal-copy p{color:#c8c8dd;margin:0 0 1rem;}
.legal-copy a{color:#a29bfe;}
.legal-copy a:hover{color:#fff;}
.nav-legal{position:static;width:auto;padding:0;border:0;box-shadow:none;background:transparent;}

/* ─── RESPONSIVE ─────────────────────────────────────────── */
@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr;}
  .hero-visual{display:none;}
  .services-grid{grid-template-columns:1fr 1fr;}
  .process-list{grid-template-columns:1fr 1fr;}
  .project-grid{grid-template-columns:1fr 1fr;}
  .about-grid{grid-template-columns:1fr;}
  .faq-layout{grid-template-columns:1fr;}
  .contact-layout{grid-template-columns:1fr;}
  .stats-inner{gap:1.5rem;}
  .stat-sep{display:none;}
  .footer-inner{flex-direction:column;text-align:center;}
  .footer-nav{justify-content:center;}
  .nav-wrap{flex-wrap:wrap;align-items:center;}

  .menu-toggle{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:2.75rem;
    height:2.75rem;
    border:1px solid var(--border);
    border-radius:999px;
    margin-left:auto;
    background:rgba(255,255,255,.04);
  }
  .nav{
    display:flex;
    width:100%;
    position:static;
    flex-direction:column;align-items:flex-start;
    gap:0;
    padding:0;
    background:rgba(15,15,24,.98);
    border:1px solid var(--border);
    border-radius:18px;
    box-shadow:var(--shadow-md);
    max-height:0;
    overflow:hidden;
    transform:translateY(-8px);
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transition:max-height .28s ease, opacity .22s ease, transform .22s ease, padding .22s ease;
    z-index:88;
  }
  .nav.open{
    max-height:360px;
    opacity:1;
    visibility:visible;
    pointer-events:auto;
    transform:translateY(0);
    padding:1rem;
  }
  .nav a{
    width:100%;padding:.9rem 0;
    border-bottom:1px solid var(--border);
    font-size:1.05rem;
  }
  .nav-cta{border-bottom:none !important;}

  .project-grid{grid-template-columns:1fr;}
  .project-overlay{
    opacity:1;
    pointer-events:auto;
  }
}

@media(max-width:600px){
  .services-grid{grid-template-columns:1fr;}
  .process-list{grid-template-columns:1fr;}
  .project-grid{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  .hero-actions{flex-direction:column;}
  .hero-actions .btn{text-align:center;justify-content:center;}
}
