/* =========================
   Bexstage – Pro Styles v3
   ========================= */

/* Font */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

/* ---------- Design tokens ---------- */
:root{
  /* Brand */
  --brand-blue: #1B2BBF;
  --brand-blue-2: #1523A8;
  --brand-blue-3: #0E187F;
  --brand-orange: #FF6A00;

  /* Neutrals */
  --ink: #0E1116;
  --ink-2: #1C222B;
  --muted: #667085;
  --line: #E6E8F0;
  --surface: #FFFFFF;
  --surface-2: #F6F8FC;

  /* Effects */
  --radius-md: 14px;
  --radius-lg: 20px;
  --shadow-xs: 0 1px 2px rgba(16, 24, 40, .06);
  --shadow-sm: 0 4px 14px rgba(16, 24, 40, .08);
  --shadow-md: 0 18px 44px rgba(16, 24, 40, .12);
}

/* ---------- Base ---------- */
html{ scroll-behavior: smooth; }

body{
  font-family: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  color: var(--ink-2);
  letter-spacing: 0;
  background: linear-gradient(180deg,#fff 0%, #fbfcff 100%);
}

/* Global type scale */
h1,.display-5{ letter-spacing:-.015em; }
h1,h2,h3{ color: var(--ink); }
.lead{ color:#2B3443; }

/* Layout rhythm */
.py-6{ padding-block: 5rem; }
@media (min-width: 992px){
  .py-6{ padding-block: 6.5rem; }
}

/* Links & focus */
a{ text-decoration: none; }
a[href^="mailto:"], a[href^="tel:"]{ text-underline-offset: 3px; }
a:hover{ text-decoration: underline; }

:focus-visible{
  outline: 3px solid rgba(255,106,0,.45);
  outline-offset: 2px;
  border-radius: 6px;
}

/* ---------- Navbar ---------- */
.navbar{
  background: rgba(255,255,255,.85) !important;
  backdrop-filter: blur(8px);
  border-bottom: 1px solid rgba(20, 22, 30, .06) !important;
  transition: box-shadow .25s ease, background .25s ease;
}

.navbar .nav-link{
  font-weight: 600;
  color:#2D3748;
  padding: .75rem 1rem;
  position: relative;
}

.navbar .nav-link:hover{ color: var(--brand-blue); }

.navbar .nav-link::after{
  content:"";
  position:absolute;
  left:1rem;
  right:1rem;
  bottom:.4rem;
  height:2px;
  background: linear-gradient(90deg,var(--brand-orange),var(--brand-blue));
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .25s ease;
}

.navbar .nav-link:hover::after{ transform:scaleX(1); }

.btn.btn-primary.rounded-pill{
  padding:.625rem 1.25rem;
  font-weight:700;
}

/* ---------- Buttons ---------- */
.btn-primary{
  --bs-btn-bg: var(--brand-blue);
  --bs-btn-border-color: var(--brand-blue);
  --bs-btn-hover-bg: var(--brand-blue-2);
  --bs-btn-hover-border-color: var(--brand-blue-2);
  --bs-btn-active-bg: var(--brand-blue-3);
  --bs-btn-active-border-color: var(--brand-blue-3);
  box-shadow: 0 8px 20px rgba(27,43,191,.25);
}

.btn-outline-primary{
  --bs-btn-color: var(--brand-blue);
  --bs-btn-border-color: var(--brand-blue);
  --bs-btn-hover-bg: var(--brand-blue);
  --bs-btn-hover-border-color: var(--brand-blue);
  --bs-btn-hover-color: #fff;
}

/* ---------- Hero ---------- */
header#home{
  background:
    radial-gradient(1800px 600px at 0% -10%, rgba(27,43,191,.08) 0%, rgba(27,43,191,0) 40%),
    radial-gradient(1200px 400px at 100% -5%, rgba(255,106,0,.10) 0%, rgba(255,106,0,0) 50%),
    var(--surface-2);
}

.hero-img{
  max-height: 520px;
  aspect-ratio: 4/5;
  object-fit: cover;
  border-radius: 24px;
  box-shadow: var(--shadow-md);
  -webkit-mask-image: radial-gradient(120% 120% at 80% 0%, #000 70%, rgba(0,0,0,.0) 100%);
          mask-image: radial-gradient(120% 120% at 80% 0%, #000 70%, rgba(0,0,0,.0) 100%);
}

/* ---------- Section tags & light sections ---------- */
.text-primary{ color: var(--brand-blue) !important; }
.bg-light{ background: var(--surface-2) !important; }

section>span.text-primary{
  display:inline-block;
  padding:.35rem .7rem;
  border-radius:999px;
  background: rgba(27,43,191,.08);
}

/* ---------- Cards (global) ---------- */
.card{
  border: 1px solid var(--line) !important;   /* altijd een subtiele rand */
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-xs);
  background-clip: padding-box;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.card:hover{
  transform: translateY(-4px);
  box-shadow: var(--shadow-sm);
  border-color: rgba(27,43,191,.25) !important;
}

.card .card-body{ padding: 2rem; }
.card h3{ font-weight: 700; margin-bottom:.35rem; }
.card p{ color:#475569; }

/* Extra highlight voor diensten + contactkaarten */
#diensten .card,
#contact .card{
  border-color: #D0D7E3 !important;
}

#diensten .card:hover,
#contact .card:hover{
  border-color: #1B2BBF !important;
  box-shadow: 0 0 0 3px rgba(27, 43, 191, 0.18);
}

/* Nummer-badge in kaarten */
.card .d-inline-flex{
  width:56px;
  height:56px;
  border-radius:12px;
  background: linear-gradient(135deg, rgba(27,43,191,.12), rgba(255,106,0,.12)) !important;
  box-shadow: inset 0 0 0 1px rgba(27,43,191,.15);
}

/* ---------- Quote ---------- */
.blockquote{
  font-weight: 600;
  color:#1F2937;
  position:relative;
  padding: 1.25rem 0;
}

.blockquote::before{
  content:"“";
  position:absolute;
  left:-.05em;
  top:-.15em;
  font-size:3.25rem;
  color: var(--brand-orange);
  opacity:.9;
}

.blockquote-footer{ color:#778197; }

/* ---------- CTA band ---------- */
section.bg-primary{
  background: linear-gradient(90deg, var(--brand-blue) 0%, var(--brand-blue-2) 100%) !important;
}

section.bg-primary .btn-light{
  box-shadow: var(--shadow-sm);
}

/* ---------- Forms ---------- */
.form-control,
.form-select,
.input-group .form-control{
  border-radius: 12px;
  border: 1.25px solid #D0D7E3 !important;  /* altijd zichtbaar */
  background:#fff;
  padding: .95rem 1rem;
  transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

.form-control::placeholder{
  color: #98A2B3;
}

.form-control:hover,
.form-select:hover{
  border-color:#B8C3D6 !important;
}

.form-control:focus,
.form-select:focus{
  border-color: var(--brand-blue) !important;
  box-shadow: 0 0 0 .25rem rgba(27,43,191,.15);
  outline: 0;
}

textarea.form-control{ min-height: 180px; }

label.form-label{
  font-weight: 600;
  color:#374151;
}

/* Contact cards specifiek */
#contact .card{
  border-radius: 18px !important;
}

/* Contact details icons */
#contact .list-unstyled i{
  color: var(--brand-blue);
  opacity:.9;
}

/* ---------- Footer ---------- */
footer{
  background: #fff;
  border-top:1px solid var(--line);
}

footer .nav-link{
  color:#8C95A6;
}

footer .nav-link:hover{
  color: var(--brand-blue);
}

/* ---------- Social media icons in footer ---------- */
.social-link{
  transition: color 0.25s ease, transform 0.25s ease;
}

.social-link:hover{
  color: var(--brand-blue);
  transform: translateY(-2px);
}

/* ---------- Utility & misc ---------- */
.rounded-4{ border-radius: var(--radius-lg) !important; }
.shadow-sm{ box-shadow: var(--shadow-sm) !important; }

/* Logo sizes */
.logo-img{
  width: clamp(150px, 12vw, 190px);
  height: auto;
}

.footer-logo{
  width: clamp(130px, 11vw, 170px);
  height: auto;
}

/* Navbar tweaks op kleine schermen */
@media (max-width: 576px){
  .logo-img{ width: 150px; }
}
/* --- Habbang footer credit --- */
.habbang-credit{
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: center;
}

.habbang-link{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  color: var(--muted);
  text-decoration: none;
}

.habbang-link:hover{
  text-decoration: underline;
}

.habbang-logo{
  height: 18px;   /* pas grootte aan indien gewenst */
  width: auto;
  display: block;
}
