
:root{
  --bg:#020817;--panel:#07172f;--panel2:#0a2144;--txt:#f8fbff;--muted:#abc0d8;
  --blue:#087cff;--cyan:#27d8ff;--deep:#08111f;--white:#fff;--ink:#07101f;
  --soft:#f4f9ff;--line:rgba(255,255,255,.12);--line2:rgba(7,16,31,.10);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:Inter,system-ui,-apple-system,Segoe UI,Arial,sans-serif;background:var(--soft);color:var(--ink);line-height:1.6;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{max-width:100%;height:auto}
.container{width:min(1210px,calc(100% - 36px));margin:auto}
.header{position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(2,8,23,.78);backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}
.nav{height:82px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:14px;color:#fff;font-weight:950;letter-spacing:.06em}
.mark{width:52px;height:52px;border-radius:17px;background:linear-gradient(135deg,var(--cyan),var(--blue) 65%,#0041e8);display:grid;place-items:center;font-size:23px;letter-spacing:-.15em;box-shadow:0 16px 42px rgba(8,124,255,.35)}
.brand span:last-child{line-height:1.08;font-size:17px}
.links{display:flex;align-items:center;gap:30px;color:#e6f4ff;font-size:13px;font-weight:900;text-transform:uppercase}
.links a:hover{color:var(--cyan)}
.cta{display:inline-flex;align-items:center;justify-content:center;gap:10px;background:linear-gradient(90deg,var(--cyan),var(--blue));color:#fff;padding:13px 22px;border-radius:999px;font-size:13px;font-weight:950;text-transform:uppercase;box-shadow:0 18px 44px rgba(8,124,255,.32)}
.menu{display:none;background:rgba(255,255,255,.07);border:1px solid var(--line);color:#fff;border-radius:14px;width:46px;height:46px;font-size:24px}
.hero{position:relative;padding:140px 0 0;min-height:900px;color:#fff;background:
 radial-gradient(circle at 70% 25%,rgba(39,216,255,.28),transparent 29rem),
 radial-gradient(circle at 18% 15%,rgba(8,124,255,.18),transparent 28rem),
 linear-gradient(135deg,#020817 0%,#07142a 48%,#082d5c 100%);overflow:hidden}
.hero:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);background-size:72px 72px;mask-image:radial-gradient(circle at 60% 22%,#000,transparent 72%)}
.hero:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:175px;background:linear-gradient(180deg,transparent,var(--soft) 72%)}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.02fr .98fr;align-items:center;gap:42px}
.kicker{display:inline-flex;align-items:center;gap:14px;color:#8cecff;font-weight:950;letter-spacing:.13em;text-transform:uppercase;font-size:13px;margin-bottom:22px}
.kicker:after{content:"";width:62px;height:2px;background:linear-gradient(90deg,var(--cyan),transparent)}
h1{font-size:clamp(46px,5.6vw,84px);line-height:.98;letter-spacing:-.065em;margin-bottom:23px}
.grad{background:linear-gradient(90deg,#80f0ff,#19a8ff,#2f63ff);-webkit-background-clip:text;background-clip:text;color:transparent}
.lead{font-size:22px;color:#eaf7ff;max-width:660px;margin-bottom:16px}
.copy{font-size:17px;color:#b8c9df;max-width:600px}
.actions{display:flex;gap:16px;flex-wrap:wrap;margin-top:34px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:16px 24px;border-radius:16px;font-size:13px;font-weight:950;text-transform:uppercase;transition:.18s}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:linear-gradient(90deg,var(--cyan),var(--blue));color:#fff;box-shadow:0 18px 48px rgba(8,124,255,.34)}
.btn-ghost{border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.055);color:#fff}
.media{position:relative;min-height:620px;display:flex;align-items:flex-end;justify-content:center}
.orbit{position:absolute;width:min(620px,92vw);height:min(620px,92vw);border-radius:50%;bottom:28px;background:radial-gradient(circle,rgba(39,216,255,.35),rgba(8,124,255,.12) 58%,transparent 70%);border:1px solid rgba(128,240,255,.18)}
.portrait{position:relative;z-index:2;width:min(570px,90vw);filter:drop-shadow(0 38px 82px rgba(0,0,0,.56))}
.metric{position:absolute;z-index:3;left:12px;bottom:88px;width:260px;padding:18px 20px;border-radius:22px;background:rgba(255,255,255,.085);border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(16px)}
.metric b{font-size:30px;display:block}.metric span{font-size:14px;color:#c5d8ee}
.quote{position:absolute;right:8px;top:170px;z-index:3;width:230px;color:#ddecff;font-size:19px}
.quote:before{content:"“";display:block;color:var(--cyan);font-size:68px;line-height:.7;font-weight:900}
.quote em{display:block;color:#35d8ff;font-family:cursive;font-size:27px;margin-top:14px}
.projects{position:relative;z-index:5;margin-top:-105px;background:linear-gradient(135deg,rgba(7,23,47,.96),rgba(4,29,62,.99));border:1px solid rgba(39,216,255,.20);box-shadow:0 34px 95px rgba(3,15,35,.28);border-radius:32px;padding:30px}
.projects-head{display:flex;justify-content:space-between;align-items:end;gap:22px;margin-bottom:22px;color:#fff}
.projects-head h2{font-size:21px;letter-spacing:.12em;text-transform:uppercase}.projects-head p{color:#b7cae1}
.logos{display:grid;grid-template-columns:repeat(6,1fr);border-radius:22px;overflow:hidden;border:1px solid rgba(255,255,255,.08)}
.logo{min-height:118px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;background:rgba(255,255,255,.025);border-right:1px solid rgba(255,255,255,.08)}
.logo:last-child{border-right:0}.logo:hover{background:rgba(39,216,255,.08)}
.logo b{font-size:23px;line-height:1.05;color:#fff}.logo small{color:#b7cae1;margin-top:10px}
.section{padding:94px 0}.section-title{max-width:760px;margin-bottom:34px}
.eyedark{color:#087cff;text-transform:uppercase;font-weight:950;letter-spacing:.13em;font-size:13px;margin-bottom:10px}
h2{font-size:clamp(34px,4vw,56px);line-height:1.04;letter-spacing:-.055em;color:#07101f}
.muted{color:#627287;font-size:18px}
.grid2{display:grid;grid-template-columns:.92fr 1.08fr;gap:24px}
.card{background:#fff;border:1px solid var(--line2);border-radius:30px;padding:34px;box-shadow:0 24px 80px rgba(8,22,48,.08)}
.card p{color:#46576d}.dark{background:linear-gradient(135deg,#07152d,#004987 62%,#057aff);color:#fff;border-color:rgba(255,255,255,.12)}
.dark p,.dark .muted{color:#d8eaff}.dark h2,.dark h3{color:#fff}
.values{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:24px}.value{padding:20px;border-radius:22px;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.12)}
.value h3{color:#8cecff;margin-bottom:5px}
.wp{display:grid;grid-template-columns:190px 1fr;gap:30px;align-items:center}
.wp-badge{width:185px;height:185px;border-radius:50%;display:grid;place-items:center;text-align:center;color:#fff;font-weight:950;background:linear-gradient(135deg,#0395d6,#075fa8);box-shadow:0 18px 48px rgba(3,149,214,.28);line-height:1.05}.wp-badge small{display:block;font-size:13px;margin-top:7px}
.stats{display:flex;gap:14px;flex-wrap:wrap;margin:22px 0}.stat{padding:10px 13px;border-radius:14px;background:#edf7ff;color:#005bd4;font-weight:900}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.service{background:#fff;border:1px solid var(--line2);border-radius:24px;padding:26px;box-shadow:0 20px 60px rgba(8,22,48,.07)}.service h3{font-size:24px;margin-bottom:8px}
.contact{margin-bottom:80px}
.footer{background:#020817;color:#9fb3ca;padding:44px 0;text-align:center}.footer b{color:#fff}.footer a{color:#6fe8ff}.footlinks{display:flex;gap:18px;flex-wrap:wrap;justify-content:center;margin-top:14px}
.legal{padding:140px 0 80px;min-height:100vh;background:#f7fbff}.legal h1{color:#07101f;font-size:48px}.legal h2{font-size:28px;margin-top:26px}.legal p,.legal li{color:#4a5b70;margin:12px 0}.legal ul{padding-left:22px}
@media(max-width:980px){
 .nav{height:72px}.menu{display:block}.desktop{display:none}.links{position:fixed;display:none;flex-direction:column;align-items:stretch;gap:0;left:16px;right:16px;top:78px;padding:12px;border-radius:24px;background:rgba(3,12,27,.98);border:1px solid rgba(39,216,255,.22);box-shadow:0 30px 80px rgba(0,0,0,.35)}.links.open{display:flex}.links a{padding:15px;border-radius:15px}.links a:hover{background:rgba(39,216,255,.08)}
 .hero{padding-top:108px;min-height:unset}.hero-grid{grid-template-columns:1fr;text-align:center}.media{order:-1;min-height:430px}.copy,.lead{margin-left:auto;margin-right:auto}.actions{justify-content:center}.metric,.quote{display:none}
 .projects{margin-top:34px}.projects-head{display:block;text-align:center}.logos{grid-template-columns:repeat(2,1fr)}.logo{border-bottom:1px solid rgba(255,255,255,.08)}.logo:nth-child(2n){border-right:0}.logo:nth-last-child(-n+2){border-bottom:0}
 .grid2,.wp{grid-template-columns:1fr}.wp-badge{margin:auto}.cards{grid-template-columns:1fr}
}
@media(max-width:560px){
 .container{width:min(100% - 24px,1210px)}.brand span:last-child{font-size:15px}.mark{width:44px;height:44px;border-radius:14px}.hero h1{font-size:39px}.lead{font-size:18px}.copy{font-size:16px}.media{min-height:330px}.btn{width:100%}.projects{padding:18px;border-radius:24px}.logo{min-height:88px}.logo b{font-size:19px}.section{padding:66px 0}.card{padding:24px}.values{grid-template-columns:1fr}
}


/* Logo/color correction */
.brand-logos .logo{
  background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.025));
  padding:18px 14px;
}
.logo-img img{
  max-width:135px;
  max-height:48px;
  object-fit:contain;
  filter:none;
}
.logo-wide img{
  max-width:160px;
  max-height:55px;
}
.brand-logos .logo b span{
  color:#38d8ff;
}
.wp-logo-real{
  border-radius:50%;
  object-fit:contain;
  background:transparent !important;
  box-shadow:0 18px 48px rgba(3,149,214,.16);
}
@media(max-width:560px){
  .logo-img img{max-width:112px;max-height:42px}
  .logo-wide img{max-width:138px;max-height:48px}
}


/* === Mobile/typography/button refinement requested === */
p,
.copy,
.lead,
.muted,
.card p,
.service p,
.value p,
.quote,
.logo small,
.projects-head p{
  font-size:17px;
  line-height:1.75;
  font-weight:400;
  letter-spacing:0;
}

.btn,
.cta{
  background:#ffffff !important;
  border:1.5px solid rgba(39,216,255,.75) !important;
  color:#087cff !important;
  box-shadow:0 12px 32px rgba(8,124,255,.12) !important;
  font-weight:500 !important;
  text-transform:none !important;
}

.btn-primary,
.btn-ghost{
  background:#ffffff !important;
  color:#087cff !important;
}

.btn::first-letter,
.cta::first-letter{
  color:#087cff;
}

.card,
.projects,
.service{
  border:1px solid rgba(8,124,255,.12) !important;
  box-shadow:0 18px 55px rgba(8,22,48,.07) !important;
}

.projects{
  background:#ffffff !important;
  color:#07101f !important;
}

.projects-head h2,
.projects-head p,
.logo b,
.logo small{
  color:#07101f !important;
}

.logo{
  background:#ffffff !important;
  border-color:rgba(8,124,255,.10) !important;
}

.dark{
  background:#ffffff !important;
  color:#07101f !important;
}

.dark h2,
.dark h3{
  color:#07101f !important;
}

.dark p,
.dark .muted,
.value p{
  color:#46576d !important;
}

.value{
  background:#f6fbff !important;
  border:1px solid rgba(8,124,255,.10) !important;
}

.value h3{
  color:#087cff !important;
}

@media(max-width:980px){
  .hero{
    padding-top:118px !important;
  }
  .media{
    min-height:470px !important;
    padding-top:54px !important;
    margin-top:22px !important;
  }
  .orbit{
    bottom:18px !important;
    width:min(560px,88vw) !important;
    height:min(560px,88vw) !important;
  }
  .portrait{
    width:min(500px,82vw) !important;
  }
  .actions{
    gap:14px !important;
  }
  .btn{
    border-radius:18px !important;
    padding:15px 22px !important;
  }
}

@media(max-width:560px){
  p,
  .copy,
  .lead,
  .muted,
  .card p,
  .service p,
  .value p,
  .quote,
  .logo small,
  .projects-head p{
    font-size:16px !important;
    line-height:1.75 !important;
    font-weight:400 !important;
  }

  .hero{
    padding-top:122px !important;
  }

  .media{
    order:-1;
    min-height:390px !important;
    padding-top:78px !important;
    margin-top:18px !important;
  }

  .orbit{
    top:58px !important;
    bottom:auto !important;
    width:86vw !important;
    height:86vw !important;
  }

  .portrait{
    width:78vw !important;
    margin-top:20px !important;
  }

  .hero-grid{
    gap:22px !important;
  }

  .kicker{
    margin-top:12px !important;
  }

  .btn{
    width:100%;
    justify-content:center;
    font-size:15px !important;
    font-weight:500 !important;
    letter-spacing:0 !important;
    padding:16px 20px !important;
  }

  .projects{
    margin-top:48px !important;
    border-radius:26px !important;
    background:#ffffff !important;
  }

  .logos{
    border-color:rgba(8,124,255,.10) !important;
  }

  .logo{
    min-height:104px !important;
  }

  .card{
    border-radius:26px !important;
  }
}


/* === Centered + compact spacing update === */
body{
  text-align:center;
}

.container,
.hero-grid,
.section-title,
.card,
.service,
.projects,
.projects-head,
.logo,
.wp,
.contact,
.footer,
.legal{
  text-align:center !important;
}

.copy,
.lead,
.muted,
.card p,
.service p,
.value p,
.projects-head p{
  margin-left:auto !important;
  margin-right:auto !important;
}

.actions,
.stats,
.footlinks{
  justify-content:center !important;
}

.grid2,
.wp,
.cards,
.values{
  align-items:center !important;
}

.section{
  padding:58px 0 !important;
}

.section-title{
  margin-left:auto !important;
  margin-right:auto !important;
  margin-bottom:24px !important;
}

.projects{
  margin-top:-42px !important;
}

.card{
  display:flex;
  flex-direction:column;
  align-items:center;
}

.wp{
  justify-items:center !important;
}

.wp > div{
  text-align:center !important;
}

.hero{
  padding-top:112px !important;
  min-height:780px !important;
}

.hero-grid{
  gap:18px !important;
}

.media{
  min-height:560px !important;
  padding-top:0 !important;
  margin-top:0 !important;
}

.orbit{
  bottom:12px !important;
}

.portrait{
  margin-left:auto !important;
  margin-right:auto !important;
}

.kicker{
  justify-content:center !important;
}

@media(max-width:980px){
  .hero{
    padding-top:86px !important;
    min-height:auto !important;
  }

  .hero-grid{
    gap:10px !important;
  }

  .media{
    min-height:365px !important;
    padding-top:16px !important;
    margin-top:0 !important;
  }

  .orbit{
    top:24px !important;
    bottom:auto !important;
    width:min(430px,82vw) !important;
    height:min(430px,82vw) !important;
  }

  .portrait{
    width:min(390px,74vw) !important;
    margin-top:0 !important;
  }

  .section{
    padding:46px 0 !important;
  }

  .projects{
    margin-top:22px !important;
  }

  .card{
    padding:26px !important;
  }
}

@media(max-width:560px){
  .hero{
    padding-top:78px !important;
  }

  .media{
    min-height:315px !important;
    padding-top:8px !important;
    margin-top:0 !important;
  }

  .orbit{
    top:18px !important;
    width:76vw !important;
    height:76vw !important;
  }

  .portrait{
    width:68vw !important;
    margin-top:0 !important;
  }

  .kicker{
    margin-top:0 !important;
    margin-bottom:14px !important;
  }

  h1{
    text-align:center !important;
    margin-left:auto !important;
    margin-right:auto !important;
  }

  .lead,
  .copy{
    max-width:94% !important;
  }

  .actions{
    margin-top:22px !important;
  }

  .projects{
    margin-top:24px !important;
    padding:18px !important;
  }

  .projects-head{
    margin-bottom:16px !important;
  }

  .section{
    padding:38px 0 !important;
  }

  .section-title{
    margin-bottom:18px !important;
  }

  .grid2,
  .wp,
  .cards{
    gap:16px !important;
  }

  .values{
    gap:12px !important;
  }

  .card,
  .service{
    padding:22px !important;
  }

  .contact{
    margin-bottom:40px !important;
  }
}


/* Anchor offset fix for fixed header */
html{
  scroll-padding-top:120px;
}
section[id], div[id]{
  scroll-margin-top:120px;
}

/* New logo */
.mark{
  background:none !important;
  overflow:hidden;
  padding:0;
}
.mark img{
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:16px;
}

/* Project pages */
.project-hero{
  padding:140px 0 80px;
  background:linear-gradient(135deg,#020817,#082d5c);
  color:white;
  text-align:center;
}
.project-content{
  max-width:900px;
  margin:auto;
  padding:60px 20px;
}
.project-content h2{
  margin-bottom:18px;
}
.project-content p{
  margin-bottom:18px;
}
.service-list{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:20px;
  margin-top:30px;
}
.service-item{
  background:#fff;
  border:1px solid rgba(8,124,255,.12);
  border-radius:22px;
  padding:24px;
  box-shadow:0 12px 40px rgba(8,22,48,.06);
}
@media(max-width:560px){
  html{
    scroll-padding-top:95px;
  }
  section[id], div[id]{
    scroll-margin-top:95px;
  }
}


/* === Plus update: full menu on every page, richer home, better legal pages === */
.page-main{padding-top:96px}
.premium-band{
  padding:56px 0;
  background:linear-gradient(180deg,#f4f9ff,#ffffff);
}
.unique-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.unique-card{
  background:#fff;
  border:1px solid rgba(8,124,255,.12);
  border-radius:26px;
  padding:28px;
  box-shadow:0 18px 55px rgba(8,22,48,.07);
  text-align:center;
}
.unique-card .icon{
  width:58px;height:58px;border-radius:18px;
  margin:0 auto 16px;
  display:grid;place-items:center;
  background:linear-gradient(135deg,#22d3ee,#2563eb);
  color:white;font-size:26px;
}
.timeline{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
  margin-top:28px;
}
.step{
  background:#fff;
  border:1px solid rgba(8,124,255,.12);
  border-radius:24px;
  padding:24px;
  box-shadow:0 14px 45px rgba(8,22,48,.06);
}
.step b{
  display:inline-flex;
  width:38px;height:38px;border-radius:50%;
  align-items:center;justify-content:center;
  background:#eef8ff;color:#087cff;margin-bottom:12px;
}
.focus-card{
  background:linear-gradient(135deg,#ffffff,#eef8ff);
  border:1px solid rgba(8,124,255,.14);
  border-radius:32px;
  padding:36px;
  box-shadow:0 18px 55px rgba(8,22,48,.07);
}
.legal-layout{
  display:grid;
  grid-template-columns:260px 1fr;
  gap:24px;
  align-items:start;
}
.legal-nav{
  position:sticky;
  top:116px;
  background:#fff;
  border:1px solid rgba(8,124,255,.12);
  border-radius:24px;
  padding:20px;
  box-shadow:0 14px 45px rgba(8,22,48,.06);
}
.legal-nav a{
  display:block;
  padding:10px 12px;
  border-radius:12px;
  color:#087cff;
}
.legal-nav a:hover{background:#eef8ff}
.legal-content{
  background:#fff;
  border:1px solid rgba(8,124,255,.12);
  border-radius:28px;
  padding:34px;
  box-shadow:0 18px 55px rgba(8,22,48,.07);
  text-align:left !important;
}
.legal-content h1,.legal-content h2,.legal-content p,.legal-content li{
  text-align:left !important;
}
.legal-content h2{
  font-size:28px;
  margin-top:28px;
  margin-bottom:8px;
}
.legal-content p,.legal-content li{
  font-size:16px !important;
  line-height:1.75 !important;
}
.project-content{
  text-align:center !important;
}
.project-content p{
  max-width:760px;
  margin-left:auto;
  margin-right:auto;
}
.project-kpis{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
  margin:28px 0;
}
.project-kpi{
  background:#fff;
  border:1px solid rgba(8,124,255,.12);
  border-radius:20px;
  padding:20px;
}
@media(max-width:900px){
  .unique-grid,.timeline,.project-kpis{grid-template-columns:1fr}
  .legal-layout{grid-template-columns:1fr}
  .legal-nav{position:relative;top:auto}
}
@media(max-width:560px){
  .premium-band{padding:38px 0}
  .unique-card,.step,.focus-card,.legal-content{padding:22px}
  .page-main{padding-top:82px}
}

.page-main{padding-top:0!important}
.project-hero{padding:170px 0 72px!important;margin-top:0!important;background:linear-gradient(135deg,#020817,#082d5c);color:#fff;text-align:center}
.service-hero{padding:170px 0 72px!important;margin-top:0!important;background:linear-gradient(135deg,#020817,#082d5c);color:#fff;text-align:center}
.project-content{padding:46px 20px 60px!important;max-width:1050px;margin:auto;text-align:center!important}
.detail-block{background:#fff;border:1px solid rgba(8,124,255,.12);border-radius:28px;padding:30px;box-shadow:0 18px 55px rgba(8,22,48,.07);margin:22px auto;max-width:940px;text-align:center}
.detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:26px auto;max-width:1050px}
.detail-card{background:#f7fbff;border:1px solid rgba(8,124,255,.12);border-radius:22px;padding:22px;text-align:center}
.detail-card h3{margin-bottom:8px}
.service-page-section{padding:54px 0;background:#f7fbff}
.service-list a{display:block;color:inherit}
@media(max-width:560px){
  .project-hero,.service-hero{padding-top:145px!important;padding-bottom:58px!important}
  .project-content{padding-top:34px!important}
  .detail-grid{grid-template-columns:1fr;gap:14px}
  .detail-block{padding:22px;border-radius:24px}
}


/* === Official Manuel Cafarella logo update === */
.brand{
  gap:0 !important;
}
.brand .mark{
  width:260px !important;
  height:64px !important;
  border-radius:0 !important;
  box-shadow:none !important;
  background:transparent !important;
  display:block !important;
}
.brand .mark img{
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
  border-radius:0 !important;
}
.brand > span:last-child{
  display:none !important;
}
.header{
  background:rgba(2,8,23,.88) !important;
}
@media(max-width:560px){
  .brand .mark{
    width:220px !important;
    height:58px !important;
  }
  .nav{
    gap:10px !important;
  }
}
@media(max-width:390px){
  .brand .mark{
    width:190px !important;
  }
}


/* === Header: horizontal official logo only, no extra text === */
.header{
  background:rgba(255,255,255,.92) !important;
  border-bottom:1px solid rgba(8,22,48,.08) !important;
}
.brand{
  display:flex !important;
  align-items:center !important;
  gap:0 !important;
  min-width:0 !important;
}
.brand-logo-horizontal{
  display:block !important;
  width:300px !important;
  max-width:42vw !important;
  height:auto !important;
  object-fit:contain !important;
}
.nav{
  height:86px !important;
}
.menu{
  color:#07101f !important;
  border-color:rgba(8,22,48,.14) !important;
  background:rgba(7,16,31,.04) !important;
}
.links{
  color:#07101f !important;
}
.links a:hover{
  color:#087cff !important;
}
@media(max-width:980px){
  .nav{
    height:82px !important;
  }
  .links{
    background:rgba(255,255,255,.98) !important;
    border:1px solid rgba(8,124,255,.18) !important;
  }
  .links a{
    color:#07101f !important;
  }
}
@media(max-width:560px){
  .brand-logo-horizontal{
    width:245px !important;
    max-width:62vw !important;
  }
  .nav{
    height:78px !important;
  }
}
@media(max-width:380px){
  .brand-logo-horizontal{
    width:210px !important;
    max-width:58vw !important;
  }
}


/* === Logo backgrounds preserved: add clean containers instead of removing backgrounds === */
.header{
  background:rgba(255,255,255,.94) !important;
  border-bottom:1px solid rgba(8,22,48,.08) !important;
}
.nav{
  height:92px !important;
}
.brand-logo-box{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:330px !important;
  max-width:44vw !important;
  height:68px !important;
  padding:8px 14px !important;
  background:#ffffff !important;
  border:1px solid rgba(8,22,48,.08) !important;
  border-radius:18px !important;
  box-shadow:0 10px 30px rgba(8,22,48,.08) !important;
  overflow:hidden !important;
}
.brand-logo-horizontal{
  display:block !important;
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
}
.brand .mark,
.brand > span:last-child{
  display:none !important;
}
.menu{
  color:#07101f !important;
  border-color:rgba(8,22,48,.14) !important;
  background:rgba(7,16,31,.04) !important;
}
.links{
  color:#07101f !important;
}
.logo-img img,
.wp-logo-real,
.wp-badge{
  background:#ffffff !important;
  padding:10px !important;
  border-radius:18px !important;
  box-shadow:0 10px 28px rgba(8,22,48,.08) !important;
  object-fit:contain !important;
}
.wp-logo-real,
.wp-badge{
  border-radius:50% !important;
  padding:0 !important;
}
.brand-logos .logo,
.logo{
  background:#ffffff !important;
}
@media(max-width:980px){
  .nav{
    height:86px !important;
  }
  .brand-logo-box{
    width:285px !important;
    max-width:62vw !important;
    height:62px !important;
    padding:7px 12px !important;
  }
  .links{
    background:rgba(255,255,255,.98) !important;
    border:1px solid rgba(8,124,255,.18) !important;
  }
  .links a{color:#07101f !important}
}
@media(max-width:420px){
  .brand-logo-box{
    width:235px !important;
    max-width:60vw !important;
    height:58px !important;
    border-radius:16px !important;
  }
}


/* === SEO/performance + final logo corrections === */
html{scroll-padding-top:96px}
section[id],div[id]{scroll-margin-top:96px}
.header{
  background:rgba(255,255,255,.96) !important;
  border-bottom:1px solid rgba(8,22,48,.08) !important;
}
.nav{height:72px !important}
.brand-logo-box{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:210px !important;
  max-width:36vw !important;
  height:46px !important;
  padding:4px 8px !important;
  background:#fff !important;
  border:1px solid rgba(8,22,48,.08) !important;
  border-radius:12px !important;
  box-shadow:0 6px 18px rgba(8,22,48,.06) !important;
  overflow:hidden !important;
}
.brand-logo-horizontal{
  display:block !important;
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
}
.brand .mark,.brand>span:last-child{display:none !important}
.menu{
  color:#07101f !important;
  border-color:rgba(8,22,48,.14) !important;
  background:rgba(7,16,31,.04) !important;
}
.links{color:#07101f !important}
.links a:hover{color:#087cff !important}

/* Project logos: normal, not transparent, inside clean white cards */
.logo-img img{
  background:transparent !important;
  padding:0 !important;
  border-radius:0 !important;
  box-shadow:none !important;
  max-width:132px !important;
  max-height:56px !important;
  object-fit:contain !important;
  filter:none !important;
}
.logo-wide img{
  max-width:162px !important;
  max-height:62px !important;
}
.wp-logo-real,.wp-badge{
  background:transparent !important;
  padding:0 !important;
  box-shadow:none !important;
  object-fit:contain !important;
}
.brand-logos .logo,.logo{
  background:#fff !important;
}
a:focus-visible,button:focus-visible{
  outline:3px solid #22d3ee;
  outline-offset:3px;
}
img{height:auto}
@media(max-width:980px){
  html{scroll-padding-top:84px}
  section[id],div[id]{scroll-margin-top:84px}
  .nav{height:68px !important}
  .brand-logo-box{width:190px !important;max-width:54vw !important;height:43px !important}
  .links{
    background:rgba(255,255,255,.98) !important;
    border:1px solid rgba(8,124,255,.18) !important;
  }
  .links a{color:#07101f !important}
}
@media(max-width:420px){
  .brand-logo-box{width:170px !important;max-width:52vw !important;height:40px !important}
  .menu{width:42px !important;height:42px !important}
  .logo-img img{max-width:112px !important;max-height:48px !important}
  .logo-wide img{max-width:138px !important;max-height:52px !important}
}


/* === FINAL FIX: header logo size + original project logo backgrounds === */
.header{
  background:rgba(255,255,255,.96) !important;
  border-bottom:1px solid rgba(8,22,48,.08) !important;
}
.nav{
  height:74px !important;
}
.brand{
  min-width:0 !important;
}
.brand-logo-box{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:198px !important;
  max-width:34vw !important;
  height:48px !important;
  padding:5px 9px !important;
  background:#ffffff !important;
  border:1px solid rgba(8,22,48,.10) !important;
  border-radius:20px !important;
  box-shadow:0 8px 24px rgba(8,22,48,.07) !important;
  overflow:hidden !important;
}
.brand-logo-horizontal{
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
  display:block !important;
  border-radius:0 !important;
}
.brand .mark,
.brand > span:last-child{
  display:none !important;
}

/* Loghi progetti: immagini originali normali, con il loro sfondo, non trasparenti */
.logo-img img,
.logo-wide img{
  display:block !important;
  background:transparent !important;
  padding:0 !important;
  border-radius:0 !important;
  box-shadow:none !important;
  object-fit:contain !important;
  filter:none !important;
}
.logo-img img{
  max-width:138px !important;
  max-height:58px !important;
}
.logo-wide img{
  max-width:170px !important;
  max-height:66px !important;
}
.wp-logo-real,
.wp-badge{
  background:transparent !important;
  padding:0 !important;
  box-shadow:none !important;
  object-fit:contain !important;
}
.brand-logos .logo,
.logo{
  background:#ffffff !important;
}

/* Mobile */
@media(max-width:980px){
  .nav{
    height:70px !important;
  }
  .brand-logo-box{
    width:178px !important;
    max-width:52vw !important;
    height:44px !important;
    padding:4px 8px !important;
    border-radius:18px !important;
  }
}
@media(max-width:420px){
  .brand-logo-box{
    width:158px !important;
    max-width:50vw !important;
    height:40px !important;
    padding:4px 7px !important;
    border-radius:16px !important;
  }
  .logo-img img{
    max-width:118px !important;
    max-height:50px !important;
  }
  .logo-wide img{
    max-width:145px !important;
    max-height:55px !important;
  }
}


/* === FINAL OVERRIDES: small header logo, no header/hero gap, original logos === */
.header{
  position:fixed !important;
  top:0 !important;
  left:0 !important;
  right:0 !important;
  z-index:999 !important;
  background:rgba(255,255,255,.97) !important;
  border-bottom:1px solid rgba(8,22,48,.08) !important;
}
.nav{
  height:64px !important;
}
.brand-logo-box{
  width:150px !important;
  max-width:42vw !important;
  height:42px !important;
  padding:3px 7px !important;
  background:#ffffff !important;
  border:1px solid rgba(8,22,48,.10) !important;
  border-radius:20px !important;
  box-shadow:0 6px 18px rgba(8,22,48,.06) !important;
  overflow:hidden !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
}
.brand-logo-horizontal{
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
  display:block !important;
}
.brand .mark,
.brand > span:last-child{
  display:none !important;
}

/* Home hero starts under fixed header without empty gap */
.hero{
  padding-top:64px !important;
  margin-top:0 !important;
}

/* Inner pages: hero attached visually to header. Content starts exactly after fixed header. */
.page-main{
  padding-top:64px !important;
}
.project-hero,
.service-hero{
  margin-top:0 !important;
  padding-top:76px !important;
  padding-bottom:70px !important;
}

/* Original project logos: never transparent processing, shown as normal images */
.logo-img img,
.logo-wide img{
  background:transparent !important;
  padding:0 !important;
  border-radius:0 !important;
  box-shadow:none !important;
  filter:none !important;
  object-fit:contain !important;
  max-width:138px !important;
  max-height:58px !important;
}
.logo-wide img{
  max-width:170px !important;
  max-height:64px !important;
}
.wp-logo-real,
.wp-badge{
  background:transparent !important;
  padding:0 !important;
  box-shadow:none !important;
  object-fit:contain !important;
}
.brand-logos .logo,
.logo{
  background:#ffffff !important;
}

@media(max-width:980px){
  .nav{
    height:60px !important;
  }
  .brand-logo-box{
    width:140px !important;
    max-width:44vw !important;
    height:38px !important;
    padding:3px 6px !important;
    border-radius:18px !important;
  }
  .hero{
    padding-top:60px !important;
  }
  .page-main{
    padding-top:60px !important;
  }
  .project-hero,
  .service-hero{
    padding-top:68px !important;
    padding-bottom:58px !important;
  }
}
@media(max-width:420px){
  .brand-logo-box{
    width:130px !important;
    max-width:42vw !important;
    height:36px !important;
    padding:3px 5px !important;
    border-radius:16px !important;
  }
  .menu{
    width:40px !important;
    height:40px !important;
  }
  .project-hero,
  .service-hero{
    padding-top:64px !important;
  }
  .logo-img img{
    max-width:112px !important;
    max-height:50px !important;
  }
  .logo-wide img{
    max-width:145px !important;
    max-height:55px !important;
  }
}


/* === Header logo visible + compact project spacing + footer logo === */
.header{
  position:fixed !important;
  top:0 !important;
  left:0 !important;
  right:0 !important;
  z-index:9999 !important;
  background:#ffffff !important;
  border-bottom:1px solid rgba(8,22,48,.10) !important;
}
.nav{
  height:70px !important;
  display:flex !important;
  align-items:center !important;
}
.brand{
  display:flex !important;
  align-items:center !important;
  min-width:0 !important;
}
.brand-logo-box{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:190px !important;
  max-width:42vw !important;
  height:48px !important;
  padding:5px 9px !important;
  background:#ffffff !important;
  border:1px solid rgba(8,22,48,.12) !important;
  border-radius:20px !important;
  box-shadow:0 6px 18px rgba(8,22,48,.08) !important;
  overflow:hidden !important;
  opacity:1 !important;
  visibility:visible !important;
}
.brand-logo-horizontal{
  display:block !important;
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
  opacity:1 !important;
  visibility:visible !important;
}
.brand .mark,
.brand > span:last-child{
  display:none !important;
}
.menu{
  color:#07101f !important;
  border-color:rgba(8,22,48,.14) !important;
  background:rgba(7,16,31,.04) !important;
}
.links{
  color:#07101f !important;
}

/* Hero spacing */
.hero{
  padding-top:70px !important;
  margin-top:0 !important;
}
.page-main{
  padding-top:70px !important;
}
.project-hero,
.service-hero{
  margin-top:0 !important;
  padding-top:72px !important;
  padding-bottom:44px !important;
}
.project-content{
  padding-top:22px !important;
}
.premium-band{
  padding-top:30px !important;
}
.detail-block{
  margin-top:10px !important;
}
.detail-grid{
  margin-top:18px !important;
}

/* Footer logo */
.footer-logo-box{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:230px !important;
  max-width:80vw !important;
  height:62px !important;
  padding:6px 12px !important;
  margin:0 auto 16px !important;
  background:#ffffff !important;
  border-radius:20px !important;
  box-shadow:0 10px 28px rgba(0,0,0,.18) !important;
  overflow:hidden !important;
}
.footer-logo-box img{
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
  display:block !important;
}

@media(max-width:980px){
  .nav{
    height:66px !important;
  }
  .brand-logo-box{
    width:170px !important;
    max-width:50vw !important;
    height:44px !important;
    padding:4px 8px !important;
  }
  .hero{
    padding-top:66px !important;
  }
  .page-main{
    padding-top:66px !important;
  }
  .project-hero,
  .service-hero{
    padding-top:64px !important;
    padding-bottom:36px !important;
  }
  .project-content{
    padding-top:18px !important;
  }
  .premium-band{
    padding-top:24px !important;
  }
  .links{
    background:#ffffff !important;
    border:1px solid rgba(8,124,255,.18) !important;
  }
  .links a{
    color:#07101f !important;
  }
}
@media(max-width:420px){
  .brand-logo-box{
    width:158px !important;
    max-width:48vw !important;
    height:40px !important;
    border-radius:18px !important;
  }
  .project-hero,
  .service-hero{
    padding-top:58px !important;
    padding-bottom:32px !important;
  }
  .project-content{
    padding-top:14px !important;
  }
  .detail-block{
    margin-top:6px !important;
  }
}


/* === FINAL: visible header logo + much tighter spacing === */
.mc-fixed-header{
  position:fixed !important;
  top:0 !important;
  left:0 !important;
  right:0 !important;
  z-index:99999 !important;
  height:66px !important;
  background:#ffffff !important;
  border-bottom:1px solid rgba(8,22,48,.10) !important;
  box-shadow:0 6px 20px rgba(8,22,48,.06) !important;
}
.mc-nav{
  height:66px !important;
  min-height:66px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
}
.mc-brand-logo{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:205px !important;
  max-width:44vw !important;
  height:46px !important;
  padding:4px 9px !important;
  background:#ffffff !important;
  border:1px solid rgba(8,22,48,.12) !important;
  border-radius:20px !important;
  box-shadow:0 6px 16px rgba(8,22,48,.08) !important;
  overflow:hidden !important;
  flex:0 0 auto !important;
  opacity:1 !important;
  visibility:visible !important;
}
.mc-brand-logo img{
  display:block !important;
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
  opacity:1 !important;
  visibility:visible !important;
}
.mc-menu{
  color:#07101f !important;
  background:rgba(7,16,31,.04) !important;
  border:1px solid rgba(8,22,48,.14) !important;
}

/* remove old logo conflicts */
.brand,.brand-logo-box,.brand-logo-horizontal,.mark{
  all:unset;
}

/* Tighter vertical rhythm sitewide */
.hero{
  padding-top:66px !important;
  padding-bottom:0 !important;
  margin-top:0 !important;
  min-height:auto !important;
}
.page-main{
  padding-top:66px !important;
}
.project-hero,
.service-hero{
  margin-top:0 !important;
  padding-top:58px !important;
  padding-bottom:30px !important;
}
.project-content{
  padding-top:12px !important;
  padding-bottom:34px !important;
}
.premium-band{
  padding-top:20px !important;
  padding-bottom:28px !important;
}
.section{
  padding-top:32px !important;
  padding-bottom:32px !important;
}
.detail-block{
  margin-top:6px !important;
  margin-bottom:12px !important;
  padding-top:22px !important;
  padding-bottom:22px !important;
}
.detail-grid{
  margin-top:12px !important;
  margin-bottom:12px !important;
  gap:14px !important;
}
.card,
.service,
.service-item,
.unique-card,
.step{
  padding-top:20px !important;
  padding-bottom:20px !important;
}
.section-title{
  margin-bottom:16px !important;
}
.projects{
  margin-top:12px !important;
  margin-bottom:22px !important;
}
.contact{
  margin-bottom:28px !important;
}

/* Footer logo */
.footer-logo-box{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:230px !important;
  max-width:80vw !important;
  height:62px !important;
  padding:6px 12px !important;
  margin:0 auto 14px !important;
  background:#ffffff !important;
  border-radius:20px !important;
  box-shadow:0 10px 28px rgba(0,0,0,.18) !important;
  overflow:hidden !important;
}
.footer-logo-box img{
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
  display:block !important;
}

@media(max-width:980px){
  .mc-fixed-header,
  .mc-nav{
    height:62px !important;
    min-height:62px !important;
  }
  .mc-brand-logo{
    width:184px !important;
    max-width:52vw !important;
    height:42px !important;
    border-radius:18px !important;
  }
  .hero{
    padding-top:62px !important;
  }
  .page-main{
    padding-top:62px !important;
  }
  .project-hero,
  .service-hero{
    padding-top:50px !important;
    padding-bottom:24px !important;
  }
  .project-content{
    padding-top:10px !important;
  }
  .premium-band{
    padding-top:16px !important;
    padding-bottom:24px !important;
  }
  .section{
    padding-top:26px !important;
    padding-bottom:26px !important;
  }
  .mc-links{
    background:#ffffff !important;
    border:1px solid rgba(8,124,255,.18) !important;
  }
  .mc-links a{
    color:#07101f !important;
  }
}
@media(max-width:420px){
  .mc-brand-logo{
    width:170px !important;
    max-width:50vw !important;
    height:40px !important;
    padding:3px 7px !important;
  }
  .mc-menu{
    width:40px !important;
    height:40px !important;
  }
  .project-hero,
  .service-hero{
    padding-top:44px !important;
    padding-bottom:22px !important;
  }
  .detail-block{
    padding-top:18px !important;
    padding-bottom:18px !important;
  }
}
