/*
Theme Name: ACL ARCHITECT
Author: Focus Web
Version: 0.1.1
Text Domain: acl-architect
*/

:root{
  --header-bg:#474747;
  --header-h:120px;
  --container:1200px;
  --text:rgba(255,255,255,.92);
  --muted:rgba(255,255,255,.72);
  --accent:#f28a1a;
}

*{box-sizing:border-box;}

body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
}

/* =======================================================
   HEADER
======================================================= */

.site-header{
  background:var(--header-bg);
  color:var(--text);
  min-height:var(--header-h);
}

.header-inner{
  max-width:var(--container);
  margin:0 auto;
  padding:18px 28px;
  min-height:var(--header-h);
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:24px;
}

/* =======================================================
   BRAND
======================================================= */

.brand{
  display:flex;
  align-items:flex-start;
  gap:18px;
  min-width:420px;
}

.brand-logo img{
  display:block;
  height:78px;
  width:auto;
}

.brand-fallback{
  color:#fff;
  text-decoration:none;
  font-weight:800;
  font-size:28px;
}

.brand-meta{line-height:1.15;padding-top:6px;}

.brand-tagline{
  font-size:26px;
  letter-spacing:.02em;
  color:var(--accent);
  margin-bottom:10px;
}

.brand-contact{
  font-size:12.5px;
  color:var(--muted);
}

.brand-contact a{
  color:var(--accent);
  text-decoration:none;
}

.brand-contact-row{
  display:flex;
  align-items:center;
  gap:10px;
  margin-top:3px;
}

.dot{color:rgba(255,255,255,.35);}

/* =======================================================
   NAVIGATION
======================================================= */
a {
color: white;
}
.nav{margin-left:auto;}

.nav-list{
  list-style:none;
  display:flex;
  align-items:center;
  gap:42px;
  margin:0;
  padding:0 10px 10px 0;
}

/* ===== FORCE ABSOLUE LIENS HEADER ===== */

.site-header a,
.site-header a:link,
.site-header a:visited,
.site-header a:hover,
.site-header a:active,
.site-header a:focus{
  color:#fff !important;
  text-decoration:none !important;
}

/* Menu principal */

.nav-list > li > a{
  font-size:16px;
  letter-spacing:.06em;
  text-transform:uppercase;
  opacity:.95;
  padding:8px 2px;
  transition:opacity .2s ease;
}

.nav-list > li > a:hover{
  opacity:1;
  color:#fff !important;
}

/* Active item orange */

.nav-list .current-menu-item > a{
  color:var(--accent) !important;
  opacity:1;
}

/* =======================================================
   DROPDOWN
======================================================= */

.nav-list .menu-item{
  position:relative;
}

.nav-list .menu-item-has-children > a::after{
  content:'';
  display:inline-block;
  width:0;
  height:0;
  margin-left:6px;
  border-left:4px solid transparent;
  border-right:4px solid transparent;
  border-top:4px solid currentColor;
  opacity:.7;
  vertical-align:middle;
}

.nav-list .sub-menu{
  display:none;
  position:absolute;
  top:100%;
  left:0;
	color: white !important;
  background:#4a4a4a;
  border-top:2px solid var(--accent);
  min-width:280px;
  padding:8px 0;
  margin-top:8px;
  list-style:none;
  z-index:1000;
  box-shadow:0 4px 12px rgba(0,0,0,0.3);
}

.nav-list .menu-item-has-children:hover > .sub-menu{
  display:block;
}

.nav-list .sub-menu li{
  margin:0;
  padding:0;
}

.nav-list .sub-menu a{
  display:block;
  padding:12px 24px;
  font-size:14px;
  text-transform:none;
  letter-spacing:.02em;
  opacity:.9;
  transition:all .2s ease;
  color:white !important;

}

.nav-list .sub-menu a:hover{
  background:rgba(255,255,255,0.08);
  padding-left:28px;
  color:#fff !important;
}

/* =======================================================
   RESPONSIVE
======================================================= */

@media (max-width:980px){
  .header-inner{
    align-items:flex-start;
    flex-direction:column;
  }
  .nav-list{
    gap:22px;
    padding:6px 0 0 0;
    flex-wrap:wrap;
  }
}

@media (max-width:900px){
  .header-inner{
    flex-direction:column;
    align-items:flex-start;
    gap:14px;
    padding:18px 16px;
  }
  .brand{
    min-width:0;
    width:100%;
  }
  .nav-list{
    flex-wrap:wrap;
    gap:16px;
  }
}

#primary{
  width:100%;
  max-width:100%;
}

/* =======================================================
   FOOTER
======================================================= */

.site-footer{
  background:#3a3a3a;
  color:rgba(255,255,255,0.85);
  padding:20px 0;
  text-align:center;
  font-size:13px;
}

.footer-inner{
  max-width:var(--container);
  margin:0 auto;
  padding:0 28px;
}

.site-footer small{
  line-height:1.6;
}

.footer-link{
  color:var(--accent);
  text-decoration:none;
  transition:opacity .2s ease;
}

.footer-link:hover{
  opacity:.8;
  text-decoration:underline;
}

@media (max-width:600px){
  .site-footer{
    font-size:12px;
    padding:16px 0;
  }
  .footer-inner{
    padding:0 16px;
  }
}
