@import url('https://fonts.googleapis.com/css2?family=Familjen+Grotesk:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

*{box-sizing:border-box;margin:0;padding:0;}

:root{
  --navy:#0b1628;
  --navy2:#0f1e38;
  --navy3:#162540;
  --amber:#f5a623;
  --amber2:#e8950f;
  --amber-light:#fff8ec;
  --white:#ffffff;
  --offwhite:#f7f5f0;
  --gray:#8a9ab5;
  --gray2:#e8edf5;
  --text:#0b1628;
  --text2:#4a5568;
  --display:'Familjen Grotesk',sans-serif;
  --body:'Familjen Grotesk',sans-serif;
}

html{scroll-behavior:smooth;}

body{
  background:var(--offwhite);
  color:var(--text);
  font-family:var(--body);
  font-size:15px;
  line-height:1.65;
}

/* NAV */
nav{
  position:sticky;top:0;z-index:200;
  background:rgba(11,22,40,0.97);
  -webkit-backdrop-filter:blur(12px);
  backdrop-filter:blur(12px);
  padding:0 2.5rem;
  height:60px;
  display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid rgba(245,166,35,0.15);
}

.nav-brand{
  display:flex;align-items:center;gap:10px;
  text-decoration:none;
}

.nav-logo-mark{
  width:60px;height:60px;
  object-fit:contain;
  flex-shrink:0;
}

.nav-brand-text{
  font-family:var(--display);
  font-weight:700;
  font-size:17px;
  color:var(--white);
  letter-spacing:-0.3px;
}

.nav-brand-text span{color:var(--amber);}

.nav-links{
  display:flex;gap:2rem;list-style:none;
}

.nav-links a{
  color:rgba(255,255,255,0.6);
  text-decoration:none;
  font-size:13px;
  letter-spacing:0.04em;
  text-transform:uppercase;
  font-weight:500;
  transition:color 0.2s;
}
.nav-links a:hover{color:var(--amber);}

.nav-cta{
  padding:8px 20px;
  background:var(--amber);
  color:var(--navy);
  font-family:var(--body);
  font-size:13px;
  font-weight:600;
  text-decoration:none;
  border-radius:4px;
  letter-spacing:0.02em;
  transition:background 0.2s;
}
.nav-cta:hover{background:var(--amber2);}

/* HERO */
.hero{
  background:var(--navy);
  min-height:92vh;
  display:flex;align-items:center;
  position:relative;
  overflow:hidden;
  padding:5rem 2.5rem;
}

.hero::before{
  content:'';
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(245,166,35,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(245,166,35,0.06) 1px, transparent 1px);
  background-size:60px 60px;
}

.hero::after{
  content:'';
  position:absolute;
  right:-10%;top:-20%;
  width:700px;height:700px;
  background:radial-gradient(circle, rgba(245,166,35,0.12) 0%, transparent 65%);
  border-radius:50%;
}

.hero-inner{
  max-width:1000px;margin:0 auto;
  position:relative;z-index:1;
}

.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(245,166,35,0.12);
  border:1px solid rgba(245,166,35,0.25);
  border-radius:100px;
  padding:5px 14px;
  font-size:12px;
  font-weight:500;
  color:var(--amber);
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin-bottom:1.75rem;
}

.hero-eyebrow::before{
  content:'';
  width:6px;height:6px;
  border-radius:50%;
  background:var(--amber);
  animation:blink 2s ease-in-out infinite;
}

@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}

.hero-headline{
  font-family:var(--display);
  font-size:clamp(3rem,6vw,5.5rem);
  font-weight:700;
  line-height:1.05;
  letter-spacing:-2px;
  color:var(--white);
  margin-bottom:1.5rem;
}

.hero-headline .line2{color:var(--amber);}

.hero-sub{
  font-size:clamp(1rem,2vw,1.2rem);
  color:rgba(255,255,255,0.6);
  max-width:560px;
  margin-bottom:2.5rem;
  line-height:1.75;
}

.hero-actions{
  display:flex;gap:14px;flex-wrap:wrap;
  margin-bottom:4rem;
}

.btn-primary{
  padding:13px 28px;
  background:var(--amber);
  color:var(--navy);
  font-family:var(--body);
  font-size:14px;
  font-weight:600;
  text-decoration:none;
  border-radius:4px;
  transition:background 0.2s,transform 0.15s;
  display:inline-block;
}
.btn-primary:hover{background:var(--amber2);transform:translateY(-1px);}

.btn-outline{
  padding:12px 28px;
  background:transparent;
  color:var(--white);
  font-family:var(--body);
  font-size:14px;
  font-weight:500;
  text-decoration:none;
  border:1px solid rgba(255,255,255,0.25);
  border-radius:4px;
  transition:border-color 0.2s,color 0.2s;
  display:inline-block;
}
.btn-outline:hover{border-color:var(--amber);color:var(--amber);}

.hero-stats{
  display:flex;gap:3rem;flex-wrap:wrap;
  padding-top:3rem;
  border-top:1px solid rgba(255,255,255,0.1);
}

.hero-stat-num{
  font-family:var(--display);
  font-size:2.2rem;
  font-weight:700;
  color:var(--amber);
  line-height:1;
  margin-bottom:4px;
}

.hero-stat-label{
  font-size:12px;
  color:rgba(255,255,255,0.45);
  letter-spacing:0.06em;
  text-transform:uppercase;
}

/* SECTION COMMON */
section{padding:5rem 2.5rem;}
.section-inner{max-width:1000px;margin:0 auto;}

.label{
  display:inline-block;
  font-size:11px;
  font-weight:600;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--amber2);
  margin-bottom:0.75rem;
}

.label.accent{
  color:rgba(245,166,35,0.8);
}

h2.title{
  font-family:var(--display);
  font-size:clamp(2rem,4vw,3rem);
  font-weight:700;
  letter-spacing:-1px;
  line-height:1.1;
  color:var(--navy);
  margin-bottom:1rem;
}

h2.title.light{color:var(--white);}

.subtitle{
  font-size:1.05rem;
  color:var(--text2);
  max-width:560px;
  line-height:1.75;
  margin-bottom:3rem;
}

.subtitle.light{color:rgba(255,255,255,0.6);}

/* DIVISIONS */
.divisions-bg{background:var(--white);}

.divisions-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:1.25rem;
}

.div-card{
  background:var(--offwhite);
  border:1px solid var(--gray2);
  border-radius:8px;
  padding:1.75rem;
  position:relative;
  overflow:hidden;
  transition:border-color 0.2s,transform 0.2s,box-shadow 0.2s;
  cursor:default;
}

.div-card:hover{
  border-color:var(--amber);
  transform:translateY(-3px);
  box-shadow:0 12px 32px rgba(11,22,40,0.08);
}

.div-card::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:3px;
  background:var(--amber);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform 0.25s;
}

.div-card:hover::before{transform:scaleX(1);}

.div-icon{
  width:44px;height:44px;
  background:var(--amber-light);
  border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:20px;
  margin-bottom:1rem;
}

.div-name{
  font-family:var(--display);
  font-size:1.1rem;
  font-weight:700;
  color:var(--navy);
  margin-bottom:0.2rem;
}

.div-tagline{
  font-size:12px;
  font-weight:500;
  color:var(--amber2);
  letter-spacing:0.06em;
  text-transform:uppercase;
  margin-bottom:0.75rem;
}

.div-desc{
  font-size:13px;
  color:var(--text2);
  line-height:1.65;
  margin-bottom:1rem;
}

.div-services{
  display:flex;flex-wrap:wrap;gap:6px;
}

.div-tag{
  font-size:11px;
  padding:3px 9px;
  background:var(--white);
  border:1px solid var(--gray2);
  border-radius:100px;
  color:var(--text2);
}

.div-badge{
  position:absolute;top:1.25rem;right:1.25rem;
  font-size:10px;
  font-weight:600;
  padding:3px 8px;
  border-radius:100px;
  background:rgba(245,166,35,0.12);
  color:var(--amber2);
  border:1px solid rgba(245,166,35,0.25);
  letter-spacing:0.06em;
  text-transform:uppercase;
}

/* APPROACH */
.approach-bg{background:var(--navy);}

.approach-steps{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(160px,1fr));
  gap:1rem;
}

.step{
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:8px;
  padding:1.5rem;
  transition:background 0.2s,border-color 0.2s;
}

.step:hover{
  background:rgba(245,166,35,0.07);
  border-color:rgba(245,166,35,0.3);
}

.step-num{
  font-family:var(--display);
  font-size:2rem;
  font-weight:700;
  color:rgba(245,166,35,0.2);
  line-height:1;
  margin-bottom:0.5rem;
}

.step-name{
  font-family:var(--display);
  font-size:1rem;
  font-weight:600;
  color:var(--white);
  margin-bottom:0.4rem;
}

.step-desc{
  font-size:12px;
  color:rgba(255,255,255,0.45);
  line-height:1.6;
}

/* PROJECTS */
.projects-bg{background:var(--offwhite);}

.projects-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:1.25rem;
}

.project-card{
  background:var(--white);
  border:1px solid var(--gray2);
  border-radius:8px;
  padding:1.75rem;
  transition:box-shadow 0.2s,transform 0.2s;
  overflow:hidden;
}

.project-card:hover{
  box-shadow:0 8px 28px rgba(11,22,40,0.1);
  transform:translateY(-2px);
}

.project-card img.project-image{
  width:100%;
  max-height:180px;
  object-fit:cover;
  border-radius:8px;
  display:block;
  margin-bottom:1rem;
}

.project-client{
  font-size:11px;
  font-weight:600;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--amber2);
  margin-bottom:0.4rem;
}

.project-title{
  font-family:var(--display);
  font-size:1.05rem;
  font-weight:700;
  color:var(--navy);
  margin-bottom:0.6rem;
  line-height:1.3;
}

.project-desc{
  font-size:13px;
  color:var(--text2);
  line-height:1.65;
}

/* TEAM */
.team-bg{background:var(--white);}

.team-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:1.25rem;
}

.team-card{
  background:var(--offwhite);
  border:1px solid var(--gray2);
  border-radius:8px;
  padding:1.75rem;
  display:flex;
  align-items:flex-start;
  gap:1rem;
}

.team-avatar{
  width:52px;height:52px;
  border-radius:50%;
  background:var(--navy);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);
  font-weight:700;
  font-size:16px;
  color:var(--amber);
  flex-shrink:0;
}

.team-name{
  font-family:var(--display);
  font-size:1rem;
  font-weight:700;
  color:var(--navy);
  margin-bottom:3px;
}

.team-role{
  font-size:12px;
  color:var(--amber2);
  font-weight:500;
  letter-spacing:0.04em;
}

/* PARTNERS */
.partners-bg{background:var(--navy2);}

.partners-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:1rem;
}

.partners-grid > div,
.partner-card{
  background:var(--offwhite);
  border:1px solid var(--gray2);
  border-radius:10px;
  padding:1.5rem;
  min-height:100%;
  display:flex;
  flex-direction:column;
  position:relative;
  overflow:hidden;
}

.partner-stripe{
  position:absolute;
  top:0;
  left:0;
  width:3px;
  height:100%;
  background:var(--amber);
  opacity:0.6;
}

.partner-topic{
  font-size:10px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--amber2);
  margin-bottom:0.5rem;
  font-family:var(--body);
}

.partner-title{
  font-family:var(--display);
  font-size:1rem;
  font-weight:700;
  color:var(--navy);
  margin-bottom:4px;
}

.partner-copy{
  font-size:12px;
  color:var(--text2);
}

.partner-logo{
  position:absolute;
  bottom:1rem;
  right:1rem;
  width:40px;
  height:40px;
  object-fit:contain;
  opacity:0.8;
}

.partner-logo--low-opacity{
  opacity:0.2;
}

.partners-grid > div::before,
.partner-card::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  width:3px;
  height:100%;
  background:var(--amber);
  opacity:0.65;
}

.partners-grid > div > div:first-child{
  display:none;
}

.partner-category{
  font-size:10px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--amber2);
  margin-bottom:0.5rem;
}

.partner-name{
  font-family:var(--display);
  font-size:1rem;
  font-weight:700;
  color:var(--navy);
  margin-bottom:0.35rem;
}

.partner-desc{
  font-size:12px;
  color:var(--text2);
  line-height:1.6;
  margin-bottom:1.25rem;
}

.partner-logo-wrap{
  margin-top:auto;
  min-height:84px;
  border-radius:8px;
  background:linear-gradient(180deg, rgba(11,22,40,0.02), rgba(11,22,40,0.06));
  border:1px solid rgba(11,22,40,0.06);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:1rem;
}

.partner-logo{
  width:100%;
  max-width:120px;
  max-height:52px;
  object-fit:contain;
  display:block;
}

.partners-grid > div > img{
  position:static !important;
  margin-top:auto;
  width:100% !important;
  max-width:120px;
  height:52px !important;
  object-fit:contain !important;
  align-self:center;
  opacity:1 !important;
  display:block;
}

.partner-logo-wrap--placeholder{
  background:rgba(245,166,35,0.08);
  border-color:rgba(245,166,35,0.18);
}

.partner-logo-placeholder{
  font-family:var(--display);
  font-size:1.1rem;
  font-weight:700;
  letter-spacing:0.08em;
  color:var(--amber2);
}

/* CERTIFICATIONS */
.cert-bg{background:var(--navy);}
.cert-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:1.25rem;
}
.cert-card{
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.07);
  border-radius:12px;
  padding:1.25rem;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:1rem;
  text-align:center;
  min-height:100%;
}

.cert-card img{
  width:100%;
  max-width:220px;
  height:280px;
  object-fit:cover;
  object-position:center top;
  border-radius:10px;
  display:block;
  background:rgba(255,255,255,0.08);
  box-shadow:0 10px 24px rgba(0,0,0,0.18);
}

.cert-name{
  font-family:var(--display);
  font-size:0.95rem;
  font-weight:600;
  color:var(--white);
  line-height:1.45;
}

/* WHY US */
.why-bg{background:var(--navy2);}

.why-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:1rem;
}

.why-card{
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.07);
  border-radius:8px;
  padding:1.5rem;
}

.why-icon{
  font-size:1.5rem;
  margin-bottom:0.75rem;
}

.why-title{
  font-family:var(--display);
  font-size:0.95rem;
  font-weight:700;
  color:var(--white);
  margin-bottom:0.4rem;
}

.why-desc{
  font-size:12px;
  color:rgba(255,255,255,0.45);
  line-height:1.65;
}

/* CONTACT */
.contact-bg{background:var(--offwhite);}

.contact-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:2rem;
  align-items:start;
}

.contact-info{
  background:var(--navy);
  border-radius:12px;
  padding:2.5rem;
  color:var(--white);
}

.contact-info-title{
  font-family:var(--display);
  font-size:1.5rem;
  font-weight:700;
  color:var(--white);
  margin-bottom:0.5rem;
}

.contact-info-sub{
  font-size:13px;
  color:rgba(255,255,255,0.5);
  margin-bottom:2rem;
  line-height:1.65;
}

.contact-detail{
  display:flex;
  align-items:flex-start;
  gap:12px;
  margin-bottom:1.25rem;
}

.contact-detail-icon{
  width:36px;height:36px;
  background:rgba(245,166,35,0.12);
  border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  font-size:15px;
  flex-shrink:0;
}

.contact-detail-label{
  font-size:11px;
  color:rgba(255,255,255,0.4);
  letter-spacing:0.06em;
  text-transform:uppercase;
  margin-bottom:2px;
}

.contact-detail-value{
  font-size:14px;
  color:var(--white);
}

.social-row{
  display:flex;gap:10px;
  margin-top:1.75rem;
  padding-top:1.75rem;
  border-top:1px solid rgba(255,255,255,0.1);
}

.social-btn{
  padding:8px 14px;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:4px;
  font-size:12px;
  color:rgba(255,255,255,0.6);
  text-decoration:none;
  transition:background 0.2s,color 0.2s;
}

.social-btn:hover{background:rgba(245,166,35,0.15);color:var(--amber);}

.contact-tagline{
  background:var(--white);
  border:1px solid var(--gray2);
  border-radius:12px;
  padding:2.5rem;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:1.5rem;
}

.contact-cta{
  align-self:flex-start;
}

.contact-tagline-headline{
  font-family:var(--display);
  font-size:1.8rem;
  font-weight:700;
  color:var(--navy);
  letter-spacing:-0.5px;
  line-height:1.2;
}

.contact-tagline-headline span{color:var(--amber);}

.contact-tagline-body{
  font-size:14px;
  color:var(--text2);
  line-height:1.75;
}

.contact-tag-row{
  display:flex;gap:8px;flex-wrap:wrap;
}

.ctag{
  padding:5px 12px;
  background:var(--offwhite);
  border:1px solid var(--gray2);
  border-radius:100px;
  font-size:12px;
  color:var(--text2);
}

/* FOOTER */
footer{
  background:var(--navy);
  padding:1.5rem 2.5rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:1rem;
  border-top:1px solid rgba(245,166,35,0.15);
}

.footer-brand{
  font-family:var(--display);
  font-size:14px;
  font-weight:700;
  color:var(--white);
}

.footer-brand span{color:var(--amber);}

.footer-copy{
  font-size:12px;
  color:rgba(255,255,255,0.35);
}

.footer-motto{
  font-size:12px;
  color:rgba(255,255,255,0.35);
  font-style:italic;
}

/* RESPONSIVE */
@media(max-width:640px){
  .contact-grid{grid-template-columns:1fr;}
  .hero-stats{gap:1.5rem;}
  nav .nav-links{display:none;}
}
