/*
Theme Name: Wehrens Webdesign
Theme URI: https://wehrenswebdesign.nl
Description: Wehrens Webdesign – Donker thema met elektrisch blauw. Volledig bewerkbaar met Elementor.
Author: Tim Wehrens
Author URI: https://wehrenswebdesign.nl
Template: hello-elementor
Version: 2.0.0
Text Domain: wehrens-webdesign
Tags: elementor, dark, business, portfolio
*/

/* ============================================================
   WEHRENS WEBDESIGN – Global Styles
   Accent: Elektrisch Blauw #0ea5e9
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;600;700;800;900&family=Inter:wght@300;400;500;600&display=swap');

:root {
  --ww-bg:     #0d1117;
  --ww-bg2:    #1a1f2e;
  --ww-card:   #1e2435;
  --ww-border: #2a3045;
  --ww-blue:   #0ea5e9;
  --ww-blue2:  #0284c7;
  --ww-white:  #ffffff;
  --ww-muted:  #8892a4;
  --ww-deep:   #090d14;
}

*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  background-color: var(--ww-bg) !important;
  color: var(--ww-white) !important;
  font-family: 'Inter', sans-serif !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Remove default WP margins */
.site, .site-header, .site-footer { display: none !important; }
#wpadminbar { z-index: 99999 !important; }

/* Elementor canvas full width */
.elementor-page .entry-content,
.elementor-page .post-content { padding: 0 !important; margin: 0 !important; }

/* ── TYPOGRAPHY ── */
h1, h2, h3, h4, h5, h6 { font-family: 'Poppins', sans-serif !important; color: var(--ww-white) !important; }
p, li, a, span, label { font-family: 'Inter', sans-serif !important; }
a { color: var(--ww-blue) !important; text-decoration: none !important; transition: color .25s !important; }
a:hover { color: var(--ww-blue2) !important; }

/* ── ELEMENTOR GLOBAL ── */
.elementor-section { background-color: var(--ww-bg) !important; }
.elementor-widget-heading .elementor-heading-title { font-family: 'Poppins', sans-serif !important; }
.elementor-widget-text-editor { color: var(--ww-muted) !important; font-size: 15px !important; line-height: 1.7 !important; }

/* ── BUTTONS ── */
.elementor-button,
.ww-btn {
  background: var(--ww-blue) !important;
  color: #fff !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 600 !important;
  font-size: 15px !important;
  padding: 14px 34px !important;
  border-radius: 9px !important;
  border: none !important;
  cursor: pointer !important;
  transition: all .25s !important;
  display: inline-block !important;
  text-decoration: none !important;
}
.elementor-button:hover,
.ww-btn:hover {
  background: var(--ww-blue2) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 10px 32px rgba(14,165,233,0.35) !important;
  color: #fff !important;
}

/* ── NAV MENU ── */
.elementor-nav-menu--main .elementor-item {
  color: var(--ww-muted) !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 14px !important;
  padding: 7px 15px !important;
  transition: color .25s !important;
}
.elementor-nav-menu--main .elementor-item:hover,
.elementor-nav-menu--main .elementor-item.elementor-item-active {
  color: var(--ww-blue) !important;
}
.elementor-nav-menu--main .elementor-item.elementor-item-active::after {
  background: var(--ww-blue) !important;
}

/* ── HERO BADGE ── */
.ww-hero-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  background: rgba(14,165,233,0.08) !important;
  border: 1px solid rgba(14,165,233,0.25) !important;
  border-radius: 30px !important;
  padding: 7px 18px !important;
  font-size: 13px !important;
  color: var(--ww-blue) !important;
}

/* ── CARDS ── */
.ww-card {
  background: var(--ww-card) !important;
  border: 1px solid var(--ww-border) !important;
  border-radius: 14px !important;
  padding: 30px !important;
  transition: all .3s !important;
}
.ww-card:hover {
  border-color: rgba(14,165,233,0.5) !important;
  transform: translateY(-5px) !important;
  box-shadow: 0 15px 40px rgba(14,165,233,0.08) !important;
}
.ww-card-feat {
  background: linear-gradient(135deg,#1e2435,#1a2535) !important;
  border: 1px solid rgba(14,165,233,0.35) !important;
  border-radius: 14px !important;
  padding: 30px !important;
}

/* ── PRICING ── */
.ww-pcard {
  background: var(--ww-card) !important;
  border: 1px solid var(--ww-border) !important;
  border-radius: 16px !important;
  padding: 36px !important;
  position: relative !important;
  transition: all .3s !important;
  height: 100% !important;
}
.ww-pcard:hover { transform: translateY(-4px) !important; }
.ww-pcard-feat {
  border-color: var(--ww-blue) !important;
  box-shadow: 0 0 50px rgba(14,165,233,0.15) !important;
}
.ww-pbadge {
  position: absolute !important;
  top: -14px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  background: var(--ww-blue) !important;
  color: #fff !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  padding: 4px 20px !important;
  border-radius: 20px !important;
  white-space: nowrap !important;
  font-family: 'Inter', sans-serif !important;
}
.ww-price-amt { font-family: 'Poppins', sans-serif !important; font-size: 44px !important; font-weight: 800 !important; color: var(--ww-blue) !important; }
.ww-price-per { color: var(--ww-muted) !important; font-size: 14px !important; }
.ww-pfeatures { list-style: none !important; padding: 0 !important; margin-bottom: 30px !important; }
.ww-pfeatures li { padding: 8px 0 8px 24px !important; position: relative !important; color: var(--ww-muted) !important; font-size: 13px !important; border-bottom: 1px solid rgba(42,48,69,0.45) !important; }
.ww-pfeatures li::before { content: '✓' !important; position: absolute !important; left: 0 !important; color: var(--ww-blue) !important; font-weight: 700 !important; }

/* ── CHECKLIST ── */
.ww-checklist { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 0 40px !important; }
.ww-ci { padding: 9px 0 9px 26px !important; position: relative !important; color: var(--ww-muted) !important; font-size: 14px !important; border-bottom: 1px solid rgba(42,48,69,0.5) !important; }
.ww-ci::before { content: '✓' !important; position: absolute !important; left: 0 !important; color: var(--ww-blue) !important; font-weight: 700 !important; }

/* ── PROCESS STEPS ── */
.ww-step { display: flex !important; gap: 24px !important; margin-bottom: 32px !important; align-items: flex-start !important; }
.ww-step-num { width: 60px !important; height: 60px !important; min-width: 60px !important; background: var(--ww-card) !important; border: 1px solid var(--ww-border) !important; border-radius: 12px !important; display: flex !important; align-items: center !important; justify-content: center !important; font-family: 'Poppins', sans-serif !important; font-size: 20px !important; font-weight: 700 !important; color: var(--ww-muted) !important; transition: all .3s !important; }
.ww-step:hover .ww-step-num { border-color: var(--ww-blue) !important; color: var(--ww-blue) !important; }
.ww-step h3 { font-family: 'Poppins', sans-serif !important; font-size: 18px !important; font-weight: 600 !important; margin-bottom: 7px !important; color: var(--ww-white) !important; }
.ww-step p { color: var(--ww-muted) !important; font-size: 14px !important; line-height: 1.7 !important; margin: 0 !important; }

/* ── TESTIMONIALS ── */
.ww-tcard { background: var(--ww-card) !important; border: 1px solid var(--ww-border) !important; border-radius: 14px !important; padding: 28px !important; position: relative !important; transition: all .3s !important; height: 100% !important; }
.ww-tcard:hover { border-color: rgba(14,165,233,0.4) !important; transform: translateY(-4px) !important; }
.ww-tcard::before { content: '"' !important; position: absolute !important; top: 16px !important; right: 22px !important; font-size: 60px !important; color: rgba(14,165,233,0.1) !important; line-height: 1 !important; font-family: 'Poppins', sans-serif !important; }
.ww-stars { color: #f59e0b !important; font-size: 14px !important; letter-spacing: 2px !important; margin-bottom: 14px !important; }
.ww-ttext { color: var(--ww-muted) !important; font-size: 14px !important; line-height: 1.7 !important; font-style: italic !important; margin-bottom: 20px !important; }
.ww-tname { font-family: 'Poppins', sans-serif !important; font-size: 14px !important; font-weight: 600 !important; color: var(--ww-white) !important; }
.ww-tco { color: var(--ww-muted) !important; font-size: 12px !important; }

/* ── WHY SECTION ── */
.ww-photo-card { background: var(--ww-card) !important; border: 1px solid var(--ww-border) !important; border-radius: 20px !important; padding: 40px !important; text-align: center !important; }
.ww-why-pt { display: flex !important; gap: 16px !important; align-items: flex-start !important; padding: 20px !important; background: var(--ww-card) !important; border: 1px solid var(--ww-border) !important; border-radius: 12px !important; margin-bottom: 16px !important; transition: all .3s !important; }
.ww-why-pt:hover { border-color: var(--ww-blue) !important; transform: translateX(6px) !important; }
.ww-why-icon { width: 42px !important; height: 42px !important; min-width: 42px !important; background: rgba(14,165,233,0.1) !important; border-radius: 10px !important; display: flex !important; align-items: center !important; justify-content: center !important; font-size: 20px !important; }
.ww-why-pt h4 { font-family: 'Poppins', sans-serif !important; font-size: 15px !important; font-weight: 600 !important; margin-bottom: 4px !important; color: var(--ww-white) !important; }
.ww-why-pt p { color: var(--ww-muted) !important; font-size: 13px !important; line-height: 1.5 !important; margin: 0 !important; }

/* ── PORTFOLIO CARDS ── */
.ww-pocard { background: var(--ww-card) !important; border: 1px solid var(--ww-border) !important; border-radius: 13px !important; padding: 28px !important; transition: all .35s !important; }
.ww-pocard:hover { border-color: rgba(14,165,233,0.5) !important; transform: translateY(-4px) !important; box-shadow: 0 12px 36px rgba(14,165,233,0.08) !important; }

/* ── CONTACT ── */
.ww-citem { display: flex !important; gap: 16px !important; align-items: flex-start !important; margin-bottom: 18px !important; padding: 12px !important; border-radius: 10px !important; transition: background .2s !important; }
.ww-citem:hover { background: var(--ww-card) !important; }
.ww-cicon { width: 44px !important; height: 44px !important; min-width: 44px !important; background: var(--ww-card) !important; border: 1px solid var(--ww-border) !important; border-radius: 10px !important; display: flex !important; align-items: center !important; justify-content: center !important; font-size: 18px !important; }
.ww-person-card { background: var(--ww-card) !important; border: 1px solid var(--ww-border) !important; border-radius: 12px !important; padding: 24px !important; display: flex !important; gap: 16px !important; align-items: flex-start !important; }

/* ── FORM ── */
.ww-fcard { background: var(--ww-card) !important; border: 1px solid var(--ww-border) !important; border-radius: 16px !important; padding: 36px !important; }
.elementor-field-group input,
.elementor-field-group textarea,
.elementor-field-group select {
  background: rgba(13,17,23,0.7) !important;
  border: 1px solid var(--ww-border) !important;
  border-radius: 8px !important;
  color: var(--ww-white) !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 14px !important;
  padding: 13px 16px !important;
  transition: border-color .25s !important;
}
.elementor-field-group input:focus,
.elementor-field-group textarea:focus { border-color: var(--ww-blue) !important; outline: none !important; }
.elementor-field-group label { color: var(--ww-muted) !important; font-size: 13px !important; }
.elementor-button.elementor-size-md { width: 100% !important; justify-content: center !important; }

/* ── CTA BAND ── */
.ww-cta-section { position: relative !important; overflow: hidden !important; }
.ww-cta-section::before { content: '' !important; position: absolute !important; top: 50% !important; left: 50% !important; transform: translate(-50%,-50%) !important; width: 600px !important; height: 300px !important; background: radial-gradient(ellipse,rgba(14,165,233,0.08),transparent 70%) !important; pointer-events: none !important; }

/* ── FOOTER ── */
.ww-footer-section { background: var(--ww-deep) !important; border-top: 1px solid var(--ww-border) !important; }
.ww-footer-logo { font-family: 'Poppins', sans-serif !important; font-size: 21px !important; font-weight: 700 !important; color: var(--ww-blue) !important; }
.ww-footer-link a { color: var(--ww-muted) !important; font-size: 14px !important; text-decoration: none !important; display: block !important; margin-bottom: 10px !important; transition: color .2s !important; }
.ww-footer-link a:hover { color: var(--ww-blue) !important; }

/* ── PAGE HERO ── */
.ww-page-hero { position: relative !important; overflow: hidden !important; }
.ww-page-hero::before { content: '' !important; position: absolute !important; inset: 0 !important; background: radial-gradient(ellipse 60% 80% at 50% 100%, rgba(14,165,233,0.05) 0%, transparent 70%) !important; pointer-events: none !important; }

/* ── SCROLL ANIMATIONS ── */
.ww-fade-up { animation: wwFadeUp .7s cubic-bezier(.16,1,.3,1) both !important; }
@keyframes wwFadeUp { from { opacity: 0; transform: translateY(28px); } to { opacity: 1; transform: translateY(0); } }

/* ── MAINTENANCE CARD ── */
.ww-mcard { background: var(--ww-card) !important; border: 1px solid var(--ww-border) !important; border-radius: 16px !important; padding: 40px !important; }
.ww-mamt { font-family: 'Poppins', sans-serif !important; font-size: 40px !important; font-weight: 800 !important; color: var(--ww-blue) !important; }
.ww-mi { padding: 6px 0 6px 22px !important; position: relative !important; color: var(--ww-muted) !important; font-size: 13px !important; }
.ww-mi::before { content: '+' !important; position: absolute !important; left: 0 !important; color: var(--ww-blue) !important; font-weight: 700 !important; }

/* ── BADGE ── */
.ww-badge { display: inline-block !important; background: rgba(14,165,233,0.1) !important; border: 1px solid rgba(14,165,233,0.3) !important; color: var(--ww-blue) !important; font-size: 12px !important; padding: 4px 14px !important; border-radius: 20px !important; margin-top: 14px !important; }

/* ── RESPONSIVE ── */
@media (max-width: 768px) {
  .ww-checklist { grid-template-columns: 1fr !important; }
  .elementor-section.elementor-section-boxed > .elementor-container { max-width: 100% !important; padding: 0 20px !important; }
}
