/* ================================
   Code Five – Global styles
   ================================ */

:root{
  --bg:#ffffff;
  --text:#0f172a;
  --muted:#475569;
  --primary:#2563eb;
  --primary-2:#1e40af;
  --ring: rgba(37,99,235,.25);
  --card:#f8fafc;
  --border:#e5e7eb;
}

*{ box-sizing:border-box; }

html, body{
  margin:0;
  padding:0;
  height:100%;
}

/* ================================
   BODY + BACKGROUND LAYER (FIX)
   ================================ */

body{
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  line-height:1.6;
  background:transparent;
  position:relative;
}

/* Background image */
body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;

  background:
    linear-gradient(
      rgba(255,255,255,0.00),
      rgba(255,255,255,0.00)
    ),
    url("assets/CodeFiveSiteBackground.png");

  background-repeat:no-repeat;
  background-size:cover;
  background-position:center center;
}

/* All content above bg */
body > *{
  position:relative;
  z-index:1;
}

/* ================================
   Layout helpers
   ================================ */

.container{
  width:min(1100px, 92%);
  margin:auto;
}

/* ================================
   Sticky header + anchor fix
   ================================ */

html{
  scroll-behavior:smooth;
  scroll-padding-top:96px;
}

.section{
  scroll-margin-top:96px;
}

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

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid rgba(226,232,240,.8);
}

.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0.6rem 0;
  min-height:80px;
  column-gap:1.5rem;
}

.brand{
  display:flex;
  align-items:center;
  gap:.85rem;
}

.logo{
  width:clamp(60px, 8vw, 100px);
  height:auto;
}

.menu{
  display:flex;
  gap:1.1rem;
  font-size:.95rem;
}

.menu a{
  text-decoration:none;
  color:var(--muted);
  font-weight:500;
}

.menu a:hover{
  color:var(--text);
}

/* ================================
   Language switcher
   ================================ */

.lang-switcher{
  display:flex;
  gap:.4rem;
}

.lang-btn{
  border:1px solid var(--border);
  background:#fff;
  padding:.35rem .55rem;
  border-radius:.6rem;
  font-weight:600;
  cursor:pointer;
  font-size:.78rem;
}

.lang-btn:hover{
  border-color:var(--primary);
  box-shadow:0 0 0 3px var(--ring);
}

/* ================================
   HERO SECTION
   ================================ */

.hero{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:2rem;
  padding:3rem 0 2.5rem;
}

.hero h1{
  font-size:clamp(1.8rem,4vw,3rem);
  line-height:1.15;
  margin:0 0 .6rem;
}

.hero p{
  color:var(--muted);
  margin:0 0 1.2rem;
}

.cta{
  display:flex;
  gap:.8rem;
  flex-wrap:wrap;
}

/* ================================
   Buttons
   ================================ */

.btn{
  display:inline-block;
  padding:.8rem 1.1rem;
  border-radius:.85rem;
  text-decoration:none;
  font-weight:700;
  transition: transform .08s ease, box-shadow .12s ease;
}

.btn:active{ transform: translateY(1px); }

.btn.primary{
  background:var(--primary);
  color:#fff;
  box-shadow:0 10px 20px rgba(37,99,235,.12);
}

.btn.primary:hover{
  box-shadow:0 12px 26px rgba(37,99,235,.18);
}

.btn.outline{
  border:2px solid var(--primary);
  color:var(--primary);
  background:#fff;
}

.btn.link{
  color:var(--primary);
  font-weight:700;
}

/* White CTA button on dark background */
.btn.white{
  background:#fff;
  color:var(--primary-2);
  border:1px solid rgba(255,255,255,.65);
}

.btn.white:hover{
  box-shadow:0 0 0 3px rgba(255,255,255,.22);
}

/* ================================
   Cards / Sections
   ================================ */

.features{
  padding:2.2rem 0;
}

.features h2{
  margin-bottom:1rem;
}

.grid-3{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1rem;
}

.card{
  background:rgba(255,255,255,.92);
  border:1px solid var(--border);
  border-radius:1rem;
  padding:1rem;
  backdrop-filter:blur(6px);
}

.projects{
  padding:2rem 0 1rem;
}

.industries{
  padding:1rem 0 2rem;
}

/* ================================
   FlowBiz boxed section
   ================================ */

.flowbiz-box{
  border:1px solid rgba(37,99,235,.22);
  border-radius:1.2rem;
  background:rgba(255,255,255,.90);
  backdrop-filter: blur(8px);
  padding:1.25rem 1.25rem 1.1rem;
  box-shadow: 0 18px 40px rgba(15,23,42,.10);
}

.flowbiz-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  margin-bottom:.35rem;
}

.flowbiz-box h2{
  margin:.1rem 0;
}

.badge{
  display:inline-flex;
  align-items:center;
  padding:.35rem .6rem;
  border-radius:999px;
  font-weight:700;
  font-size:.78rem;
  color:var(--primary-2);
  background: rgba(37,99,235,.10);
  border:1px solid rgba(37,99,235,.18);
  white-space:nowrap;
}

.flowbiz-cta{
  display:flex;
  gap:.75rem;
  flex-wrap:wrap;
  margin-top:.9rem;
}

/* ================================
   WHY list with icons
   ================================ */

.why-list{
  list-style:none;
  padding:0;
  margin:1rem 0 0;
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:.75rem 1rem;
}

.why-item{
  display:flex;
  align-items:flex-start;
  gap:.65rem;
  padding:.75rem .85rem;
  border:1px solid var(--border);
  border-radius:1rem;
  background:rgba(255,255,255,.92);
  backdrop-filter: blur(6px);
}

.why-ic{
  width:34px;
  height:34px;
  border-radius:.85rem;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background: rgba(37,99,235,.10);
  border:1px solid rgba(37,99,235,.18);
  flex: 0 0 auto;
  margin-top:.05rem;
}

.why-ic svg{
  width:18px;
  height:18px;
  fill: var(--primary);
}

/* ================================
   Contact
   ================================ */

.contact{
  padding:2rem 0 3rem;
}

.contact-cta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  margin:1.1rem 0 1.1rem;
  padding:1.1rem 1.1rem;
  border-radius:1.2rem;
  background: linear-gradient(135deg, var(--primary-2), var(--primary));
  color:#fff;
  box-shadow: 0 18px 40px rgba(37,99,235,.22);
}

.contact-cta h3{
  margin:0 0 .25rem;
  font-size:1.15rem;
  letter-spacing:-0.01em;
}

.contact-cta p{
  margin:0;
  opacity:.92;
}

.contact-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:1.2rem;
}

.contact-form{
  background:rgba(255,255,255,.95);
  border:1px solid var(--border);
  border-radius:1rem;
  padding:.5rem;
}

.contact-form iframe{
  width:100%;
  height:860px;
  border:0;
  border-radius:.7rem;
  background:#fff;
}

.contact-aside{
  background:rgba(255,255,255,.92);
  border:1px solid var(--border);
  border-radius:1rem;
  padding:1rem;
  backdrop-filter: blur(6px);
}

/* ================================
   Footer
   ================================ */

.site-footer{
  border-top:1px solid var(--border);
  background:#fff;
}

.foot{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:1rem 0;
  color:var(--muted);
}

.socials a{
  margin-left:1rem;
  color:var(--muted);
  text-decoration:none;
}

.socials a:hover{
  color:var(--text);
}

/* ================================
   Hero SVG
   ================================ */

.hero-art{
  display:flex;
  align-items:center;
  justify-content:center;
}

.hero-svg{
  width:min(420px, 100%);
  color:rgba(37,99,235,.65);
}

/* ================================
   Responsive
   ================================ */

@media (max-width:900px){
  .nav{ flex-wrap:wrap; row-gap:.4rem; }

  .menu{
    order:3;
    width:100%;
    justify-content:center;
    flex-wrap:wrap;
    gap:.9rem;
  }

  .lang-switcher{ margin-left:auto; }

  .hero{ grid-template-columns:1fr; }
  .contact-grid{ grid-template-columns:1fr; }
  .grid-3{ grid-template-columns:1fr; }

  .why-list{
    grid-template-columns: 1fr;
  }

  html{ scroll-padding-top:110px; }
  .section{ scroll-margin-top:110px; }

  .contact-form iframe{
    height: 980px;
  }

  .contact-cta{
    flex-direction:column;
    align-items:flex-start;
  }
}
