/* Studio Mendicino - Design System */
:root{
  --bg:#0d0f12;
  --bg-2:#15181d;
  --yellow:#f5b417;
  --yellow-2:#ffc83a;
  --white:#ffffff;
  --light:#f6f5f1;
  --muted:#a8a8a8;
  --text:#1a1a1a;
  --text-light:#5a5a5a;
  --border:rgba(255,255,255,.12);
  --maxw:1500px;
  --font-display:'Barlow Condensed',sans-serif;
  --font-body:'Inter',sans-serif;
  --font-script:'Dancing Script',cursive;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--text);background:#fff;line-height:1.55;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* Header */
.site-header{
  position:absolute;
  top:0;
  left:0;
  right:0;
  z-index:10000;
  background:transparent;
}

.page-chi-siamo .site-header,
.page-servizi .site-header,
.page-formazione .site-header,
.page-progetti .site-header,
.page-news .site-header,
.page-contatti .site-header,
.page-progettazione .site-header{
  position:relative;
  background:#0d0f12;
}

.header-inner{
  display:grid;
  grid-template-columns:340px minmax(0,1fr) auto;
  align-items:center;
  gap:28px;
  padding:18px 24px;
}

.logo{
  display:flex;
  align-items:center;
  width:340px;
  min-width:0;
}

.logo-img{
  display:block;
  width:320px;
  max-width:100%;
  height:auto;
  max-height:78px;
  object-fit:contain;
  object-position:left center;
}

.main-nav{
  min-width:0;
}

.main-nav ul{
  display:flex;
  justify-content:flex-end;
  align-items:center;
  gap:clamp(18px,2vw,34px);
  list-style:none;
  flex-wrap:nowrap;
}

.main-nav li,
.main-nav a{
  white-space:nowrap;
}

.main-nav a{
  color:#fff;
  font-weight:500;
  font-size:13px;
  letter-spacing:1px;
  padding:8px 0;
  position:relative;
  transition:color .2s;
}

.main-nav a:hover,
.main-nav a.active{
  color:var(--yellow);
}

.main-nav a.active::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-4px;
  height:2px;
  background:var(--yellow);
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:14px 26px;
  font-family:var(--font-body);
  font-weight:700;
  font-size:13px;
  letter-spacing:1px;
  border:none;
  cursor:pointer;
  transition:all .25s;
  text-transform:uppercase;
  border-radius:2px;
  line-height:1.2;
}

.btn-primary{
  background:var(--yellow);
  color:#0d0f12;
}

.btn-primary:hover{
  background:var(--yellow-2);
  transform:translateY(-1px);
}

.btn-outline{
  background:transparent;
  color:#fff;
  border:1px solid #fff;
}

.btn-outline:hover{
  background:#fff;
  color:#0d0f12;
}

.btn-outline-dark{
  background:transparent;
  color:#0d0f12;
  border:1px solid #0d0f12;
}

.btn-outline-dark:hover{
  background:#0d0f12;
  color:#fff;
}

.btn-dark{
  background:#0d0f12;
  color:#fff;
}

.btn-dark:hover{
  background:#000;
}

.header-cta{
  justify-self:end;
  white-space:nowrap;
  min-width:210px;
}

.hamburger{
  display:none;
  background:none;
  border:none;
  flex-direction:column;
  gap:5px;
  cursor:pointer;
  z-index:10001;
}

.hamburger span{
  width:26px;
  height:2px;
  background:#fff;
}

/* Hero */
.hero{position:relative;min-height:720px;background:#0d0f12;color:#fff;overflow:visible;padding-top:120px;padding-bottom:70px}
.hero-bg{position:absolute;inset:0;background:url('../images/hero.jpg') center right/cover no-repeat}
.hero-bg::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,#0d0f12 0%,#0d0f12cc 35%,transparent 70%)}
.hero-inner{position:relative;z-index:2;padding:60px 0 80px;max-width:var(--maxw);margin:0 auto;padding-left:24px;padding-right:24px}
.hero-script{font-family:var(--font-script);color:var(--yellow);font-size:42px;font-weight:500;line-height:1}
.hero h1{font-family:var(--font-display);font-size:clamp(64px,9vw,128px);font-weight:800;letter-spacing:2px;line-height:.95;margin-top:8px}
.hero-sub{font-family:var(--font-display);font-weight:600;letter-spacing:4px;font-size:16px;margin-top:18px;color:#fff}
.hero-desc{max-width:480px;color:#cfcfcf;margin-top:24px;font-size:15px}
.hero-actions{display:flex;gap:18px;margin-top:36px;flex-wrap:wrap}
.hero-features{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:0 24px 60px;display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid rgba(255,255,255,.18);}
.hero-features-wrap{position:relative;z-index:2;max-width:var(--maxw);margin:40px auto 0;padding:0 24px;transform:none}
.hf-grid{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid rgba(255,255,255,.18);background:#0d0f12}
.hf{display:flex;align-items:center;gap:14px;padding:22px 20px;border-right:1px solid rgba(255,255,255,.15)}
.hf:last-child{border-right:none}
.hf-icon{width:42px;height:42px;color:var(--yellow);flex-shrink:0}
.hf strong{display:block;font-family:var(--font-display);font-weight:700;letter-spacing:1.5px;font-size:14px;color:#fff}
.hf span{display:block;font-size:11.5px;color:#bdbdbd;line-height:1.45;margin-top:4px}

/* Mission section */
.mission{background:#fff;padding:140px 0 80px}
.mission-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:0;align-items:stretch}
.mission-left{padding-right:48px}
.eyebrow{color:var(--yellow);font-weight:700;font-size:12px;letter-spacing:3px;margin-bottom:16px;text-transform:uppercase}
.mission h2{font-family:var(--font-display);font-size:38px;line-height:1.1;font-weight:700;letter-spacing:1px;margin-bottom:24px}
.mission p{color:var(--text-light);font-size:14.5px;margin-bottom:18px}
.mission-img{background:url('../images/building.jpg') center/cover;min-height:380px;position:relative}
.mission-card{background:#0d0f12;color:#fff;padding:40px;display:flex;flex-direction:column;justify-content:center}
.mission-card h3{font-family:var(--font-display);color:var(--yellow);font-size:14px;letter-spacing:3px;margin-bottom:18px}
.mission-card p{color:#cfcfcf;font-size:14px;margin-bottom:14px}
.mission-card .signature{font-family:var(--font-script);color:var(--yellow);font-size:26px;margin-top:20px}
.mission-card .role{color:#bdbdbd;font-size:12px;margin-bottom:24px}
.mission-bottom{display:grid;grid-template-columns:1fr 1fr;margin-top:0}

/* Services */
.services-section{background:var(--light);padding:90px 0}
.services-section h2{font-family:var(--font-display);font-size:42px;font-weight:700;letter-spacing:1px;line-height:1.05;margin-bottom:50px}
.services-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.service-card{background:#fff;display:flex;flex-direction:column;box-shadow:0 4px 20px rgba(0,0,0,.05);transition:transform .25s,box-shadow .25s}
.service-card:hover{transform:translateY(-6px);box-shadow:0 12px 30px rgba(0,0,0,.12)}
.service-img{position:relative;aspect-ratio:4/3;background-size:cover;background-position:center}
.service-icon{position:absolute;left:16px;bottom:-16px;width:44px;height:44px;background:var(--yellow);display:flex;align-items:center;justify-content:center;color:#0d0f12}
.service-body{padding:30px 22px 24px}
.service-body h3{font-family:var(--font-display);font-size:18px;font-weight:700;letter-spacing:1px;margin-bottom:14px;line-height:1.2}
.service-body ul{list-style:none;padding:0;margin:0 0 18px}
.service-body ul li{position:relative;padding-left:14px;font-size:13px;color:var(--text-light);margin-bottom:8px}
.service-body ul li::before{content:"•";color:var(--yellow);position:absolute;left:0;font-weight:700}
.service-link{font-size:12px;font-weight:600;letter-spacing:1.5px;color:#0d0f12;display:inline-flex;align-items:center;gap:8px;padding-top:14px;border-top:1px solid #eee;margin-top:auto}
.service-link:hover{color:var(--yellow)}

/* Highlight strip */
.highlight-strip{display:grid;grid-template-columns:repeat(6,1fr);background:#fff}
.hs-img{aspect-ratio:1/1;background-size:cover;background-position:center}
.hs-text{padding:30px 24px;background:#fff;display:flex;flex-direction:column;justify-content:center}
.hs-text h4{font-family:var(--font-display);font-size:18px;letter-spacing:1px;margin-bottom:10px;line-height:1.2}
.hs-text p{font-size:13px;color:var(--text-light);margin-bottom:14px}
.hs-text a{font-size:11px;font-weight:700;letter-spacing:1.5px;color:#0d0f12}
.hs-text a:hover{color:var(--yellow)}

/* Footer */
.site-footer{margin-top:0}
.footer-main{background:var(--yellow);color:#0d0f12;padding:60px 0;background-image:linear-gradient(90deg,#1a1d22 0%,#1a1d22 33%,var(--yellow) 33%,var(--yellow) 100%)}
.footer-grid{display:grid;grid-template-columns:1.2fr 1.4fr 1fr;gap:50px;align-items:start}
.footer-brand{color:#fff;padding-right:40px}
.footer-brand p{font-size:13px;color:#bdbdbd;margin-top:18px;line-height:1.6}
.footer-contact h4,.footer-cta h4{font-family:var(--font-display);font-size:18px;letter-spacing:2px;margin-bottom:18px;color:#0d0f12}
.footer-contact ul{list-style:none}
.footer-contact li{font-size:13px;margin-bottom:14px;display:flex;gap:8px}
.footer-contact .ic{color:#0d0f12;font-weight:700}
.footer-cta p{font-size:13px;margin-bottom:18px}
.footer-bottom{background:#0a0c10;color:#888;padding:18px 0;font-size:12px}
.footer-bottom .container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
.footer-bottom a{color:#bbb;margin-right:10px}

/* Inner page hero */
.page-hero{
  position:relative;
  min-height:auto;
  background:#0d0f12;
  color:#fff;
  display:block;
  overflow:hidden;
}

.page-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,#0d0f12 0%,#0d0f12cc 50%,transparent 100%);
  z-index:2;
  pointer-events:none;
}

.page-hero-bg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
}

.page-hero > .container{
  position:relative;
  z-index:3;
  padding-top:90px;
  padding-bottom:88px;
  text-align:center;
}

.page-hero h1{
  font-family:var(--font-display);
  font-size:64px;
  font-weight:700;
  letter-spacing:2px;
  line-height:1;
}

.page-hero p{
  color:#cfcfcf;
  margin:14px auto 0;
  max-width:560px;
  font-size:15px;
}

.breadcrumb{
  position:relative;
  z-index:4;
  background:#fff;
  color:#666;
  font-size:12px;
  padding:18px 0;
}

.breadcrumb a{
  color:var(--yellow);
  font-weight:600;
}

/* Generic page sections */
.section{padding:80px 0}
.section h2{font-family:var(--font-display);font-size:34px;letter-spacing:1px;margin-bottom:30px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.list-check{list-style:none;padding:0}
.list-check li{position:relative;padding:8px 0 8px 28px;border-bottom:1px solid #eee;font-size:14px}
.list-check li::before{content:"✓";position:absolute;left:0;color:var(--yellow);font-weight:700}

.value-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center;margin-top:40px}
.value{padding:24px}
.value .ic{width:60px;height:60px;margin:0 auto 16px;color:var(--yellow);display:flex;align-items:center;justify-content:center;border:1px solid #ddd;border-radius:50%}
.value h4{font-family:var(--font-display);font-size:14px;letter-spacing:2px;margin-bottom:8px}

.dark-block{background:#0d0f12;color:#fff;padding:50px}
.dark-block h3{font-family:var(--font-display);color:var(--yellow);font-size:14px;letter-spacing:3px;margin-bottom:18px}
.dark-block h2{color:#fff;font-size:28px}
.dark-block p{color:#cfcfcf;font-size:14px;margin-bottom:14px}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr 1fr;gap:30px;margin-top:30px}
.contact-card{background:#fff;padding:30px;border:1px solid #eee}
.contact-card h3{font-family:var(--font-display);font-size:14px;letter-spacing:2px;color:var(--yellow);margin-bottom:18px}
.contact-card p{font-size:14px;margin-bottom:12px;display:flex;gap:10px;align-items:flex-start}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid input,.form-grid textarea{grid-column:span 2;padding:14px;border:1px solid #ddd;font-family:inherit;font-size:14px;background:#fafafa}
.form-grid input.half{grid-column:span 1}
.form-grid textarea{min-height:120px;resize:vertical}
.form-grid button{grid-column:span 2;background:var(--yellow);border:none;padding:16px;font-weight:700;letter-spacing:2px;cursor:pointer;color:#0d0f12;font-size:13px}
.form-grid button:hover{background:var(--yellow-2)}
.map-card{background:#e9e9e9;min-height:200px;background:url('https://maps.googleapis.com/maps/api/staticmap?center=Rome&zoom=13&size=400x300') center/cover;display:flex;align-items:center;justify-content:center;color:#999}
.hours{padding:30px;background:#fafafa}
.hours h4{font-family:var(--font-display);letter-spacing:2px;font-size:14px;margin-bottom:10px}

@media (max-width: 1180px){
  .header-inner{
    grid-template-columns:300px minmax(0,1fr) auto;
    gap:22px;
  }

  .logo{width:300px}
  .logo-img{width:280px}

  .main-nav ul{
    gap:20px;
  }

  .main-nav a{
    font-size:12px;
    letter-spacing:.8px;
  }

  .header-cta{
    min-width:auto;
    padding:13px 20px;
  }
}

@media (max-width: 980px){
  .header-inner{
    display:flex;
    position:relative;
    justify-content:space-between;
    gap:18px;
  }

  .logo{
    width:auto;
  }

  .logo-img{
    width:230px;
    height:auto;
    max-height:62px;
  }

  .main-nav{
    display:none;
  }

  .main-nav.open{
    display:block;
    position:absolute;
    top:100%;
    left:0;
    right:0;
    z-index:9999;
    background:#0d0f12;
    padding:22px 24px;
    border-top:1px solid rgba(255,255,255,.12);
  }

  .main-nav.open ul{
    flex-direction:column;
    align-items:flex-start;
    gap:14px;
  }

  .hamburger{
    display:flex;
  }

  .header-cta{
    display:none;
  }

  .hero{
    min-height:auto;
    padding-top:110px;
    padding-bottom:40px;
  }

  .hero h1{
    font-size:64px;
  }

  .hero-features-wrap{
    transform:none;
    margin-top:30px;
    padding:0 24px;
  }

  .hf-grid{
    grid-template-columns:1fr 1fr;
  }

  .hf{
    border-right:none;
    border-bottom:1px solid rgba(255,255,255,.15);
  }

  .mission{
    padding:90px 0 60px;
  }

  .mission-grid,
  .two-col,
  .contact-grid{
    grid-template-columns:1fr;
  }

  .mission-left{
    padding-right:0;
    margin-bottom:30px;
  }

  .mission-bottom{
    grid-template-columns:1fr;
  }

  .services-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .highlight-strip{
    grid-template-columns:1fr 1fr;
  }

  .footer-grid{
    grid-template-columns:1fr;
    gap:30px;
  }

  .footer-main{
    background:#1a1d22;
  }

  .footer-contact h4,
  .footer-cta h4{
    color:var(--yellow);
  }

  .footer-contact li,
  .footer-cta p{
    color:#cfcfcf;
  }

  .footer-contact .ic{
    color:var(--yellow);
  }

  .value-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .page-hero > .container{
    padding-top:70px;
    padding-bottom:70px;
  }

  .page-hero h1{
    font-size:42px;
  }
}

@media (max-width: 520px){
  .container{
    padding:0 18px;
  }

  .header-inner{
    padding:14px 18px;
  }

  .logo-img{
    width:185px;
    max-height:52px;
  }

  .hero{
    padding-top:100px;
    padding-bottom:32px;
  }

  .hero-inner{
    padding:40px 18px 45px;
  }

  .hero-script{
    font-size:34px;
  }

  .hero h1{
    font-size:48px;
  }

  .hero-sub{
    font-size:13px;
    letter-spacing:2px;
  }

  .hero-desc{
    font-size:14px;
  }

  .hero-actions{
    flex-direction:column;
    align-items:flex-start;
  }

  .hf-grid,
  .services-grid,
  .highlight-strip,
  .value-grid{
    grid-template-columns:1fr;
  }

  .page-hero > .container{
    padding-top:56px;
    padding-bottom:56px;
  }

  .page-hero h1{
    font-size:36px;
  }

  .section{
    padding:60px 0;
  }

  .dark-block{
    padding:32px 24px;
  }

  .form-grid input.half{
    grid-column:span 2;
  }
}
