:root{
  --brand:#570E82;
  --brand-2:#7f1fb6;
  --pink:#C50076;
  --ink:#0b0d0f;
  --muted:#555e67;
  --bg:#f7f8fb;
  --ring:rgba(87,14,130,.18);
  --shadow:0 10px 30px rgba(0,0,0,.10);
}
*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Outfit",system-ui,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--ink);
  line-height:1.6;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(87,14,130,.06), transparent 60%),
    radial-gradient(1000px 500px at -10% 10%, rgba(127,31,182,.06), transparent 60%),
    linear-gradient(180deg, #ffffff 0%, var(--bg) 100%);
}
.container{width:min(1160px,92%);margin-inline:auto}
h1,h2,h3{line-height:1.15;margin:0 0 10px}
.lead{color:var(--muted);max-width:760px;margin:0 auto 22px}
a{color:var(--brand);text-decoration:none}

/* Header / Nav */
.site-header{position:sticky;top:0;z-index:40;background:#570E82;border-bottom:1px solid rgba(0,0,0,.2)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.site-logo{height:64px;width:auto;display:block} /* bigger logo */
.menu{display:flex;gap:20px}
.menu a{color:#fff;font-weight:600;font-size:1rem;padding:10px 14px;border-radius:8px;transition:background .2s}
.menu a:hover,.menu a.active{background:rgba(255,255,255,.2);color:#fff}
.menu a::after{content:"";position:absolute;left:12px;right:12px;bottom:6px;height:2px;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .2s ease;opacity:.8}
.menu a:hover::after,.menu a.active::after{transform:scaleX(1)}
.burger{display:none;background:none;border:0;cursor:pointer;padding:8px;border-radius:12px}
.burger span{display:block;width:26px;height:2px;background:#fff;margin:5px 0}
.menu a.connect-btn{background:var(--pink);color:#fff;font-weight:700;border-radius:999px;padding:10px 20px;box-shadow:0 4px 12px rgba(197,0,118,.4);text-transform:uppercase}
.menu a.connect-btn:hover{background:#a00060;box-shadow:0 6px 16px rgba(197,0,118,.6)}
@media (max-width:860px){
  body.noscroll{overflow:hidden}
  .burger{display:block}
  .menu{position:fixed;inset:64px 0 auto 0;background:#fff;border-top:1px solid rgba(0,0,0,.06);display:none;flex-direction:column;padding:12px;gap:8px;box-shadow:var(--shadow)}
  .menu.open{display:flex}
  .menu a{color:#222}
  .menu a.connect-btn{color:#fff}
}

/* Buttons */
.btn{display:inline-block;padding:12px 18px;border-radius:14px;font-weight:700;border:1px solid rgba(0,0,0,.08);transition:.2s;position:relative;overflow:hidden}
.btn--brand{background:linear-gradient(90deg,var(--brand),var(--brand-2));color:#fff;border-color:transparent;box-shadow:0 6px 18px rgba(87,14,130,.28)}
.btn--light{background:#fff;color:var(--ink);border-color:rgba(0,0,0,.08)}
.btn--light:hover{box-shadow:var(--shadow)}
/* Ripple ink */
.btn .ink{position:absolute;width:12px;height:12px;border-radius:50%;background:rgba(255,255,255,.6);transform:scale(0);pointer-events:none;animation:ripple .6s linear;mix-blend-mode:screen}
@keyframes ripple{to{transform:scale(14);opacity:0}}

/* HERO */
.hero{position:relative;padding:80px 0 100px;overflow:hidden}
.hero--image{isolation:isolate;color:#fff;text-align:center}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;display:block;transition:transform .2s ease-out}
.hero--image::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(87,14,130,.85) 0%, rgba(87,14,130,.65) 40%, rgba(87,14,130,.3) 80%, rgba(87,14,130,0) 100%);z-index:-1}
.hero h1{font-size:clamp(36px,6vw,64px);margin:0 0 10px;font-weight:700}
.hero__shine{position:absolute;inset:auto -20% -140px -20%;height:280px;background:radial-gradient(60% 180% at 50% 10%, rgba(87,14,130,.18), rgba(127,31,182,.14) 60%, transparent 70%);filter:blur(30px);z-index:0}
.hero-logo{max-width:380px;width:100%;height:auto;margin:0 auto 20px;display:block} /* bigger hero logo */
.hero .lead{color:#f3e9f8}

/* Services */
.services{padding:80px 0 100px} /* longer page */
.service-layout{display:grid;grid-template-columns:1.1fr 1fr;gap:22px;align-items:start}
@media (max-width:920px){.service-layout{grid-template-columns:1fr;gap:14px}}
.service-visual{position:relative;border-radius:18px;overflow:hidden;border:1px solid rgba(0,0,0,.08);background:#fff;box-shadow:var(--shadow)}
.service-visual img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:4/3;transition:transform .45s ease}
.service-visual:hover img{transform:scale(1.03)}
.tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}
.tab{background:#fff;border:1px solid rgba(0,0,0,.1);color:var(--ink);padding:10px 14px;border-radius:999px;cursor:pointer;box-shadow:0 4px 12px rgba(0,0,0,.06);transition:transform .15s ease, box-shadow .2s ease}
.tab:hover{transform:translateY(-2px)}
.tab.active{background:linear-gradient(90deg,var(--brand),var(--brand-2));color:#fff;border-color:transparent;font-weight:800;box-shadow:0 8px 24px rgba(87,14,130,.28)}
.tab-content{background:#fff;border:1px solid rgba(0,0,0,.1);border-radius:16px;padding:18px;box-shadow:0 6px 18px rgba(0,0,0,.08)}
.bullets{margin:10px 0 0 16px}

/* Clients slider */
.clients{padding:80px 0 100px;background:linear-gradient(180deg, transparent, #fff);position:relative;z-index:1}
.slider{position:relative;overflow:hidden;border:1px solid rgba(0,0,0,.06);border-radius:16px;background:#fff;box-shadow:var(--shadow)}
.slider__track{display:flex;gap:30px;animation:scroll 30s linear infinite;will-change:transform;pointer-events:none}
.slide{min-width:20%;padding:16px;display:flex;align-items:center;justify-content:center}
.slide img{max-width:100%;max-height:74px;object-fit:contain;filter:none}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(max-width:900px){.slide{min-width:33.33%}.slider__track{gap:18px;animation-duration:36s}}
@media(max-width:640px){.slide{min-width:50%}.slider__track{animation-duration:42s}}

/* Connect */
#connect{scroll-margin-top:96px}
.contact{padding:100px 0 120px;position:relative;z-index:2}
.form{display:grid;gap:14px;max-width:820px}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:640px){.form__row{grid-template-columns:1fr}}
input,textarea,select{width:100%;background:#fff;color:var(--ink);border:1px solid rgba(0,0,0,.12);border-radius:12px;padding:12px 14px;box-shadow:0 2px 8px rgba(0,0,0,.04)}
input:focus,textarea:focus,select:focus{outline:2px solid var(--ring);border-color:var(--brand)}

/* Footer */
.site-footer{border-top:1px solid rgba(0,0,0,.06);background:#fff}
.footer__inner{display:flex;align-items:center;justify-content:space-between;padding:18px 0}
.footer__nav a{color:var(--muted);margin-left:14px}
.footer__nav a.connect-btn{background:var(--pink);color:#fff;font-weight:700;border-radius:999px;padding:8px 16px}
.footer__nav a.connect-btn:hover{background:#a00060}

/* About page extras */
.about-intro{padding:28px 0 10px}
.about-hero-card{background:radial-gradient(80% 100% at 100% 0, rgba(87,14,130,.08), transparent),#fff;border:1px solid rgba(0,0,0,.06);border-radius:20px;padding:24px;box-shadow:var(--shadow);text-align:center}
.pill{display:inline-block;padding:8px 12px;border-radius:999px;font-weight:700;font-size:.85rem;background:#fff;border:1px solid rgba(0,0,0,.08)}
.pill-brand{background:linear-gradient(90deg,var(--brand),var(--brand-2));color:#fff;border-color:transparent}
.about-title{font-size:clamp(24px,4.6vw,40px);margin:10px 0 6px}
.about-sub{color:var(--muted);margin:0 auto 14px;max-width:800px}
.about-stats{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:6px}
.stat{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:14px;padding:10px 14px;box-shadow:0 6px 16px rgba(0,0,0,.06)}
.stat strong{font-size:20px;display:block;line-height:1}.stat span{color:var(--muted);font-size:.9rem}
.about-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;padding:10px 0 26px}
@media (max-width:900px){.about-grid{grid-template-columns:1fr}}
.feature-card{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:18px;padding:20px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.feature-card::after{content:"";position:absolute;inset:auto -20% -120px -20%;height:220px;background:radial-gradient(60% 180% at 50% 0, rgba(87,14,130,.10), rgba(127,31,182,.08) 60%, transparent 70%);filter:blur(30px);z-index:0}
.feature-icon{width:40px;height:40px;display:grid;place-items:center;color:var(--brand);background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:12px;box-shadow:0 6px 16px rgba(0,0,0,.06);margin-bottom:8px;z-index:1;position:relative}
.feature-card h3{margin:0 0 8px;position:relative;z-index:1}
.feature-card p{margin:0 0 10px;color:var(--muted);position:relative;z-index:1}
.ticks{margin:0;padding-left:1.2rem;position:relative;z-index:1}
.ticks li{margin:6px 0}

/* Fun highlight when arriving at services */
#services.arrived{position:relative;border-radius:18px;box-shadow:0 0 0 4px rgba(197,0,118,.35);animation:services-pulse 1.6s ease-out 2}
@keyframes services-pulse{0%{box-shadow:0 0 0 0 rgba(197,0,118,.35)}100%{box-shadow:0 0 0 28px rgba(197,0,118,0)}}

/* Confetti */
.confetti{position:fixed;top:-10px;width:8px;height:12px;opacity:.95;animation:fall 1.4s linear forwards;border-radius:2px;z-index:9999;will-change:transform,opacity}
@keyframes fall{to{transform:translateY(110vh) rotate(300deg);opacity:.9}}

/* Mobile tweaks */
:root{ --space: 18px; }
@media (max-width: 900px){
  .container{ width: min(1100px, 94%); }
  h1{ font-size: clamp(28px, 6.2vw, 42px); }
  h2{ font-size: clamp(22px, 4.8vw, 32px); }
  .lead{ margin-bottom: 18px; }
  .hero{ padding: 56px 0 74px; }
  .cta-row{ display:flex; gap:10px; justify-content:center; flex-wrap: wrap; }
  .btn{ padding: 12px 16px; }
}
@media (max-width: 780px){
  .footer__inner{ flex-direction: column; align-items: flex-start; gap: 10px; }
  .footer__nav{ display:flex; flex-wrap: wrap; gap: 8px; }
  .footer__nav a{ margin-left: 0; }
}
