/*
Theme Name: Total Kitchens Leerdam
Theme URI: https://totalkitchensleerdam.nl
Author: Total Kitchens Leerdam
Description: Professioneel WordPress thema voor Total Kitchens Leerdam.
Version: 2.0.0
Requires at least: 5.8
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: totalkitchens
*/

/* ── Variables ─────────────────────────────────────────────── */
:root {
  --primary:     #1a3a5c;
  --primary-dk:  #0d2440;
  --accent:      #e8720c;
  --accent-dk:   #c45e08;
  --bg:          #f4f6f9;
  --white:       #ffffff;
  --text:        #1e2030;
  --muted:       #6b7280;
  --border:      #dde1e9;
  --footer-bg:   #0f1623;
  --radius:      6px;
  --shadow:      0 4px 20px rgba(0,0,0,.07);
  --shadow-lg:   0 8px 40px rgba(0,0,0,.13);
  --trans:       .2s ease;
  --max:         1160px;
}

/* ── Reset ─────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Inter','Segoe UI',Arial,sans-serif;color:var(--text);background:var(--white);line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--primary);text-decoration:none;transition:color var(--trans)}
a:hover{color:var(--accent)}
ul{list-style:none}

/* ── Typography ────────────────────────────────────────────── */
h1,h2,h3,h4,h5{font-weight:700;line-height:1.2;color:var(--primary)}
h1{font-size:clamp(1.9rem,4vw,2.9rem)}
h2{font-size:clamp(1.5rem,3vw,2.1rem)}
h3{font-size:clamp(1.1rem,2vw,1.4rem)}
p{margin-bottom:1rem}
p:last-child{margin-bottom:0}

/* ── Layout ────────────────────────────────────────────────── */
.container{max-width:var(--max);margin:0 auto;padding:0 1.5rem}
.section{padding:76px 0}
.section--gray{background:var(--bg)}
.section--dark{background:var(--primary-dk);color:var(--white)}
.section--dark h2,.section--dark h3,.section--dark p{color:var(--white)}

.label{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:.55rem}
.lead{font-size:1.05rem;color:var(--muted);max-width:600px;margin-bottom:2.5rem}

.g2{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}

/* ── Buttons ───────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:.45rem;font-family:inherit;font-size:.92rem;font-weight:600;border-radius:var(--radius);cursor:pointer;border:2px solid transparent;padding:.7rem 1.6rem;transition:all var(--trans);white-space:nowrap;text-decoration:none}
.btn-primary{background:var(--accent);color:var(--white);border-color:var(--accent)}
.btn-primary:hover{background:var(--accent-dk);border-color:var(--accent-dk);color:var(--white);transform:translateY(-1px);box-shadow:0 6px 18px rgba(232,114,12,.32)}
.btn-dark{background:var(--primary);color:var(--white);border-color:var(--primary)}
.btn-dark:hover{background:var(--primary-dk);border-color:var(--primary-dk);color:var(--white);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--white);border-color:rgba(255,255,255,.5)}
.btn-ghost:hover{background:var(--white);color:var(--primary);border-color:var(--white)}
.btn svg{width:15px;height:15px;fill:currentColor;flex-shrink:0}

/* ── Header ────────────────────────────────────────────────── */
.site-header{position:sticky;top:0;z-index:900;background:var(--white);border-bottom:1px solid var(--border);box-shadow:0 2px 10px rgba(0,0,0,.05)}

.topbar{background:var(--primary);padding:.38rem 0;font-size:.8rem;color:rgba(255,255,255,.8)}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}
.topbar-items{display:flex;gap:1.4rem}
.ti{display:flex;align-items:center;gap:.4rem}
.ti svg{width:13px;height:13px;fill:rgba(255,255,255,.7);flex-shrink:0}
.ti a{color:rgba(255,255,255,.8)}
.ti a:hover{color:var(--accent)}

.header-main{padding:.9rem 0}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem}

.site-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none}
.logo-box{width:42px;height:42px;background:var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.logo-box svg{width:24px;height:24px;fill:var(--white)}
.logo-name{font-size:1.1rem;font-weight:800;color:var(--primary);line-height:1.1;letter-spacing:-.01em}
.logo-sub{font-size:.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:500}

.nav-wrap{display:flex;align-items:center;gap:1.75rem}
.nav-list{display:flex;gap:.1rem}
.nav-list a{display:block;padding:.45rem .8rem;font-size:.93rem;font-weight:500;color:var(--text);border-radius:var(--radius);transition:all var(--trans)}
.nav-list a:hover,.nav-list .current-menu-item>a,.nav-list .current-page-ancestor>a{background:var(--bg);color:var(--primary)}

.hamburger{display:none;background:none;border:none;cursor:pointer;padding:.3rem;color:var(--text)}
.hamburger svg{width:26px;height:26px;display:block}

.mob-nav{display:none;flex-direction:column;gap:.15rem;padding:1rem 1.5rem 1.5rem;background:var(--white);border-top:1px solid var(--border)}
.mob-nav.open{display:flex}
.mob-nav a{padding:.7rem 1rem;font-size:.95rem;font-weight:500;border-radius:var(--radius);color:var(--text)}
.mob-nav a:hover{background:var(--bg);color:var(--primary)}
.mob-nav .btn{width:100%;justify-content:center;margin-top:.4rem}

/* ── Page hero (inner pages) ───────────────────────────────── */
.page-hero{background:linear-gradient(135deg,var(--primary-dk) 0%,var(--primary) 100%);padding:52px 0 46px;color:var(--white)}
.page-hero h1{color:var(--white);margin-bottom:.4rem}
.breadcrumb{font-size:.82rem;color:rgba(255,255,255,.55)}
.breadcrumb a{color:rgba(255,255,255,.55)}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb .sep{margin:0 .35rem}

/* ── Homepage hero ─────────────────────────────────────────── */
.home-hero{position:relative;background:linear-gradient(135deg,var(--primary-dk) 0%,#1e4d75 100%);color:var(--white);padding:96px 0 88px;overflow:hidden}
.home-hero::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E") repeat;pointer-events:none}
.home-hero-inner{position:relative;max-width:700px}
.hero-badge{display:inline-flex;align-items:center;gap:.4rem;font-size:.73rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);background:rgba(232,114,12,.12);border:1px solid rgba(232,114,12,.3);border-radius:20px;padding:.3rem .9rem;margin-bottom:1.1rem}
.hero-badge svg{width:13px;height:13px;fill:var(--accent)}
.home-hero h1{color:var(--white);margin-bottom:1.1rem;max-width:580px}
.hero-desc{font-size:1.08rem;color:rgba(255,255,255,.8);margin-bottom:1.9rem;max-width:520px}
.hero-btns{display:flex;gap:.9rem;flex-wrap:wrap}
.hero-stats{display:flex;gap:2.5rem;margin-top:2.5rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.12)}
.hs-num{display:block;font-size:1.75rem;font-weight:800;color:var(--accent);line-height:1}
.hs-lbl{font-size:.78rem;color:rgba(255,255,255,.6);margin-top:.15rem}

/* ── USP strip ─────────────────────────────────────────────── */
.usp-strip{background:var(--accent);padding:1rem 0}
.usp-list{display:flex;justify-content:space-around;flex-wrap:wrap;gap:.6rem}
.usp-item{display:flex;align-items:center;gap:.5rem;color:var(--white);font-size:.87rem;font-weight:600}
.usp-item svg{width:17px;height:17px;fill:var(--white);flex-shrink:0}

/* ── Service cards ─────────────────────────────────────────── */
.svc-card{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:1.75rem;transition:all var(--trans);position:relative;overflow:hidden}
.svc-card::after{content:'';position:absolute;bottom:0;left:0;width:100%;height:3px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform var(--trans)}
.svc-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.svc-card:hover::after{transform:scaleX(1)}
.svc-icon{width:48px;height:48px;background:rgba(26,58,92,.08);border-radius:9px;display:flex;align-items:center;justify-content:center;margin-bottom:1.1rem}
.svc-icon svg{width:26px;height:26px;fill:var(--primary)}
.svc-card h3{font-size:1.05rem;margin-bottom:.5rem}
.svc-card p{font-size:.88rem;color:var(--muted);margin-bottom:0}

/* ── Feature rows (about, dienst detail) ───────────────────── */
.feat-row{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center}
.feat-row.flip .feat-text{order:2}
.feat-row.flip .feat-visual{order:1}
.feat-visual{border-radius:12px;overflow:hidden;background:linear-gradient(135deg,var(--primary) 0%,#2d5f8e 100%);aspect-ratio:4/3;display:flex;align-items:center;justify-content:center}
.feat-placeholder{display:flex;flex-direction:column;align-items:center;gap:.8rem;color:rgba(255,255,255,.45);font-size:.82rem;text-align:center;padding:2rem}
.feat-placeholder svg{width:56px;height:56px;fill:rgba(255,255,255,.35)}
.feat-checks{margin:1.25rem 0;display:flex;flex-direction:column;gap:.6rem}
.feat-check{display:flex;align-items:flex-start;gap:.7rem;font-size:.9rem}
.feat-check svg{width:18px;height:18px;fill:var(--accent);flex-shrink:0;margin-top:1px}

/* ── Brand grid ─────────────────────────────────────────────── */
.brand-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.9rem;margin-top:1.75rem}
.brand-item{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:1.2rem .8rem;display:flex;align-items:center;justify-content:center;font-size:.88rem;font-weight:700;color:var(--muted);text-align:center;min-height:72px;transition:all var(--trans)}
.brand-item:hover{border-color:var(--primary);color:var(--primary);box-shadow:var(--shadow);transform:translateY(-2px)}

/* ── CTA banner ────────────────────────────────────────────── */
.cta-section{background:linear-gradient(135deg,var(--primary-dk) 0%,var(--primary) 100%);padding:68px 0;text-align:center}
.cta-section h2{color:var(--white);margin-bottom:.8rem}
.cta-section p{color:rgba(255,255,255,.72);font-size:1.05rem;margin-bottom:1.8rem;max-width:520px;margin-left:auto;margin-right:auto}
.cta-btns{display:flex;gap:.9rem;justify-content:center;flex-wrap:wrap}

/* ── Contact ────────────────────────────────────────────────── */
.contact-layout{display:grid;grid-template-columns:1fr 1.7fr;gap:3.5rem;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:1.4rem}
.ci{display:flex;align-items:flex-start;gap:.9rem}
.ci-icon{width:42px;height:42px;background:rgba(26,58,92,.08);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ci-icon svg{width:20px;height:20px;fill:var(--primary)}
.ci-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:.15rem}
.ci-value{font-size:.92rem;font-weight:600}
.ci-value a{color:var(--primary)}
.ci-value a:hover{color:var(--accent)}
.opening-uren{margin-top:.25rem;font-size:.83rem;color:var(--muted);font-weight:400}
.map-wrap{border-radius:10px;overflow:hidden;border:1px solid var(--border);margin-top:.5rem}

/* ── Contact form ───────────────────────────────────────────── */
.cf-wrap{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:2.25rem;box-shadow:var(--shadow)}
.cf-wrap h3{margin-bottom:1.4rem;font-size:1.15rem}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.fg{margin-bottom:1.1rem}
.fg label{display:block;font-size:.82rem;font-weight:600;margin-bottom:.38rem}
.fg label .r{color:var(--accent)}
.fg input,.fg textarea,.fg select{width:100%;padding:.7rem .95rem;font-size:.92rem;font-family:inherit;color:var(--text);background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);outline:none;transition:border-color var(--trans),box-shadow var(--trans);-webkit-appearance:none;appearance:none}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--primary);background:var(--white);box-shadow:0 0 0 3px rgba(26,58,92,.09)}
.fg textarea{resize:vertical;min-height:120px}
/* Honeypot – verborgen voor mensen, bots vullen het in */
.fg-hp{position:absolute;left:-9999px;top:-9999px;opacity:0;height:0;overflow:hidden;pointer-events:none;tab-index:-1}
.privacy-row{display:flex;align-items:flex-start;gap:.55rem;font-size:.8rem;color:var(--muted);margin-bottom:1.1rem}
.privacy-row input[type=checkbox]{width:auto;margin-top:2px;flex-shrink:0}
.privacy-row a{color:var(--primary);text-decoration:underline}
.cf-note{font-size:.74rem;color:var(--muted);text-align:center;margin-top:.8rem}
.cf-note svg{width:13px;height:13px;fill:var(--muted);vertical-align:middle;margin-right:2px}
.msg{display:none;padding:.9rem 1.1rem;border-radius:var(--radius);font-size:.88rem;font-weight:600;margin-bottom:1rem}
.msg-ok{background:#d1fae5;color:#065f46;border:1px solid #6ee7b7}
.msg-err{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}

/* ── Footer ────────────────────────────────────────────────── */
.site-footer{background:var(--footer-bg);color:rgba(255,255,255,.7);padding-top:56px}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1.4fr;gap:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.07)}
.footer-brand p{font-size:.85rem;color:rgba(255,255,255,.55);margin:1rem 0 1.25rem;max-width:260px}
.footer-kvk{font-size:.75rem;color:rgba(255,255,255,.3)}
.fh{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--white);margin-bottom:.9rem}
.footer-links{display:flex;flex-direction:column;gap:.4rem}
.footer-links a{font-size:.85rem;color:rgba(255,255,255,.6)}
.footer-links a:hover{color:var(--accent)}
.fc-items{display:flex;flex-direction:column;gap:.65rem}
.fci{display:flex;align-items:flex-start;gap:.55rem;font-size:.83rem;color:rgba(255,255,255,.6)}
.fci svg{width:14px;height:14px;fill:var(--accent);flex-shrink:0;margin-top:2px}
.fci a{color:rgba(255,255,255,.6)}
.fci a:hover{color:var(--accent)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.6rem;padding:1.3rem 0;font-size:.76rem;color:rgba(255,255,255,.35)}
.footer-bottom a{color:rgba(255,255,255,.35)}
.footer-bottom a:hover{color:var(--accent)}
.fbl{display:flex;gap:1.4rem}

/* ── Responsive ─────────────────────────────────────────────── */
@media(max-width:1024px){
  .g4{grid-template-columns:1fr 1fr}
  .brand-grid{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .section{padding:50px 0}
  .g2,.g3,.feat-row,.contact-layout{grid-template-columns:1fr;gap:1.5rem}
  .feat-row.flip .feat-text,.feat-row.flip .feat-visual{order:unset}
  .home-hero{padding:64px 0 56px}
  .hero-stats{flex-wrap:wrap;gap:1.5rem}
  .brand-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .cf-row{grid-template-columns:1fr}
  .nav-wrap{display:none}
  .hamburger{display:flex}
}
@media(max-width:480px){
  .usp-list{flex-direction:column;align-items:center}
  .cta-btns,.hero-btns{flex-direction:column;align-items:center}
}
