/*
Theme Name: Asbestsanering NL
Theme URI: https://asbestsanering-nl.nl
Author: Asbestsanering
Description: Thema op maat voor asbestsanering Nederland. Gecertificeerde sanering golfplaten, dak, vloer en vrijgavemeting. SC-540 gecertificeerd.
Version: 1.0
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: asbestsanering-nl
*/

/* === RESET & BASE === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:#FAF9F2;color:#1a1a1a;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;font-size:16px;font-weight:400;line-height:1.65}
img{max-width:100%;height:auto;display:block}
a{color:#312E81;text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.25;color:#1a1a1a}
ul{list-style:none}
p{margin-bottom:1rem}

/* === UTILITY === */
.asnl-container{max-width:1160px;margin:0 auto;padding:0 1.5rem}

/* === HEADER === */
.asnl-hdr{background:#312E81;padding:0 1.5rem}
.asnl-hdr__inner{max-width:1160px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:68px}
.asnl-hdr__logo{display:flex;align-items:center;gap:.75rem;text-decoration:none}
.asnl-hdr__logo img{height:40px;width:auto}
.asnl-hdr__logo span{color:#fff;font-size:1.2rem;font-weight:700;letter-spacing:-.01em}
.asnl-hdr__nav{display:flex;align-items:center;gap:.25rem}
.asnl-hdr__nav a{color:rgba(255,255,255,.88);font-size:.9rem;font-weight:400;padding:.4rem .75rem;border-radius:4px}
.asnl-hdr__nav a:hover{color:#fff;background:rgba(255,255,255,.12);text-decoration:none}
.asnl-hdr__cta{background:#FACC15 !important;color:#1a1a00 !important;font-size:.9rem;font-weight:700;padding:.5rem 1.25rem;border-radius:6px;margin-left:.75rem;white-space:nowrap}
.asnl-hdr__cta:hover{background:#fde047;text-decoration:none;color:#1a1a00 !important}

/* hamburger CSS-only */
.asnl-hdr__ham{display:none}
.asnl-hdr__ham-label{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:.5rem}
.asnl-hdr__ham-label span{display:block;width:24px;height:2px;background:#fff}
@media(max-width:768px){
  .asnl-hdr__ham-label{display:flex}
  .asnl-hdr__nav{display:none;position:absolute;top:68px;left:0;right:0;background:#312E81;flex-direction:column;align-items:flex-start;padding:1rem 1.5rem;gap:.5rem;z-index:100}
  .asnl-hdr__ham:checked ~ .asnl-hdr__nav{display:flex}
  .asnl-hdr__cta{display:none}
}

/* === HERO === */
.asnl-hero{background:#312E81;position:relative;overflow:hidden;padding:3.5rem 1.5rem 4rem}
.asnl-hero::before{content:'';position:absolute;inset:0;background:url('/wp-content/themes/asbestsanering-nl/assets/images/hero-bg.jpg') center/cover no-repeat;opacity:.18;pointer-events:none}
.asnl-hero__inner{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:5fr 7fr;gap:2.5rem;align-items:start;position:relative;z-index:1}

/* Form LEFT */
.asnl-form{background:#fff;border-radius:10px;padding:2rem 1.75rem;box-shadow:0 8px 40px rgba(0,0,0,.28)}
.asnl-form__title{font-size:1.15rem;font-weight:700;color:#312E81;margin-bottom:1.25rem}
.asnl-form__group{margin-bottom:1rem}
.asnl-form__group label{display:block;font-size:.82rem;font-weight:700;color:#312E81;margin-bottom:.3rem;text-transform:uppercase;letter-spacing:.04em}
.asnl-form__group input,
.asnl-form__group select,
.asnl-form__group textarea{width:100%;border:1.5px solid #d1d5db;border-radius:5px;padding:.6rem .85rem;font-size:.95rem;font-family:inherit;color:#1a1a1a;background:#fff;outline:none}
.asnl-form__group input:focus,
.asnl-form__group select:focus,
.asnl-form__group textarea:focus{border-color:#312E81}
.asnl-form__website{position:absolute;left:-9999px;opacity:0;width:1px;height:1px}
.asnl-form__submit{width:100%;background:#FACC15;color:#1a1a00;font-size:1.05rem;font-weight:700;padding:.85rem;border:none;border-radius:6px;cursor:pointer;margin-top:.5rem}
.asnl-form__submit:hover{background:#fde047}
.asnl-form__note{font-size:.78rem;color:#6b7280;margin-top:.75rem;text-align:center}

/* H1 + intro RIGHT */
.asnl-hero__right{color:#fff;padding-top:.5rem}
.asnl-hero__right h1{font-size:2.75rem;font-weight:700;color:#fff;margin-bottom:1rem;line-height:1.15}
.asnl-hero__right h1 em{color:#FACC15;font-style:normal}
.asnl-hero__intro{font-size:1.05rem;color:rgba(255,255,255,.88);margin-bottom:1.75rem;line-height:1.6}
.asnl-hero__trust{display:flex;flex-direction:column;gap:.75rem}
.asnl-hero__trust-item{display:flex;align-items:center;gap:.75rem;font-size:.95rem;font-weight:700;color:#fff}
.asnl-hero__trust-item svg{flex-shrink:0;color:#FACC15}

@media(max-width:768px){
  .asnl-hero__inner{grid-template-columns:1fr}
  .asnl-hero__right h1{font-size:2rem}
  .asnl-hero__right{order:-1}
}

/* === STAPPEN (vertical timeline) === */
.asnl-stappen{padding:5rem 1.5rem}
.asnl-stappen__inner{max-width:760px;margin:0 auto}
.asnl-stappen__heading{text-align:center;font-size:1.9rem;font-weight:700;color:#312E81;margin-bottom:.5rem}
.asnl-stappen__sub{text-align:center;color:#4b5563;margin-bottom:3rem}
.asnl-timeline{position:relative;padding-left:3.5rem}
.asnl-timeline::before{content:'';position:absolute;left:1.35rem;top:0;bottom:0;width:3px;background:#FACC15}
.asnl-timeline__item{position:relative;margin-bottom:2.5rem}
.asnl-timeline__item:last-child{margin-bottom:0}
.asnl-timeline__num{position:absolute;left:-3.5rem;top:0;width:2.75rem;height:2.75rem;background:#312E81;color:#FACC15;font-size:1.35rem;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center;border:3px solid #FACC15}
.asnl-timeline__title{font-size:1.1rem;font-weight:700;color:#312E81;margin-bottom:.4rem}
.asnl-timeline__body{color:#374151;font-size:.96rem;line-height:1.6}

/* === FOTOS === */
.asnl-fotos{background:#312E81;padding:4rem 1.5rem}
.asnl-fotos__inner{max-width:1160px;margin:0 auto}
.asnl-fotos__heading{text-align:center;font-size:1.9rem;font-weight:700;color:#FACC15;margin-bottom:.5rem}
.asnl-fotos__sub{text-align:center;color:rgba(255,255,255,.8);margin-bottom:2.5rem}
.asnl-fotos__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.asnl-fotos__grid img{border-radius:8px;width:100%;height:220px;object-fit:cover;border:2px solid rgba(250,204,21,.3)}
@media(max-width:640px){.asnl-fotos__grid{grid-template-columns:1fr 1fr}}

/* === CONTENT === */
.asnl-content{padding:4.5rem 1.5rem}
.asnl-content__inner{max-width:800px;margin:0 auto}
.asnl-content h2{font-size:1.65rem;font-weight:700;color:#312E81;margin:2rem 0 .75rem}
.asnl-content h2:first-child{margin-top:0}
.asnl-content h3{font-size:1.2rem;font-weight:700;color:#1a1a1a;margin:1.5rem 0 .5rem}
.asnl-content p{color:#374151;line-height:1.7}
.asnl-content ul li{color:#374151;padding-left:1.25rem;position:relative;margin-bottom:.4rem}
.asnl-content ul li::before{content:'';position:absolute;left:0;top:.55em;width:.55rem;height:.55rem;background:#FACC15;border-radius:50%}
.asnl-content table{width:100%;border-collapse:collapse;margin:1.5rem 0}
.asnl-content table th,
.asnl-content table td{padding:.6rem .85rem;border:1px solid #e5e7eb;text-align:left;color:#374151}
.asnl-content table th{background:#312E81;color:#fff;font-weight:700}

/* === TARIEVEN === */
.asnl-tarieven{background:#f1f0ed;padding:4.5rem 1.5rem}
.asnl-tarieven__inner{max-width:1000px;margin:0 auto}
.asnl-tarieven__heading{text-align:center;font-size:1.9rem;font-weight:700;color:#312E81;margin-bottom:.5rem}
.asnl-tarieven__sub{text-align:center;color:#4b5563;margin-bottom:2.5rem}
.asnl-tarieven__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.asnl-tarieven__card{background:#fff;border-radius:10px;padding:1.75rem 1.5rem;border:2px solid #e5e7eb;position:relative}
.asnl-tarieven__card--featured{border-color:#312E81}
.asnl-tarieven__badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:#FACC15;color:#1a1a00;font-size:.78rem;font-weight:700;padding:.2rem .9rem;border-radius:20px;white-space:nowrap}
.asnl-tarieven__card h3{font-size:1.05rem;font-weight:700;color:#312E81;margin-bottom:.5rem}
.asnl-tarieven__price{font-size:1.6rem;font-weight:700;color:#1a1a1a;margin-bottom:.25rem}
.asnl-tarieven__price span{font-size:.85rem;font-weight:400;color:#6b7280}
.asnl-tarieven__items{margin-top:1rem;display:flex;flex-direction:column;gap:.4rem}
.asnl-tarieven__item{font-size:.9rem;color:#374151;padding-left:1.2rem;position:relative}
.asnl-tarieven__item::before{content:'';position:absolute;left:0;top:.55em;width:.5rem;height:.5rem;background:#FACC15;border-radius:50%}
@media(max-width:768px){.asnl-tarieven__grid{grid-template-columns:1fr}}

/* === FAQ === */
.asnl-faq{padding:4.5rem 1.5rem}
.asnl-faq__inner{max-width:760px;margin:0 auto}
.asnl-faq__heading{text-align:center;font-size:1.9rem;font-weight:700;color:#312E81;margin-bottom:.5rem}
.asnl-faq__sub{text-align:center;color:#4b5563;margin-bottom:2.5rem}
.asnl-faq__item{border-bottom:1px solid #e5e7eb;padding:.85rem 0}
.asnl-faq__q{width:100%;background:none;border:none;text-align:left;font-size:1rem;font-weight:700;color:#312E81;cursor:pointer;display:flex;justify-content:space-between;align-items:center;padding:0}
.asnl-faq__q svg{flex-shrink:0;color:#FACC15}
.asnl-faq__a{display:none;padding:.75rem 0 .25rem;color:#374151;font-size:.95rem;line-height:1.65}
details.asnl-faq__item summary.asnl-faq__q{list-style:none}
details.asnl-faq__item summary.asnl-faq__q::-webkit-details-marker{display:none}
details[open] .asnl-faq__q svg{transform:rotate(180deg)}
details[open] .asnl-faq__a{display:block}

/* === CTA BAND === */
.asnl-cta{background:#312E81;padding:4rem 1.5rem;text-align:center}
.asnl-cta__heading{font-size:2rem;font-weight:700;color:#fff;margin-bottom:.75rem}
.asnl-cta__sub{color:rgba(255,255,255,.82);font-size:1.05rem;margin-bottom:2rem}
.asnl-cta__btn{display:inline-block;background:#FACC15;color:#1a1a00;font-size:1.1rem;font-weight:700;padding:.9rem 2.5rem;border-radius:8px}
.asnl-cta__btn:hover{background:#fde047;text-decoration:none;color:#1a1a00}

/* === FOOTER === */
.asnl-ftr{background:#1e1b4b;padding:3rem 1.5rem 2rem}
.asnl-ftr__inner{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr 1fr;gap:2rem}
.asnl-ftr__brand h3{color:#FACC15;font-size:1.1rem;font-weight:700;margin-bottom:.5rem}
.asnl-ftr__brand p{color:rgba(255,255,255,.65);font-size:.88rem;line-height:1.6}
.asnl-ftr__col h4{color:#fff;font-size:.9rem;font-weight:700;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.05em}
.asnl-ftr__col ul li{margin-bottom:.4rem}
.asnl-ftr__col ul li a{color:rgba(255,255,255,.65);font-size:.88rem}
.asnl-ftr__col ul li a:hover{color:#FACC15;text-decoration:none}
.asnl-ftr__bottom{max-width:1160px;margin:2rem auto 0;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem}
.asnl-ftr__bottom p{color:#9b9bbf;font-size:.8rem}
.asnl-ftr__bottom a{color:#9b9bbf;font-size:.8rem}
.asnl-ftr__bottom a:hover{color:#FACC15;text-decoration:none}
@media(max-width:768px){
  .asnl-ftr__inner{grid-template-columns:1fr}
  .asnl-ftr__bottom{flex-direction:column}
}
