/*
Theme Name: ITFirm Child
Template: itfirm
Version: 1.0
*/

/* =========================================================
   PRO IT – HEADER STYLES
========================================================= */

:root{
  --navy:#0A1628;
  --navy-mid:#0E2040;
  --blue:#1565C0;
  --cyan:#00B4D8;
  --orange:#FF6B35;
  --white:#FFFFFF;
  --gray-200:#E2E8F0;
  --text-dark:#0D1B2A;

  --radius-sm:8px;
  --radius-md:14px;

  --shadow-md:0 8px 32px rgba(10,22,40,.12);
}

*,
*::before,
*::after{
  box-sizing:border-box;
}

body{
  font-family:'Poppins',sans-serif;
  overflow-x:hidden;
  padding-top:130px;
}

a{
  text-decoration:none;
  color:inherit;
}

/* =========================================================
   TOP BAR
========================================================= */

.header-topbar{
  background:var(--navy-mid);
  padding:8px 0;
  border-bottom:1px solid rgba(255,255,255,.06);
}

.topbar-inner{
  max-width:1200px;
  margin:0 auto;
  padding:0 24px;

  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:24px;
}

.topbar-link{
  display:flex;
  align-items:center;
  gap:6px;

  font-size:13px;
  font-weight:500;
  color:rgba(255,255,255,.7);

  transition:color .2s;
}

.topbar-link:hover{
  color:var(--cyan);
}

.topbar-sep{
  color:rgba(255,255,255,.2);
  font-size:12px;
}

/* =========================================================
   MAIN HEADER
========================================================= */

#site-header{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:1000;

  transition:all .3s ease;
}

#site-header.scrolled .header-topbar{
  display:none;
}

#site-header.scrolled .header-main{
  background:rgba(10,22,40,.97);
  backdrop-filter:blur(12px);
  box-shadow:0 4px 24px rgba(0,0,0,.3);
}

.header-main{
  padding:18px 0;
  transition:all .3s ease;
  background:var(--navy);
}

.header-inner{
  max-width:1200px;
  margin:0 auto;
  padding:0 24px;

  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}

/* =========================================================
   LOGO
========================================================= */

.site-logo{
  display:flex;
  align-items:center;
  gap:10px;
}

.site-logo img{
  height:44px;
  width:auto;
  display:block;
}

.logo-fallback{
  display:flex;
  align-items:center;
  gap:10px;
}

.logo-mark{
  width:40px;
  height:40px;

  background:var(--orange);
  border-radius:10px;

  display:flex;
  align-items:center;
  justify-content:center;

  font-weight:800;
  font-size:16px;
  color:var(--white);

  flex-shrink:0;
}

.logo-text{
  font-weight:700;
  font-size:20px;
  color:var(--white);
}

.logo-text span{
  color:var(--cyan);
}

/* =========================================================
   DESKTOP NAV
========================================================= */

#primary-nav ul{
  display:flex;
  align-items:center;
  gap:2px;
  list-style:none;
}

#primary-nav ul li{
  position:relative;
}

#primary-nav ul li a{
  padding:8px 12px;

  font-size:13px;
  font-weight:500;
  color:rgba(255,255,255,.8);

  border-radius:var(--radius-sm);
  transition:all .2s;
  white-space:nowrap;
}

#primary-nav ul li a:hover,
#primary-nav ul li.current-menu-item > a{
  color:var(--white);
  background:rgba(255,255,255,.08);
}

/* Dropdown */

#primary-nav ul li ul{
  display:none;

  position:absolute;
  top:100%;
  left:0;

  background:var(--navy-mid);
  border-radius:var(--radius-md);

  padding:8px;
  min-width:220px;

  box-shadow:var(--shadow-md);
  border:1px solid rgba(255,255,255,.07);
}

#primary-nav ul li:hover > ul{
  display:block;
}

#primary-nav ul li ul li a{
  display:block;
  padding:10px 14px;

  border-radius:var(--radius-sm);

  font-size:13px;
  color:rgba(255,255,255,.75);
}

#primary-nav ul li ul li a:hover{
  background:rgba(255,255,255,.06);
  color:var(--white);
}

/* =========================================================
   HEADER ACTIONS
========================================================= */

.header-actions{
  display:flex;
  align-items:center;
  gap:12px;
}

.header-phone{
  display:flex;
  align-items:center;
  gap:7px;

  color:rgba(255,255,255,.85);

  font-size:13px;
  font-weight:500;
}

.btn-header{
  display:inline-flex;
  align-items:center;
  gap:7px;

  padding:10px 20px;
  border-radius:50px;

  font-family:'Poppins',sans-serif;
  font-size:13px;
  font-weight:600;

  cursor:pointer;
  border:none;
  white-space:nowrap;

  transition:all .25s;
}

.btn-header-primary{
  background:var(--orange);
  color:var(--white);

  box-shadow:0 4px 16px rgba(255,107,53,.35);
}

.btn-header-primary:hover{
  background:#e85a25;
  transform:translateY(-1px);
}

/* =========================================================
   HAMBURGER
========================================================= */

.hamburger-btn{
  display:none;
  flex-direction:column;
  gap:5px;

  cursor:pointer;
  padding:8px;

  background:none;
  border:none;
}

.hamburger-btn span{
  display:block;
  width:24px;
  height:2px;

  background:var(--white);
  border-radius:2px;

  transition:all .3s;
}

.hamburger-btn.open span:nth-child(1){
  transform:translateY(7px) rotate(45deg);
}

.hamburger-btn.open span:nth-child(2){
  opacity:0;
  transform:scaleX(0);
}

.hamburger-btn.open span:nth-child(3){
  transform:translateY(-7px) rotate(-45deg);
}

/* =========================================================
   MOBILE NAV
========================================================= */

#mobile-nav{
  display:none;

  position:fixed;
  inset:0;
  z-index:999;

  flex-direction:column;
}

#mobile-nav.open{
  display:flex;
}

.mob-overlay{
  position:absolute;
  inset:0;

  background:rgba(5,12,25,.75);
  backdrop-filter:blur(4px);
}

.mob-drawer{
  position:relative;
  z-index:1;

  width:300px;
  max-width:90vw;
  height:100%;

  background:var(--navy-mid);

  padding:76px 0 40px;

  display:flex;
  flex-direction:column;

  box-shadow:4px 0 40px rgba(0,0,0,.4);

  animation:drawerIn .3s ease;
}

@keyframes drawerIn{
  from{
    transform:translateX(-100%);
  }
  to{
    transform:translateX(0);
  }
}

.mob-drawer ul{
  list-style:none;
  padding:0 24px;
  flex:1;
}

.mob-drawer ul li{
  border-bottom:1px solid rgba(255,255,255,.06);
}

.mob-drawer ul li a{
  display:block;
  padding:15px 0;

  font-size:15px;
  font-weight:600;

  color:rgba(255,255,255,.85);

  transition:color .2s;
}

.mob-drawer ul li a:hover{
  color:var(--cyan);
}

.mob-close-btn{
  position:absolute;
  top:18px;
  right:18px;

  width:36px;
  height:36px;

  border:none;
  border-radius:50%;

  background:rgba(255,255,255,.08);

  color:var(--white);
  font-size:20px;

  cursor:pointer;

  display:flex;
  align-items:center;
  justify-content:center;

  transition:background .2s;
}

.mob-close-btn:hover{
  background:rgba(255,255,255,.15);
}

.mob-footer{
  padding:20px 24px;
  border-top:1px solid rgba(255,255,255,.07);
}

.mob-cta-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;

  width:100%;
  padding:13px;

  background:var(--orange);
  color:var(--white);

  border:none;
  border-radius:50px;

  font-family:'Poppins',sans-serif;
  font-size:14px;
  font-weight:600;

  cursor:pointer;
  margin-bottom:12px;

  transition:all .25s;
}

.mob-cta-btn:hover{
  background:#e85a25;
}

.mob-phone-link{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;

  color:rgba(255,255,255,.6);

  font-size:14px;
  font-weight:500;

  padding:8px 0;

  transition:color .2s;
}

.mob-phone-link:hover{
  color:var(--cyan);
}

/* =========================================================
   POPUP MODAL
========================================================= */

#popup-overlay{
  position:fixed;
  inset:0;
  z-index:9999;

  background:rgba(0,0,0,.75);

  display:none;
  align-items:center;
  justify-content:center;

  padding:20px;
}

#popup-overlay.open{
  display:flex;
}

.popup-box{
  position:relative;

  width:100%;
  max-width:620px;

  background:#fff;
  border-radius:18px;

  padding:40px;
}

.popup-close{
  position:absolute;
  top:15px;
  right:15px;

  width:40px;
  height:40px;

  border:none;
  border-radius:50%;

  background:#f3f4f6;

  cursor:pointer;
  font-size:18px;
}

.popup-title{
  font-size:32px;
  line-height:1.2;
  margin-bottom:12px;
  color:#111827;
}

.popup-sub{
  color:#6b7280;
  margin-bottom:24px;
}

.popup-badge{
  display:inline-block;

  background:#EFF6FF;
  color:#2563EB;

  padding:8px 14px;
  border-radius:50px;

  font-size:13px;
  font-weight:600;

  margin-bottom:18px;
}

.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}

.fg{
  margin-bottom:18px;
}

.fg label{
  display:block;
  margin-bottom:8px;

  font-size:14px;
  font-weight:600;
  color:#111827;
}

.fg input,
.fg textarea,
.fg select{
  width:100%;
  padding:14px;

  border:1px solid #d1d5db;
  border-radius:10px;

  font-size:14px;
}

.fg textarea{
  min-height:120px;
  resize:vertical;
}

.popup-submit{
  width:100%;
  padding:15px;

  border:none;
  border-radius:50px;

  background:var(--orange);
  color:#fff;

  font-size:15px;
  font-weight:600;

  cursor:pointer;
}

.popup-note{
  margin-top:14px;
  text-align:center;
  color:#6b7280;
  font-size:13px;
}

#popup-success{
  display:none;
  text-align:center;
}

#popup-success.show{
  display:block;
}

.success-icon{
  width:70px;
  height:70px;

  margin:0 auto 20px;

  border-radius:50%;

  background:#dcfce7;
  color:#16a34a;

  display:flex;
  align-items:center;
  justify-content:center;
}

/* =========================================================
   RESPONSIVE
========================================================= */

@media(max-width:1024px){

  #primary-nav ul li a{
    padding:8px 9px;
    font-size:12px;
  }

}

@media(max-width:768px){

  body{
    padding-top:74px;
  }

  #primary-nav,
  .header-actions .header-phone,
  .header-actions .btn-header{
    display:none;
  }

  .hamburger-btn{
    display:flex;
  }

  .form-row{
    grid-template-columns:1fr;
  }

  .popup-box{
    padding:28px 22px;
  }

  .popup-title{
    font-size:24px;
  }

}

