:root{
  --purple:#8423BD;
  --purple-dark:#6F1AA8;
  --purple-soft:#F2E8FA;
  --purple-tint:#C9A1E8;
  --ink:#171A24;
  --muted:#5E6472;
  --line:#E9E3F0;
  --paper:#FFFFFF;
  --charcoal:#0B1020;
  --soft:#FAFAFC;
  --shadow:0 20px 60px rgba(23,26,36,.10);
  --shadow-purple:0 12px 30px rgba(132,35,189,.18);
  --radius:20px;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Arial,sans-serif;color:var(--ink);background:var(--paper);line-height:1.55}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button,input,textarea,select{font:inherit;color:inherit}
.topbar{background:linear-gradient(90deg,var(--purple-dark),var(--purple));color:#fff;font-size:.93rem}
.topbar .wrap{max-width:var(--max);margin:auto;padding:8px 22px;display:flex;justify-content:space-between;gap:20px;align-items:center}
.header{background:#fff;position:sticky;top:0;z-index:50;box-shadow:0 10px 30px rgba(11,16,32,.06)}
.nav{max-width:var(--max);margin:auto;padding:16px 22px;display:flex;align-items:center;justify-content:space-between;gap:22px}
.brand{display:flex;align-items:center;gap:14px;min-width:305px}
.brand img{width:70px;height:70px;object-fit:contain}
.brand strong{display:block;font-size:1.8rem;line-height:1;font-weight:900;color:var(--purple);letter-spacing:.02em}
.brand span{display:block;letter-spacing:.48em;font-size:.96rem;color:var(--ink);margin-top:7px}
.links{display:flex;align-items:center;gap:24px;font-weight:800;font-size:.91rem;letter-spacing:.01em}
.links a:not(.btn){position:relative;white-space:nowrap}
.links a:not(.btn)::after{content:"";position:absolute;left:0;right:0;bottom:-9px;height:3px;border-radius:99px;background:var(--purple);transform:scaleX(0);transition:.18s}
.links a:hover::after,.links a.active::after{transform:scaleX(1)}
.btn{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:4px;background:linear-gradient(135deg,var(--purple),var(--purple-dark));color:white;font-weight:900;letter-spacing:.01em;padding:14px 22px;box-shadow:var(--shadow-purple);cursor:pointer;text-align:center}
.btn:hover{transform:translateY(-1px)}
.btn.secondary{background:#fff;color:var(--purple);border:1px solid var(--line);box-shadow:none}
.btn.dark{background:var(--ink)}
.menu{display:none;background:#fff;border:1px solid var(--line);color:var(--purple);font-size:1.4rem;padding:8px 12px;border-radius:10px}
.hero{min-height:670px;background-image:linear-gradient(90deg,rgba(0,0,0,.82) 0%,rgba(0,0,0,.62) 36%,rgba(0,0,0,.10) 70%,rgba(0,0,0,.05) 100%),url('assets/images/hero-van.jpg');background-position:center;background-size:cover;display:grid;align-items:center;color:#fff}
.hero .wrap{max-width:var(--max);margin:auto;width:100%;padding:72px 22px}
.hero-copy{max-width:660px}
.eyebrow{text-transform:uppercase;letter-spacing:.22em;font-size:.82rem;font-weight:900;color:var(--purple);margin-bottom:14px}
.hero .eyebrow{color:var(--purple-tint)}
h1{font-size:clamp(2.4rem,6vw,5.8rem);line-height:.97;margin:0 0 24px;font-weight:950;letter-spacing:-.055em}
h1 em{font-style:normal;color:var(--purple)}
h2{font-size:clamp(1.9rem,4vw,3.25rem);line-height:1.06;margin:0 0 18px;font-weight:950;letter-spacing:-.045em}
h3{line-height:1.15;margin:0 0 10px;font-weight:900}
p{margin:0 0 18px;color:var(--muted)}
.hero p{font-size:1.25rem;color:#f2f2f4;max-width:560px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.trustbar{background:#fff;box-shadow:var(--shadow);max-width:var(--max);margin:-48px auto 0;position:relative;z-index:3;border-radius:var(--radius);display:grid;grid-template-columns:repeat(4,1fr);overflow:hidden}
.trust{padding:28px;border-right:1px solid var(--line);display:flex;gap:16px;align-items:flex-start}
.trust:last-child{border-right:0}
.ico{width:52px;height:52px;flex:0 0 auto;display:grid;place-items:center;border-radius:14px;background:var(--purple-soft);color:var(--purple);font-size:1.7rem;font-weight:900}
.trust p,.card p,.project p{font-size:.98rem;margin:0;color:var(--muted)}
section{padding:92px 22px}
.wrap{max-width:var(--max);margin:auto}
.grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.grid.reverse{grid-template-columns:.95fr 1.05fr}
.soft{background:var(--soft)}
.dark{background:linear-gradient(135deg,var(--charcoal),#1A1237 58%,var(--purple-dark));color:#fff}
.dark p{color:#e5e1f2}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:34px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:0 12px 35px rgba(22,17,45,.06)}
.card ul{padding-left:18px;margin:14px 0 0;color:var(--muted)}
.card li{margin:7px 0}.card .mini{color:var(--purple);font-weight:900;text-transform:uppercase;letter-spacing:.12em;font-size:.76rem;margin-bottom:8px}
.photo-card{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);background:#fff;border:1px solid var(--line)}
.photo-card img{width:100%;height:440px;object-fit:cover}.photo-card .cap{padding:18px 20px}
.pagehead{padding:76px 22px;background:linear-gradient(135deg,var(--purple-soft),#fff)}
.pagehead h1{font-size:clamp(2.4rem,5vw,4.8rem);color:var(--ink)}
.pagehead p{font-size:1.18rem;max-width:820px}.split-list{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:22px}.pill{background:#fff;border:1px solid var(--line);border-radius:999px;padding:12px 16px;font-weight:800;color:#333}
.project-tools{display:flex;gap:12px;flex-wrap:wrap;margin:34px 0}.filter{border:1px solid var(--line);background:#fff;border-radius:999px;padding:10px 16px;cursor:pointer;font-weight:800;color:var(--purple-dark)}.filter.active{background:var(--purple);color:white;border-color:var(--purple)}
.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}.project{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:0 14px 45px rgba(22,17,45,.08)}
.project-hero{height:330px;background:#eee;position:relative;overflow:hidden}.project-hero img{width:100%;height:100%;object-fit:cover;transition:.2s}.project:hover .project-hero img{transform:scale(1.025)}
.badge{position:absolute;left:16px;top:16px;background:rgba(255,255,255,.94);color:var(--purple);font-weight:900;border-radius:999px;padding:8px 13px;font-size:.78rem;text-transform:uppercase;letter-spacing:.1em}.project-body{padding:24px}.gallery-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:18px}.thumb{height:96px;border-radius:12px;overflow:hidden;border:1px solid var(--line);cursor:pointer;background:#f1f1f3}.thumb img{width:100%;height:100%;object-fit:cover}.ba{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:16px}.ba h4{margin:0 0 8px;font-size:.8rem;color:var(--purple);text-transform:uppercase;letter-spacing:.13em}.video-card{margin-top:14px;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#000}.video-card video{width:100%;display:block;max-height:480px}
.featured-projects{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:30px}.featured-project{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:0 12px 35px rgba(22,17,45,.07)}.featured-project img{height:220px;width:100%;object-fit:cover}.featured-project div{padding:18px}.featured-project span{display:block;color:var(--purple);font-weight:900;font-size:.76rem;text-transform:uppercase;letter-spacing:.12em;margin-bottom:6px}
.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:32px}.quote{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:0 12px 35px rgba(22,17,45,.06)}.quote p{font-size:1.05rem;color:#252633}.quote b{color:var(--purple)}
.formbox{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow)}label{display:block;font-weight:800;margin:0 0 16px}input,textarea,select{width:100%;border:1px solid #d8dbe3;border-radius:10px;padding:12px 14px;margin-top:7px;background:#fff}textarea{min-height:140px;resize:vertical}.fineprint{font-size:.86rem;color:#777;margin-top:12px}
.footer{background:linear-gradient(180deg,var(--charcoal),#070B16);color:#fff;padding:54px 22px}.footer .wrap{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:32px}.footer p,.footer a{color:#cdd0dc}.footer img{width:92px;margin-bottom:14px}.footlinks{display:grid;gap:8px}.copyright{border-top:1px solid rgba(255,255,255,.12);margin-top:35px;padding-top:22px;color:#aeb4c5;font-size:.9rem}
.lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.87);z-index:99;align-items:center;justify-content:center;padding:30px}.lightbox.open{display:flex}.lightbox img{max-height:88vh;max-width:94vw;border-radius:12px}.lightbox button{position:absolute;right:22px;top:18px;background:#fff;border:0;border-radius:999px;width:42px;height:42px;font-size:1.5rem;cursor:pointer}
.notice{background:#fff9e8;border:1px solid #ead28a;border-radius:16px;padding:18px;color:#3e3100;margin-top:20px}.notice p{color:#3e3100;margin:0}.admin-callout{background:linear-gradient(135deg,var(--purple-soft),#fff);border:1px solid #ded5f6;border-radius:var(--radius);padding:28px;margin-top:28px}.admin-callout code{background:#fff;border:1px solid var(--line);border-radius:8px;padding:3px 7px}
@media (max-width:980px){.links{display:none}.menu{display:block}.links.open{display:flex;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;align-items:flex-start;padding:20px 24px;box-shadow:0 25px 45px rgba(0,0,0,.12)}.nav{position:relative}.brand{min-width:0}.brand strong{font-size:1.35rem}.brand span{letter-spacing:.28em;font-size:.78rem}.brand img{width:58px;height:58px}.topbar .wrap{display:block;text-align:center}.topbar .wrap div+div{margin-top:4px}.hero{min-height:620px;background-position:center right}.trustbar{grid-template-columns:1fr 1fr;margin:0;border-radius:0}.trust{border-bottom:1px solid var(--line)}.grid,.grid.reverse{grid-template-columns:1fr}.cards,.projects-grid,.featured-projects,.testimonials{grid-template-columns:1fr 1fr}.footer .wrap{grid-template-columns:1fr}.photo-card img{height:340px}}
@media (max-width:640px){section{padding:64px 18px}.nav{padding:12px 16px}.brand strong{font-size:1.04rem}.brand span{font-size:.65rem;letter-spacing:.18em}.hero .wrap{padding:50px 18px}.hero p{font-size:1.05rem}.trustbar{grid-template-columns:1fr}.trust{border-right:0}.cards,.projects-grid,.featured-projects,.testimonials,.split-list{grid-template-columns:1fr}.project-hero{height:260px}.gallery-row{grid-template-columns:repeat(2,1fr)}.ba{grid-template-columns:1fr}.hero-actions{display:grid}.btn{width:100%}.footer{padding:44px 18px}.topbar .wrap{font-size:.82rem}h1{letter-spacing:-.04em}}


/* Version 4 cleanup: less repetition, cleaner mobile, tighter project cards */
.top-contact{display:flex;align-items:center;gap:18px;font-weight:800}
.top-email{opacity:.95}
.projects-section{padding-top:56px}
.project-intro{max-width:860px;margin-bottom:28px}
.project-intro h2{font-size:clamp(1.55rem,3vw,2.35rem);margin-bottom:10px}
.project-toggle{margin-top:14px;border:1px solid var(--purple);background:#fff;color:var(--purple);font-weight:900;border-radius:999px;padding:10px 16px;cursor:pointer}
.project-toggle:hover{background:var(--purple-soft)}
.project-details{margin-top:18px;border-top:1px solid var(--line);padding-top:18px}
.project-details[hidden]{display:none!important}.video-list{margin-top:16px}.video-card video{max-height:360px}.cta-section{padding:76px 22px}.footer .btn{display:none}
@media (max-width:980px){.hero{min-height:560px}.top-contact{justify-content:center}.project-tools{margin-top:20px}}
@media (max-width:640px){
  .topbar .wrap{padding:8px 14px}.top-email{display:none}.top-contact{margin-top:3px}.hero{min-height:520px;background-position:61% center}.hero .wrap{padding:44px 22px}.hero-copy{max-width:100%}h1{font-size:clamp(2.15rem,12vw,3.6rem)}.hero p{font-size:1rem;max-width:92%;line-height:1.45}.hero-actions{margin-top:22px}.trust{padding:24px 22px}.project-tools{gap:10px}.filter{padding:10px 14px}.projects-grid{gap:24px}.project-body{padding:22px}.project-hero{height:245px}.project-details .ba{gap:18px}.video-card video{max-height:420px}.footer .wrap{gap:24px}.footer{padding-top:42px}.cta-section{padding:58px 22px}
}


/* Version 5 palette refresh: logo-anchored purple system */
.topbar a:hover,.footer a:hover,.footlinks a:hover{color:#fff}
.btn.secondary:hover{background:var(--purple-soft);border-color:#D8C4EA}
.card,.project,.featured-project,.quote,.formbox,.photo-card{background:var(--paper)}
.notice{background:#FFF9E8;border:1px solid #EAD28A;border-radius:16px;padding:18px;color:#3E3100;margin-top:20px}
.notice p{color:#3E3100;margin:0}


/* Version 5 final polish: readability, mobile spacing, clean footer */
.hero{
  min-height:620px;
  background-image:
    linear-gradient(90deg,rgba(11,16,32,.92) 0%,rgba(11,16,32,.78) 34%,rgba(11,16,32,.28) 64%,rgba(11,16,32,.08) 100%),
    url('assets/images/hero-van.jpg');
}
.hero-copy{
  background:linear-gradient(90deg,rgba(11,16,32,.28),rgba(11,16,32,0));
  border-radius:18px;
}
.hero h1,.hero p{
  text-shadow:0 2px 16px rgba(0,0,0,.34);
}
.hero .eyebrow{
  color:#D8B5F2;
}
.hero h1 em{
  color:#A952D7;
}
.btn{
  transition:transform .16s ease, box-shadow .16s ease, background .16s ease;
}
.btn:hover{
  box-shadow:0 16px 36px rgba(132,35,189,.24);
}
.btn.secondary:hover{
  color:var(--purple-dark);
}
.trustbar{
  border:1px solid var(--line);
}
.pagehead{
  background:linear-gradient(135deg,var(--purple-soft) 0%,#fff 72%);
}
.cta-section{
  background:
    radial-gradient(circle at 80% 20%,rgba(132,35,189,.28),transparent 36%),
    linear-gradient(135deg,var(--charcoal),#1A1237 62%,var(--purple-dark));
}
.footer{
  background:linear-gradient(180deg,#0B1020,#080B14);
}
.footer img{
  opacity:.88;
}
.footer .wrap:first-child{
  align-items:start;
}
.copyright{
  color:#AEB4C5;
}

/* Keep project cards clean and intentional */
.project{
  box-shadow:0 18px 50px rgba(23,26,36,.08);
}
.project-toggle{
  border-color:#D8C4EA;
}
.project-toggle:hover{
  border-color:var(--purple);
}
.video-card{
  box-shadow:none;
}

/* Mobile polish */
@media (max-width:640px){
  .topbar .wrap{
    line-height:1.3;
  }
  .topbar .wrap > div:first-child{
    font-size:.86rem;
  }
  .top-contact{
    font-size:.9rem;
  }
  .nav{
    padding:14px 18px;
  }
  .brand{
    gap:10px;
  }
  .brand img{
    width:52px;
    height:52px;
  }
  .brand strong{
    font-size:1.14rem;
  }
  .brand span{
    font-size:.62rem;
    letter-spacing:.2em;
  }
  .menu{
    padding:10px 14px;
    border-radius:14px;
  }
  .hero{
    min-height:500px;
    background-position:64% center;
    background-image:
      linear-gradient(90deg,rgba(11,16,32,.88) 0%,rgba(11,16,32,.62) 56%,rgba(11,16,32,.18) 100%),
      url('assets/images/hero-van.jpg');
  }
  .hero .wrap{
    padding:38px 22px 44px;
  }
  .hero-copy{
    background:linear-gradient(90deg,rgba(11,16,32,.18),rgba(11,16,32,0));
  }
  .hero .eyebrow{
    font-size:.72rem;
    letter-spacing:.18em;
    margin-bottom:10px;
  }
  .hero h1{
    font-size:clamp(2rem,11vw,3.25rem);
    line-height:1;
    margin-bottom:18px;
  }
  .hero p{
    font-size:.98rem;
    max-width:96%;
  }
  .hero-actions{
    gap:12px;
  }
  .trust{
    padding:22px 20px;
  }
  section{
    padding:58px 18px;
  }
  .pagehead{
    padding:60px 22px;
  }
  .pagehead p{
    font-size:1.04rem;
  }
  .project-tools{
    margin:24px 0;
  }
  .filter{
    color:var(--purple-dark);
  }
  .filter.active{
    color:#fff;
  }
  .footer{
    padding:42px 22px 34px;
  }
  .footer img{
    width:80px;
  }
  .footer h3{
    margin-bottom:8px;
  }
  .footer p,.footer a{
    font-size:.98rem;
  }
  .copyright{
    margin-top:28px;
    padding-top:18px;
  }
}


/* Version 6 requested edits: locked brand palette, simpler nav, tighter hero */
:root{
  --purple:#8423BD;
  --purple-dark:#6F1AA8;
  --purple-soft:#F2E8FA;
  --purple-tint:#C9A1E8;
  --ink:#171A24;
  --muted:#5E6472;
  --line:#E9E3F0;
  --paper:#FFFFFF;
  --charcoal:#0B1020;
  --soft:#FAFAFC;
  --shadow:0 20px 60px rgba(23,26,36,.10);
  --shadow-purple:0 12px 30px rgba(132,35,189,.18);
  --radius:20px;
  --max:1180px;
}
.links{gap:30px}
.hero{min-height:590px}
.hero-copy{max-width:590px}
.hero h1{
  font-size:clamp(2.55rem,5.2vw,4.95rem);
  line-height:1.02;
  letter-spacing:-.05em;
  margin-bottom:20px;
}
.hero .eyebrow{margin-bottom:12px}
.hero p{font-size:1.14rem;max-width:540px}
.hero-actions{margin-top:26px}
.trustbar{margin-top:-40px}
@media (max-width:980px){
  .links{gap:0}
  .hero h1{font-size:clamp(2.25rem,9vw,4rem)}
}
@media (max-width:640px){
  .hero{min-height:480px}
  .hero h1{
    font-size:clamp(2rem,10.4vw,3.05rem);
    line-height:1.03;
    margin-bottom:16px;
  }
  .hero .eyebrow{
    font-size:.7rem;
    letter-spacing:.17em;
  }
  .hero p{
    font-size:.96rem;
    line-height:1.42;
  }
}


/* Version 7 deep-dive polish */
.services-pagehead{
  padding-bottom:42px;
}
.services-list-section{
  padding-top:46px;
}
.service-cta-section{
  padding:70px 22px;
  background:linear-gradient(135deg,var(--charcoal),#1A1237 62%,var(--purple-dark));
  color:#fff;
}
.service-cta-card{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  align-items:center;
  gap:44px;
}
.service-cta-card p{
  color:#E9E3F0;
  max-width:720px;
}
.service-cta-card .eyebrow{
  color:#D8B5F2;
}
.service-cta-card .btn{
  justify-self:end;
  min-width:260px;
}
.links a.active:not(.btn)::after{
  transform:scaleX(1);
}
.compare-wrap{
  display:grid;
  gap:18px;
  margin-top:18px;
}
.compare-set{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  padding:16px;
  border:1px solid var(--line);
  border-radius:16px;
  background:var(--soft);
}
.compare-col h4{
  margin:0 0 10px;
  color:var(--purple);
  text-transform:uppercase;
  letter-spacing:.13em;
  font-size:.78rem;
}
.compare-photo{
  width:100%;
  display:block;
  border:1px solid var(--line);
  padding:0;
  border-radius:12px;
  overflow:hidden;
  background:#fff;
  cursor:pointer;
}
.compare-photo img{
  width:100%;
  height:160px;
  object-fit:cover;
}
.compare-empty{
  display:grid;
  place-items:center;
  min-height:160px;
  border:1px dashed #D8C4EA;
  border-radius:12px;
  color:var(--muted);
  background:#fff;
  font-weight:700;
}
.video-list h4{
  margin:18px 0 10px;
  color:var(--purple);
  text-transform:uppercase;
  letter-spacing:.13em;
  font-size:.78rem;
}
.formbox .fineprint a{
  color:var(--purple);
  font-weight:900;
}
@media (max-width:980px){
  .service-cta-card{
    grid-template-columns:1fr;
  }
  .service-cta-card .btn{
    justify-self:start;
  }
}
@media (max-width:640px){
  .services-pagehead{
    padding-bottom:30px;
  }
  .services-list-section{
    padding-top:32px;
  }
  .service-cta-section{
    padding:54px 22px;
  }
  .service-cta-card{
    gap:24px;
  }
  .service-cta-card .btn{
    width:100%;
  }
  .compare-set{
    grid-template-columns:1fr;
    gap:14px;
    padding:14px;
  }
  .compare-photo img{
    height:170px;
  }
}


/* Version 9: inline form thank-you message */
.form-success,.form-error{
  margin-top:18px;
  border-radius:16px;
  padding:18px 20px;
}
.form-success{
  background:#F2E8FA;
  border:1px solid #D8C4EA;
}
.form-success h3,.form-error h3{
  margin:0 0 6px;
}
.form-success p,.form-error p{
  margin:0;
}
.form-error{
  background:#FFF3F3;
  border:1px solid #E7B8B8;
}
.form-error a{
  color:var(--purple);
  font-weight:900;
}
button[disabled]{
  opacity:.72;
  cursor:not-allowed;
}


/* Version 10: Netlify Forms detection blueprint */
.netlify-form-blueprint,
.bot-field{
  position:absolute !important;
  left:-10000px !important;
  top:auto !important;
  width:1px !important;
  height:1px !important;
  overflow:hidden !important;
}
