/* ============================================================
   44 Protection Group — ljust tema, mörk hero, blå accent
============================================================ */
:root {
  --blue: #2670F7;
  --blue-deep: #1B57D6;
  --bg: #FFFFFF;
  --surface: #F4F6FA;
  --dark: #0E1420;
  --dark-2: #161E2C;
  --ink: #141A24;
  --muted: #5B6472;
  --line: rgba(20, 26, 36, 0.10);
  --line-dark: rgba(255, 255, 255, 0.12);
  --maxw: 1180px;
  --radius: 16px;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body { font-family: 'Inter', Helvetica, Arial, sans-serif; background: var(--bg); color: var(--ink); line-height: 1.7; overflow-x: hidden; -webkit-font-smoothing: antialiased; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
.container { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }
.section { padding: clamp(60px, 8vw, 110px) 0; }

h1, h2, h3, .display { font-family: 'Questrial', 'Inter', sans-serif; line-height: 1.12; font-weight: 400; }
.h-xl { font-size: clamp(38px, 6.4vw, 72px); letter-spacing: 0.01em; }
.h-lg { font-size: clamp(28px, 4vw, 46px); }
.h-md { font-size: clamp(21px, 2.6vw, 28px); }
.eyebrow { display:inline-flex; align-items:center; gap:10px; font-family:'Inter',sans-serif; font-size:12px; font-weight:600; letter-spacing:0.22em; text-transform:uppercase; color:var(--blue); margin-bottom:16px; }
.eyebrow::before { content:""; width:28px; height:2px; background:var(--blue); }
.eyebrow--center { justify-content:center; }
.eyebrow--light { color:#7FA6FF; }
.lead { font-size: clamp(16px,1.6vw,20px); color: var(--muted); }
.muted { color: var(--muted); }
.section-head { max-width:640px; margin:0 auto clamp(40px,5vw,56px); text-align:center; }

/* Buttons */
.btn { display:inline-flex; align-items:center; gap:10px; font-family:'Inter',sans-serif; font-weight:600; font-size:15px; letter-spacing:0.02em; padding:14px 28px; border-radius:8px; border:1.5px solid transparent; cursor:pointer; transition:all .2s ease; white-space:nowrap; }
.btn-blue { background:var(--blue); color:#fff; }
.btn-blue:hover { background:var(--blue-deep); transform:translateY(-2px); box-shadow:0 14px 30px -12px rgba(38,112,247,0.5); }
.btn-outline { background:transparent; color:var(--ink); border-color:var(--line); }
.btn-outline:hover { border-color:var(--blue); color:var(--blue); transform:translateY(-2px); }

/* NAV */
.nav { position:sticky; top:0; z-index:50; background:rgba(255,255,255,0.9); backdrop-filter:blur(12px); border-bottom:1px solid var(--line); }
.nav__inner { display:flex; align-items:center; justify-content:space-between; height:72px; }
.nav__brand { font-family:'Questrial',sans-serif; font-size:19px; font-weight:400; letter-spacing:0.06em; display:flex; align-items:center; gap:9px; }
.nav__brand .mark { display:inline-grid; place-items:center; width:38px; height:38px; border-radius:50%; background:var(--blue); color:#fff; font-weight:400; font-size:17px; letter-spacing:0; }
.nav__logo { height:38px; width:auto; }
.footer__brand .nav__logo { height:42px; }
.nav__links { display:flex; align-items:center; gap:28px; list-style:none; }
.nav__links a { font-size:14px; font-weight:500; color:var(--muted); transition:color .18s ease; }
.nav__links a:hover, .nav__links a.is-active { color:var(--ink); }
.nav__cta { display:flex; align-items:center; gap:12px; }
.nav__cta .btn { padding:10px 20px; font-size:14px; }
.nav__toggle { display:none; background:none; border:0; color:var(--ink); cursor:pointer; padding:6px; }
.nav__toggle svg { width:26px; height:26px; }

/* HERO (dark) */
.hero { position:relative; min-height:82vh; display:flex; align-items:center; overflow:hidden; background:var(--dark); }
.hero__bg { position:absolute; inset:0; z-index:0; }
.hero__bg img { width:100%; height:100%; object-fit:cover; opacity:.55; }
.hero__bg::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(14,20,32,0.55), rgba(14,20,32,0.85) 70%, rgba(14,20,32,0.97)); }
.hero__inner { position:relative; z-index:1; max-width:760px; padding:120px 0; color:#fff; }
.hero h1 { color:#fff; margin:10px 0 18px; }
.hero p.lead { color:#C7D0DE; max-width:540px; margin-bottom:34px; }
.hero__actions { display:flex; flex-wrap:wrap; gap:14px; }
.hero .btn-outline { color:#fff; border-color:rgba(255,255,255,0.3); }
.hero .btn-outline:hover { border-color:#7FA6FF; color:#7FA6FF; }
.hero--sub { min-height:62vh; }

/* FEATURE */
.feature { display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,5vw,72px); align-items:center; }
.feature--reverse .feature__media { order:2; }
.feature__media { border-radius:var(--radius); overflow:hidden; aspect-ratio:4/3; box-shadow:0 30px 60px -34px rgba(14,20,32,0.4); }
.feature__media img { width:100%; height:100%; object-fit:cover; transition:transform .7s ease; }
.feature__media:hover img { transform:scale(1.04); }
.feature h2 { margin-bottom:20px; }
.feature p + p { margin-top:14px; }

/* SERVICE CARDS */
.services { background:var(--surface); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.service-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.service-card { position:relative; border-radius:var(--radius); overflow:hidden; min-height:420px; display:flex; flex-direction:column; justify-content:flex-end; color:#fff; border:1px solid var(--line); isolation:isolate; }
.service-card__bg { position:absolute; inset:0; z-index:-2; }
.service-card__bg img { width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.service-card:hover .service-card__bg img { transform:scale(1.06); }
.service-card::after { content:""; position:absolute; inset:0; z-index:-1; background:linear-gradient(180deg, rgba(14,20,32,0.15), rgba(14,20,32,0.65) 50%, rgba(14,20,32,0.95)); }
.service-card__body { padding:30px; }
.service-card__body h3 { font-size:24px; margin-bottom:10px; }
.service-card__body p { color:#C7D0DE; font-size:15px; margin-bottom:20px; }
.service-card__link { display:inline-flex; align-items:center; gap:8px; color:#9CBCFF; font-weight:600; font-size:14px; }
.service-card__link svg { width:16px; height:16px; transition:transform .2s ease; }
.service-card:hover .service-card__link svg { transform:translateX(4px); }

/* BAND (dark) */
.band { background:var(--dark); color:#fff; }
.band .container { text-align:center; }
.band .quote { font-family:'Questrial',sans-serif; font-size:clamp(22px,3.2vw,38px); line-height:1.3; max-width:880px; margin:0 auto; }
.band .quote span { color:#7FA6FF; }

/* CONTACT */
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,56px); align-items:start; }
.contact-card { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:34px; }
.contact-row { display:flex; gap:16px; align-items:flex-start; padding:16px 0; border-bottom:1px solid var(--line); }
.contact-row:last-child { border-bottom:0; }
.contact-row svg { width:20px; height:20px; color:var(--blue); flex:none; margin-top:3px; }
.contact-row a, .contact-row span { color:var(--ink); }
.contact-row a:hover { color:var(--blue); }
.contact-row small { display:block; color:var(--muted); font-size:12px; letter-spacing:0.08em; text-transform:uppercase; margin-bottom:3px; }
.map-embed { border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); min-height:340px; height:100%; }
.map-embed iframe { width:100%; height:100%; min-height:340px; border:0; }

/* FEATURE-LIST (subpages) */
.flist { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.flist__item { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:30px 26px; }
.flist__item h3 { font-size:21px; margin-bottom:12px; }
.flist__item p { color:var(--muted); font-size:15px; }

/* FOOTER (dark) */
.footer { background:var(--dark); color:#fff; padding:60px 0 34px; }
.footer__grid { display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:40px; margin-bottom:40px; }
.footer__brand .nav__brand { font-size:21px; margin-bottom:14px; }
.footer__brand p { color:#9AA5B5; max-width:320px; font-size:15px; }
.footer h4 { font-family:'Inter',sans-serif; font-size:12px; letter-spacing:0.14em; text-transform:uppercase; color:#7FA6FF; margin-bottom:16px; }
.footer ul { list-style:none; }
.footer li { margin-bottom:11px; }
.footer li a, .footer li span { color:#D4DAE3; font-size:15px; }
.footer li a:hover { color:#7FA6FF; }
.footer__social { display:flex; gap:12px; margin-top:8px; }
.footer__social a { width:40px; height:40px; border-radius:50%; border:1px solid var(--line-dark); display:grid; place-items:center; transition:all .2s ease; }
.footer__social a:hover { border-color:var(--blue); background:var(--blue); transform:translateY(-2px); }
.footer__social svg { width:18px; height:18px; }
.footer__bottom { display:flex; flex-wrap:wrap; justify-content:space-between; gap:10px; padding-top:26px; border-top:1px solid var(--line-dark); color:#8B95A5; font-size:13px; }
.footer__bottom a { color:#7FA6FF; }

/* reveal */
.reveal { opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in { opacity:1; transform:none; }

/* responsive */
@media (max-width:900px) {
  .nav__links, .nav__cta .btn-outline { display:none; }
  .nav__toggle { display:inline-flex; }
  .nav__brand { font-size:14px; letter-spacing:0.02em; gap:7px; }
  .nav__brand .mark { width:30px; height:30px; font-size:14px; }
  .nav__cta { gap:8px; }
  .nav__cta .btn { padding:9px 13px; font-size:12px; }
  .contact-card { padding:24px 20px; }
  .nav.open .nav__links { display:flex; flex-direction:column; gap:0; position:absolute; top:72px; left:0; right:0; background:#fff; border-top:1px solid var(--line); box-shadow:0 24px 40px -22px rgba(14,20,32,0.25); padding:10px 24px 18px; }
  .nav.open .nav__links li + li { border-top:1px solid var(--line); }
  .nav.open .nav__links a { display:block; padding:15px 4px; font-size:15px; }
  .feature, .contact-grid { grid-template-columns:1fr; }
  .feature--reverse .feature__media { order:0; }
  .service-grid, .flist { grid-template-columns:1fr; }
  .footer__grid { grid-template-columns:1fr; gap:30px; }
}
