/* Welsch Marketing — brand-first, responsive styles (UNDIVIDED NAV) */
:root{
  --bg:#000000;--surface:#0c1016;--text:#e6edf7;--muted:#9aa6b2;
  --brand-1:#ffffff;--brand-2:#e5e7eb;--brand:var(--brand-1);
  --ring:rgba(255,255,255,.45);--container:1120px;--radius:14px;--gap:1.1rem;
}

*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}

body{
  margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,
  Apple Color Emoji,Segoe UI Emoji,Noto Color Emoji,sans-serif;
  color:var(--text);background-color:var(--bg);line-height:1.6;position:relative;z-index:0;
}
body.lightbox-open,
body.embed-open{overflow:hidden}

/* 🔵 ONE SHARED BACKGROUND FOR NAV + HERO  */
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:var(--bg-image, url("assets/background.png"));
  background-size:cover;background-position:center top;background-repeat:no-repeat;
}

/* Keep anchors visible under sticky header */
.hero,.section{scroll-margin-top:120px}

/* Progress bar (off) */
.scroll-progress{display:none!important}
.scroll-progress__bar{height:100%;width:0;background:linear-gradient(90deg,#fff,#bbb);box-shadow:none}

img{display:block;max-width:100%;height:auto}
a{color:var(--text);text-decoration:none}

.container{width:min(100% - 2rem,var(--container));margin-inline:auto}
.section{padding:5rem 0}
.section-alt{background:transparent;border-top:none;border-bottom:none}

h1,h2,h3{line-height:1.15;margin:0 0 .75rem}
h1{font-size:clamp(2rem,2.5vw + 1.4rem,3.25rem);letter-spacing:-.02em}
h2{font-size:clamp(1.5rem,1.4vw + 1rem,2.25rem)}
h3{font-size:1.15rem}
.lead{color:var(--muted);font-size:1.05rem;max-width:62ch}

/* ===== Header / Nav (UNIFIED WITH HERO) ===== */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;background:transparent;border-bottom:none;padding:.5rem 0;
}
.site-header .container{width:min(100% - 4rem,var(--container))}

/* Frosted, centered pill nav */
.nav{
  position:relative;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.95rem 1.2rem;
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.2);
  box-shadow:0 15px 35px rgba(0,0,0,0.35), inset 0 1px rgba(255,255,255,0.35);
  backdrop-filter:blur(24px) saturate(165%);
  -webkit-backdrop-filter:blur(24px) saturate(165%);
  border-radius:999px;
  width:min(92%,var(--container));
  margin-inline:auto;
  transition:background .2s ease,border-color .2s ease,box-shadow .2s ease;
  overflow:visible;
}

.brand{
  display:inline-flex;
  align-items:center;
  gap:.65rem;
  font-weight:700;
  letter-spacing:.2px;
  position:relative;
  padding-left:clamp(105px,10.5vw,135px);
}
.brand-mark{
  position:absolute;
  left:0;
  top:50%;
  width:clamp(130px,11.5vw,165px);
  height:clamp(130px,11.5vw,165px);
  transform:translateY(-50%);
  object-fit:contain;
  filter:drop-shadow(0 8px 22px rgba(0,0,0,.35));
}
.brand-name{font-weight:700;font-size:1.3rem;letter-spacing:.08em}

.primary-nav{display:flex;align-items:center;gap:1rem}
.nav-menu{display:flex;align-items:center;gap:1rem;list-style:none;margin:0;padding:0}
.nav-toggle{display:none}
.nav-menu a{
  position:relative;
  color:var(--text);
  opacity:.92;
  padding:.65rem .9rem;
  overflow:hidden;
}
.nav-menu a::after{
  content:"";
  position:absolute;
  left:10%;
  right:10%;
  bottom:.45rem;
  height:2px;
  border-radius:999px;
  background:linear-gradient(120deg,#00c6ff,#9ad7ff,#fff);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .35s ease-out,opacity .35s ease-out;
  opacity:0;
}
.nav-menu a:hover::after,
.nav-menu a:focus-visible::after{
  transform:scaleX(1);
  opacity:.9;
}
.nav-menu a[href="#services"],
.nav-menu a[href="#projects"]{
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:.9rem;
}
.nav-menu a:hover{opacity:1;color:var(--text)}
.nav .btn-ghost{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12)}
.nav .btn-ghost:hover{background:#fff;color:#0b0f14;border-color:#fff}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.65rem 1rem;
  border-radius:999px;border:1px solid rgba(255,255,255,.1);
  transition:transform .08s ease,background .2s ease,border-color .2s ease;font-weight:600;
}
.btn:active{transform:translateY(1px)}
.btn-primary{
  color:#0b0f14;background:#fff;border-color:rgba(255,255,255,.12);
  box-shadow:0 6px 18px rgba(0,0,0,.28), inset 0 1px rgba(255,255,255,.6);
}
.btn-primary:hover{filter:saturate(1.1) brightness(1.05)}
.btn-ghost{color:var(--text);background:rgba(255,255,255,.04)}
.btn-ghost:hover{background:rgba(255,255,255,.08)}
.btn-white{
  color:#0b0f14;background:#fff;border-color:rgba(255,255,255,.12);
  box-shadow:0 6px 18px rgba(0,0,0,.3), inset 0 1px rgba(255,255,255,.6);
}
.btn-white:hover{background:#f2f5f8}

/* ===== Hero (transparent so it shares the same bg) ===== */
.hero{
  padding:clamp(3rem,4vw,4.75rem) 0 clamp(4.5rem,5.5vw,7rem);position:relative;overflow:visible;
  display:flex;align-items:center;justify-content:center;background:transparent;margin-top:0;min-height:calc(100vh - 80px);z-index:1;
}

.hero-inner{
  display:grid;grid-template-columns:1fr;gap:2rem;align-items:center;justify-items:center;justify-content:center;
  padding:clamp(2.9rem,4vw,4.25rem) clamp(3.2rem,5vw,4.9rem);
  margin-top:clamp(3.5rem,5vw,5.75rem);position:relative;isolation:isolate;
  width:min(1100px,95vw);height:auto;border-radius:16px;
  border:1px solid rgba(255,255,255,0.32);
  background:rgba(255,255,255,0.08);
  box-shadow:
    0 30px 60px rgba(0,0,0,0.45),
    inset 0 1px 0 rgba(255,255,255,0.55);
  backdrop-filter:blur(34px) saturate(165%);
  -webkit-backdrop-filter:blur(34px) saturate(165%);
  overflow:hidden;
  filter:blur(var(--hero-blur,0px));
  transition:transform .4s ease, opacity .4s ease, border-color .4s ease, filter .4s ease;
}

.hero-inner.hero-inner--shrink{
  transform:scale(.94) translateY(-20px);
  opacity:.9;
  border-color:rgba(255,255,255,0.18);
}

.hero-inner::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.35), rgba(255,255,255,0) 50%),
    radial-gradient(65% 85% at 50% 0%, rgba(255,255,255,0.45), transparent 70%);
  opacity:0.6;
  pointer-events:none;
}

.hero-inner::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:none;
  mix-blend-mode:normal;
  pointer-events:none;
}
.hero .container{width:min(100% - 2rem,1200px);margin-inline:auto}
.hero-content{
  max-width:900px;position:relative;isolation:isolate;margin-inline:auto;text-align:center;display:flex;flex-direction:column;align-items:center;
}

.hero-art{display:none}
.hero-ctas{display:flex;gap:.75rem;margin:1rem 0 1.25rem;justify-content:center}
.hero-ctas .btn{
  padding:0.95rem 1.9rem;
  font-size:1rem;
}
.stats{list-style:none;display:flex;gap:1.25rem;padding:0;margin:1.5rem 0 0;color:var(--muted);justify-content:center}
.stats li{display:grid;gap:.25rem}
.stats strong{font-size:1.15rem;color:var(--text)}

/* Text shading for depth */
.hero h1{
  text-shadow:0 4px 25px rgba(0,0,0,.85),0 3px 8px rgba(0,0,0,.65),0 2px 0 rgba(255,255,255,.08);
  font-size:clamp(2.4rem,4.4vw + 1rem,4.6rem);letter-spacing:-.02em;font-weight:700;color:#f5f7fb;margin:.25rem 0!important;
}
.hero .lead{
  margin:.25rem 0 .4rem!important;
  text-shadow:0 1px 6px rgba(0,0,0,.55);
  font-size:1.2rem;
  line-height:1.9;
}
.hero .btn{text-shadow:0 1px 2px rgba(0,0,0,.6)}
.accent-italic{font-family:"Playfair Display",Georgia,serif;font-style:italic;font-weight:700}

/* Proof row / CTA */
.proof{display:inline-flex;align-items:center;gap:.5rem;color:#bfc7d5;margin-bottom:.75rem}
.stars{color:#ffd166;letter-spacing:.15em;font-size:.9rem}
.proof-text{font-size:.9rem}
.btn-red{background:linear-gradient(135deg,#00c6ff,#0072ff);color:#fff;border-color:transparent;box-shadow:0 8px 18px rgba(0,171,255,.35), inset 0 1px rgba(255,255,255,.3)}
.btn-red:hover{filter:brightness(1.06) saturate(1.08)}
.btn-dark{background:rgba(255,255,255,.08);color:#f5f7fb;border-color:rgba(255,255,255,.16)}
.btn-dark:hover{background:rgba(255,255,255,.14)}

@media (prefers-reduced-motion:reduce){
  .hero-inner{filter:none!important}
}

/* ===== Cards / Grids ===== */
.grid{display:grid;gap:calc(var(--gap)*1.2)}
.cards{
  display:flex;
  flex-wrap:wrap;
  gap:calc(var(--gap)*1.4);
  justify-content:center;
  width:100%;
}
.card{
  flex:1 1 260px;
  max-width:340px;
  background:none;
  border:none;
  border-radius:var(--radius);
  padding:1.25rem;
  text-align:center;
  margin:0 auto;
}
.card .service-icon{
  transition:transform .25s ease, filter .25s ease;
}
.card:hover .service-icon{
  transform:translateY(-6px) scale(1.05) rotate(-2deg);
  filter:drop-shadow(0 12px 24px rgba(0,0,0,.55));
}
.card h3{margin:.35rem 0 .5rem;font-size:1.2rem;letter-spacing:.08em;text-transform:uppercase;color:#f6f8fc;text-shadow:0 6px 24px rgba(0,0,0,.55)}
.card p{color:#d4deef;margin:0;font-size:1rem;line-height:1.7;max-width:28ch;margin-inline:auto}
.service-icon{width:150px;height:150px;object-fit:contain;margin:0 auto .75rem;filter:drop-shadow(0 6px 20px rgba(0,0,0,.45))}

.section-lead{color:var(--muted);margin-top:-.25rem;margin-bottom:1.5rem}
#services h2{
  text-align:center;font-size:clamp(1.9rem,2.2vw + 1rem,2.75rem);letter-spacing:-.01em;
  color:#fff;
  text-shadow:0 6px 30px rgba(0,0,0,.45);
}
#services .section-lead{text-align:center;max-width:720px;margin:0 auto 2rem;font-size:1.15rem;color:#f3f6fb}

#services .services-panel{
  --services-scale-base:.94;
  --services-shrink:0;
  --services-blur:0px;
  background:rgba(7,12,22,.75);border:1px solid rgba(255,255,255,.08);border-radius:28px;
  padding:3rem clamp(1.5rem,4vw,3rem);backdrop-filter:blur(26px) saturate(160%);-webkit-backdrop-filter:blur(26px) saturate(160%);
  box-shadow:0 25px 80px rgba(3,8,20,.65), inset 0 1px rgba(255,255,255,.15);
  position:relative;overflow:hidden;z-index:0;
  transform:scale(calc(var(--services-scale-base) - var(--services-shrink)));
  filter:blur(var(--services-blur));
  transition:transform .7s cubic-bezier(.25,.8,.25,1), box-shadow .7s ease, filter .35s ease;
}
#services .services-panel::before{
  content:"";position:absolute;inset:12px;border-radius:inherit;border:1px solid rgba(255,255,255,.08);
  pointer-events:none;opacity:.6;z-index:-1;
}
#services .services-panel.services-panel--expanded{
  --services-scale-base:1;
  box-shadow:0 40px 110px rgba(0,0,0,.65), inset 0 1px rgba(255,255,255,.3);
}

/* ===== Elevate CTA ===== */
.section-elevate{padding:clamp(4rem,5vw,5rem) 0 clamp(3rem,4vw,4rem);background:transparent}
.elevate-inner{
  text-align:center;padding:clamp(2rem,3vw,3rem);border-radius:28px;border:1px solid rgba(255,255,255,.15);
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.02));
  box-shadow:0 20px 45px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.45);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
}
.elevate-inner .eyebrow{letter-spacing:.4em;text-transform:uppercase;font-size:.75rem;color:#c8d5ff;margin-bottom:.75rem}
.section-elevate h2{font-size:clamp(2rem,3vw + 1rem,3.25rem);letter-spacing:-.02em;margin-bottom:1rem}
.section-elevate .lead{color:#d3def2;max-width:620px;margin:0 auto 1.75rem}
.elevate-btn{box-shadow:0 14px 30px rgba(0,98,255,.35),0 6px 10px rgba(0,0,0,.35)}
.elevate-btn:hover{transform:translateY(-1px);box-shadow:0 18px 34px rgba(0,98,255,.45),0 8px 12px rgba(0,0,0,.45)}

/* ===== Projects ===== */
.projects .projects-header{
  text-align:center;
  margin:0 auto 2.5rem;
  max-width:760px;
}
.projects-header__card{
  display:inline-flex;
  flex-direction:column;
  gap:.5rem;
  padding:clamp(1rem,2vw,1.6rem) clamp(1.2rem,3vw,2rem);
  border:1px solid rgba(255,255,255,.16);
  border-radius:18px;
  background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.02));
  box-shadow:0 14px 40px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.25);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  position:relative;
  overflow:hidden;
}
.projects-header__card::after{
  content:"";
  position:absolute;
  top:0;
  left:50%;
  transform:translateX(-50%);
  width:46%;
  height:3px;
  border-radius:999px;
  background:linear-gradient(90deg,#00c6ff,#7ad8ff,#fff);
  opacity:.9;
}
.projects h2{
  font-size:clamp(1.9rem,2.2vw + 1rem,2.75rem);
  letter-spacing:-.01em;
  color:#fff;
  text-shadow:0 6px 30px rgba(0,0,0,.45);
}
.projects .section-lead{
  color:var(--muted);
  margin:0 auto;
  max-width:640px;
  font-size:1.05rem;
}
.projects-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:clamp(1.2rem,3vw,1.8rem);
  align-items:stretch;
}
.project-card{
  border:1px solid rgba(255,255,255,.1);
  border-radius:22px;
  background:linear-gradient(145deg,rgba(12,16,24,.78),rgba(12,16,24,.62));
  box-shadow:0 22px 60px rgba(0,0,0,.55), inset 0 1px rgba(255,255,255,.12);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  gap:.85rem;
  cursor:pointer;
  position:relative;
  transition:transform .18s ease, border-color .2s ease, box-shadow .2s ease;
  height:100%;
}
.project-card::before,
.project-card::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  transition:opacity .25s ease, transform .25s ease;
}
.project-card::before{
  inset:-1px;
  background:linear-gradient(130deg,rgba(0,198,255,.14),rgba(255,255,255,.02) 42%,rgba(0,0,0,0) 70%);
  opacity:0;
}
.project-card::after{
  top:-45%;
  left:-30%;
  width:65%;
  height:220%;
  background:radial-gradient(circle at center,rgba(255,255,255,.12) 0,rgba(255,255,255,0) 60%);
  transform:rotate(-8deg);
  opacity:.35;
  mix-blend-mode:screen;
}
.project-card:hover{transform:translateY(-3px);border-color:rgba(255,255,255,.16);box-shadow:0 28px 80px rgba(0,0,0,.6), inset 0 1px rgba(255,255,255,.16)}
.project-card:hover::before{opacity:1}
.project-card:hover::after{opacity:.65;transform:rotate(-2deg)}
.project-card:focus-visible{
  outline:2px solid rgba(0,198,255,.75);
  outline-offset:3px;
  box-shadow:0 30px 80px rgba(0,0,0,.7);
}
.project-media{
  position:relative;
  overflow:hidden;
  aspect-ratio:16/10;
  display:flex;
  background:rgba(255,255,255,.02);
}
.project-media img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .24s ease, filter .24s ease;
}
.project-card .project-media,
.project-card__body{position:relative;z-index:1}
.project-card:hover .project-media img{transform:scale(1.015)}
.project-card:active .project-media img{transform:scale(1.03)}
.project-media img.is-popping{transform:scale(1.05)!important;filter:drop-shadow(0 12px 28px rgba(0,0,0,.55))}
.project-card__body{
  padding:0 1.1rem 1.2rem;
  display:flex;
  flex-direction:column;
  gap:.35rem;
  flex:1;
}
.project-card__body h3{
  margin:0;
  font-size:1.05rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#fff;
}
.project-card__body p{
  margin:0;
  color:#cbd5ec;
  font-size:.95rem;
  line-height:1.5;
}
.project-card--secondary{cursor:default}
.project-card--secondary .project-media img{filter:saturate(.9)}
.project-card--secondary:hover{transform:none;border-color:rgba(255,255,255,.1);box-shadow:0 22px 60px rgba(0,0,0,.55), inset 0 1px rgba(255,255,255,.12)}
.project-pill{
  position:absolute;
  left:12px;
  bottom:12px;
  padding:.35rem .75rem;
  border-radius:999px;
  background:linear-gradient(135deg,#00c6ff,#0072ff);
  color:#fff;
  font-weight:700;
  font-size:.8rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  box-shadow:0 10px 28px rgba(0,0,0,.4);
}
.project-pill--ghost{background:rgba(255,255,255,.14);color:#fff;border:1px solid rgba(255,255,255,.25)}
.project-media::after{
  display:none;
}
.project-card[data-embed] .project-media::after{display:none}
.project-card:hover .project-media::after{display:none}
.project-card:not([data-link]) .project-media::after{display:none}


.site-embed{
  position:fixed;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:1.5rem;
  background:rgba(3,7,14,0.75);
  backdrop-filter:blur(20px) saturate(140%);
  -webkit-backdrop-filter:blur(20px) saturate(140%);
  opacity:0;
  pointer-events:none;
  transition:opacity .2s ease;
  z-index:3200;
}
.site-embed.is-open{
  opacity:1;
  pointer-events:auto;
}
.site-embed__panel{
  width:min(1200px,96vw);
  height:min(860px,90vh);
  background:#0d111a;
  border:1px solid rgba(255,255,255,.14);
  border-radius:18px;
  box-shadow:0 28px 64px rgba(0,0,0,.55), inset 0 1px rgba(255,255,255,.08);
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
.site-embed__header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:.9rem 1.1rem;
  background:rgba(255,255,255,0.03);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.site-embed__title{
  font-weight:700;
  letter-spacing:.05em;
  text-transform:uppercase;
  font-size:.9rem;
}
.site-embed__actions{
  display:flex;
  align-items:center;
  gap:.75rem;
}
.site-embed__open{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  padding:.45rem .8rem;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.25);
  background:rgba(255,255,255,0.06);
  color:#fff;
  font-weight:600;
  letter-spacing:.05em;
  font-size:.85rem;
}
.site-embed__open:hover{background:rgba(255,255,255,0.12);border-color:rgba(255,255,255,.4)}
.site-embed__close{
  width:36px;
  height:36px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.3);
  background:rgba(0,0,0,.45);
  color:#fff;
  font-weight:700;
  font-size:1.1rem;
  display:grid;
  place-items:center;
  cursor:pointer;
  transition:transform .15s ease, background .15s ease, border-color .15s ease;
}
.site-embed__close:hover{transform:translateY(-1px);background:rgba(255,255,255,0.12);border-color:rgba(255,255,255,.5)}
.site-embed__frame-wrap{
  flex:1;
  background:#060910;
}
.site-embed__frame{
  width:100%;
  height:100%;
  border:0;
  background:#0b0f17;
}
@media (max-width:768px){
  .site-embed{padding:.75rem}
  .site-embed__panel{height:min(92vh,900px);width:100%}
}

/* Toast for image expansion */
.notification-toast{
  position:fixed;
  right:1.25rem;
  bottom:1.25rem;
  display:flex;
  align-items:center;
  gap:.85rem;
  padding:.9rem 1.1rem;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(10,14,22,.9);
  box-shadow:0 18px 36px rgba(0,0,0,.55), inset 0 1px rgba(255,255,255,.12);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  opacity:0;
  transform:translateY(12px);
  pointer-events:none;
  transition:opacity .2s ease, transform .2s ease;
  z-index:3000;
}
.notification-toast.show{
  opacity:1;
  transform:translateY(0);
}
.notification-thumb{
  width:46px;
  height:46px;
  border-radius:12px;
  background:linear-gradient(135deg,#00c6ff,#0072ff);
  background-size:cover;
  background-position:center;
  border:1px solid rgba(255,255,255,.2);
  box-shadow:0 8px 18px rgba(0,0,0,.45);
}
.notification-copy{
  display:grid;
  gap:.15rem;
}
.notification-title{
  margin:0;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
  font-size:.85rem;
  color:#fff;
}
.notification-sub{
  margin:0;
  color:#c7d7ef;
  font-size:.9rem;
}

/* ===== Footer ===== */
.site-footer{
  padding:3rem 0;color:var(--muted);
  border-top:1px solid rgba(255,255,255,0.06);
  background:rgba(0,0,0,0.35);
  backdrop-filter:blur(18px);
}
.footer-inner{
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;
}
.footer-brand{display:flex;flex-direction:column;gap:.2rem}
.footer-title{margin:0;font-weight:600;color:#fff;font-size:1.1rem}
.footer-copy{margin:0;font-size:.9rem;color:var(--muted)}
.footer-links-group{
  display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;
}
.footer-links{list-style:none;display:flex;gap:1rem;margin:0;padding:0}
.footer-links a{color:var(--muted);font-weight:500;letter-spacing:.03em}
.footer-links a:hover{color:var(--text)}
.footer-social{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.5rem 1rem;border-radius:999px;
  border:1px solid rgba(255,255,255,0.25);
  color:#fff;font-weight:600;
  transition:transform .2s ease,background .2s ease;
}
.footer-social svg{
  width:20px;height:20px;fill:currentColor;
}
.footer-social:hover{
  background:rgba(255,255,255,0.12);
  transform:translateY(-2px);
}

.typeform-section{padding:4rem 0 5rem}
.typeform-card{
  background:linear-gradient(135deg,rgba(255,255,255,.06),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.16);
  border-radius:22px;
  box-shadow:0 24px 60px rgba(0,0,0,.55), inset 0 1px rgba(255,255,255,.2);
  padding:clamp(1.4rem,2vw,2rem);
  display:grid;
  gap:1rem;
}
.typeform-card h2{margin:0;font-size:clamp(1.6rem,2.4vw + .4rem,2.2rem);letter-spacing:-.01em}
.typeform-card .lead{margin:0;color:var(--muted)}
.typeform-embed{min-height:520px}
.typeform-embed [data-tf-live]{width:100%;height:100%}

/* ===== Responsive ===== */
@media (max-width:960px){
  .hero-inner{grid-template-columns:1fr}
  .hero-art{display:none!important}
  .cards{flex-direction:column;align-items:stretch}
  .hero{padding-top:4rem;padding-bottom:9rem}
  .hero .container{width:min(100% - 2rem,100%);margin-inline:auto}

  .nav-toggle{
    display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;padding:0;border-radius:999px;
    background:rgba(255,255,255,.08);color:var(--text);border:1px solid rgba(255,255,255,.18);
    box-shadow:0 12px 30px rgba(0,0,0,.38), inset 0 1px rgba(255,255,255,.4);
  }
  .hamburger{position:relative;width:20px;height:14px;display:inline-block}
  .hamburger .bar{position:absolute;left:0;right:0;height:2px;background:var(--text);border-radius:2px;transition:transform .2s ease,opacity .2s ease,top .2s ease}
  .hamburger .bar:nth-child(1){top:0}
  .hamburger .bar:nth-child(2){top:6px}
  .hamburger .bar:nth-child(3){top:12px}
  .nav-toggle[aria-expanded="true"] .bar:nth-child(1){top:6px;transform:rotate(45deg)}
  .nav-toggle[aria-expanded="true"] .bar:nth-child(2){opacity:0}
  .nav-toggle[aria-expanded="true"] .bar:nth-child(3){top:6px;transform:rotate(-45deg)}
  .nav-menu{
    position:absolute;
    right:0;
    top:calc(100% + 12px);
    min-width:240px;
    width:max(240px,45vw);
    background:linear-gradient(160deg,rgba(10,14,22,.95),rgba(14,20,30,.85));
    border:1px solid rgba(255,255,255,.2);
    border-radius:18px;
    padding:.65rem;
    flex-direction:column;
    gap:.55rem;
    box-shadow:0 30px 80px rgba(0,0,0,.6);
    backdrop-filter:blur(22px);
    -webkit-backdrop-filter:blur(22px);
    opacity:0;
    visibility:hidden;
    transform:translateY(-6px) scale(.98);
    pointer-events:none;
    transition:opacity .3s ease,transform .3s ease;
  }
  .nav-menu::before{
    content:"";
    position:absolute;
    inset:0;
    border-radius:inherit;
    background:radial-gradient(circle at top, rgba(255,255,255,.12), rgba(255,255,255,0));
    opacity:.4;
    pointer-events:none;
  }
  .nav-menu.show{
    opacity:1;
    visibility:visible;
    transform:translateY(0) scale(1);
    pointer-events:auto;
  }
  .nav-menu li a{
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:.85rem 1rem;
    border-radius:12px;
    background:rgba(255,255,255,.03);
    border:1px solid transparent;
    font-weight:600;
    letter-spacing:.04em;
    text-transform:uppercase;
    gap:.8rem;
  }
  .nav-menu li a::after{display:none}
  .nav-menu li + li a{margin-top:.35rem}
  .nav-menu li a:hover{
    background:rgba(255,255,255,.08);
    border-color:rgba(255,255,255,.12);
  }
}

@media (max-width:720px){
  #services .services-panel{padding:2rem 1.25rem}
  .cards{flex-direction:column;gap:1.25rem}
  .card{padding:1rem;max-width:100%}
  .service-icon{width:130px;height:130px}
}

@media (min-width:960px){
  .hero h1{font-size:clamp(2.6rem,3.1vw + 1.2rem,4.6rem);margin-bottom:1rem}
  .hero .lead{font-size:1.35rem;line-height:2.05;margin-bottom:1rem}
  .hero-ctas{margin-top:1.25rem}
  .stats{margin-top:2rem}

  /* robust two-column layout on desktop */
  .hero-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;width:100%}
  .hero-art{display:block!important;flex:0 0 clamp(560px,44vw,700px);margin-left:auto;transform:translateX(1in)}
  .hero-img{position:relative;z-index:1;width:100%;height:auto;display:block;filter:drop-shadow(0 20px 40px rgba(0,0,0,.5))}

  /* Ensure hero fills the top on desktop */
  .hero{padding-top:3.5rem;min-height:calc(100svh - 96px)}
}

/* Disable any old page-glow or progress elements */
.page-glow,.scroll-progress{display:none!important}

.cursor-drop{
  position:fixed;
  width:20px;
  height:20px;
  border-radius:45% 55% 60% 40%;
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,0.9), rgba(0,150,255,0.35));
  box-shadow:0 4px 18px rgba(0,150,255,0.45);
  pointer-events:none;
  mix-blend-mode:screen;
  opacity:0;
  transform:translate(-50%,-50%);
  transition:opacity .3s ease;
  z-index:2000;
}

/* Keep all sections above bg */
main,.hero,.section{position:relative;z-index:1}
