/* ============================================================
  HODOMOBILE, PAGE COMPONENTS (content pages + admin)
  Bovenop base.css; alles via tokens.
  ============================================================ */

/* page hero (compact) */
.page-hero{padding:64px 0 30px;border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.page-hero .eyebrow{margin-bottom:16px}
.page-hero h1{font-size:clamp(2.2rem,4.6vw,3.4rem)}
.page-hero h1 .em{font-style:var(--display-em-style,italic);color:var(--brand)}
.page-hero p{color:var(--text-2);font-size:1.15rem;margin-top:14px;max-width:60ch}
.page-hero .hero-actions{display:flex;gap:12px;margin-top:26px;flex-wrap:wrap}

/* prose */
.prose{max-width:68ch}
.prose p{color:var(--text-2);font-size:1.06rem;margin-bottom:18px;line-height:1.7}
.prose h2{font-size:1.7rem;margin:36px 0 14px}
.prose h3{font-size:1.2rem;margin:24px 0 8px}
.prose strong{color:var(--text)}

/* two-column feature */
.split2{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.split2 .ph{min-height:360px;height:100%}
.split2.reverse .media{order:-1}

/* service section list */
.svc-section{display:grid;grid-template-columns:auto 1fr auto;gap:28px;align-items:start;padding:34px 0;border-bottom:1px solid var(--line)}
.svc-section .s-ico{width:60px;height:60px;border-radius:var(--ico-radius);background:var(--brand-tint);color:var(--brand);display:grid;place-items:center;font-size:1.6rem}
.svc-section h2{font-size:1.5rem;margin-bottom:8px}
.svc-section p{color:var(--text-2);max-width:60ch}
.svc-section .s-price{text-align:right;white-space:nowrap}
.svc-section .s-price b{font-family:var(--font-display);font-size:1.4rem;display:block}
.svc-section .s-price small{color:var(--text-2);font-family:var(--font-mono);font-size:.68rem;text-transform:uppercase}

/* tabs / segmented */
.segtabs{display:inline-flex;background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:4px;gap:3px;flex-wrap:wrap}
.segtabs button{border:0;background:none;font:inherit;font-weight:600;font-size:.92rem;color:var(--text-2);padding:9px 16px;border-radius:9px;cursor:pointer;transition:.15s}
.segtabs button.on{background:var(--brand);color:var(--on-brand)}

/* price table */
.ptable-wrap{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;overflow-x:auto}
table.ptable{width:100%;border-collapse:collapse;min-width:560px}
table.ptable th,table.ptable td{padding:15px 18px;text-align:left;border-bottom:1px solid var(--line)}
table.ptable thead th{background:var(--surface-2);font-family:var(--font-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-2);font-weight:700}
table.ptable tbody tr{transition:background .15s}
table.ptable tbody tr:hover{background:var(--surface-2)}
table.ptable td.model{font-weight:600}
table.ptable td.price{font-family:var(--font-display);font-weight:600;white-space:nowrap}
table.ptable td .oa{color:var(--text-2);font-family:var(--font-body);font-weight:500;font-size:.9rem}

/* disclaimer / callout */
.callout{display:flex;gap:14px;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px}
.callout.accent{background:color-mix(in srgb,var(--accent) 8%,var(--surface));border-color:color-mix(in srgb,var(--accent) 30%,var(--line))}
.callout .ci{width:30px;height:30px;border-radius:8px;background:var(--brand);color:var(--on-brand);display:grid;place-items:center;flex:none;font-weight:700}
.callout.accent .ci{background:var(--accent);color:#fff}
.callout b{display:block;margin-bottom:3px}
.callout p{color:var(--text-2);font-size:.92rem;margin:0}

/* faq */
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;text-align:left;background:none;border:0;font:inherit;font-weight:600;font-size:1.08rem;color:var(--text);padding:20px 0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq-q .pm{color:var(--brand);font-size:1.4rem;transition:transform .2s;flex:none}
.faq-q[aria-expanded="true"] .pm{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s var(--ease)}
.faq-a p{color:var(--text-2);padding-bottom:20px;max-width:64ch}

/* forms */
.form-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-xl);padding:34px;box-shadow:var(--shadow-lg)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.fld{margin-bottom:18px}
.fld.full{grid-column:1/-1}
.fld label{display:block;font-weight:600;margin-bottom:7px;font-size:.92rem}
.fld label .req{color:var(--accent)}
.fld input,.fld select,.fld textarea{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:11px;background:var(--surface-2);color:var(--text);font:inherit;font-size:1rem}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:none;border-color:var(--brand)}
.fld .hint{color:var(--text-2);font-size:.8rem;margin-top:5px}
.filedrop{border:1.5px dashed var(--line);border-radius:12px;padding:22px;text-align:center;color:var(--text-2);cursor:pointer;transition:.15s;background:var(--surface-2)}
.filedrop:hover{border-color:var(--brand);color:var(--text)}
.filedrop.has{border-color:var(--brand);color:var(--text)}
.consent{display:flex;gap:12px;align-items:flex-start;background:var(--surface-2);border:1px solid var(--line);border-radius:11px;padding:16px;cursor:pointer}
.consent input{width:20px;height:20px;margin-top:2px;flex:none;accent-color:var(--brand)}
.consent span{font-size:.9rem;color:var(--text-2)}
.form-ok{display:none;text-align:center;padding:30px 10px}
.form-ok.show{display:block}
.form-ok .big{width:74px;height:74px;border-radius:50%;background:color-mix(in srgb,#1f8a5b 18%,var(--surface));color:#22a366;display:grid;place-items:center;font-size:2rem;margin:0 auto 18px}

/* status pill */
.pill{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:.66rem;text-transform:uppercase;letter-spacing:.05em;font-weight:700;padding:5px 11px;border-radius:999px}
.pill .d{width:7px;height:7px;border-radius:50%;background:currentColor}
.pill.req{color:#b07a00;background:#fff5e0}
.pill.confirmed{color:#1f6fb8;background:#e7f1fa}
.pill.progress{color:#7a3fd0;background:#f0e9fc}
.pill.done{color:#1f8a5b;background:#e6f4ec}
.pill.cancel{color:#b8392f;background:#fdeceb}
.pill.contact{color:#c0392b;background:#fdeceb}
html[data-theme="b"] .pill.req{color:#e6b450;background:rgba(230,180,80,.14)}
html[data-theme="b"] .pill.confirmed{color:#5aa6f0;background:rgba(90,166,240,.14)}
html[data-theme="b"] .pill.progress{color:#b89cf0;background:rgba(150,120,240,.16)}
html[data-theme="b"] .pill.done{color:#4cc38a;background:rgba(76,195,138,.14)}
html[data-theme="b"] .pill.cancel,html[data-theme="b"] .pill.contact{color:#ff6b6b;background:rgba(227,6,19,.16)}

/* info grid */
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.info-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.info-card .ic{width:44px;height:44px;border-radius:var(--ico-radius);background:var(--brand-tint);color:var(--brand);display:grid;place-items:center;font-size:1.2rem;margin-bottom:14px}
.info-card h3{font-size:1.1rem;margin-bottom:6px}
.info-card p{color:var(--text-2);font-size:.94rem}

@media(max-width:820px){
 .split2{grid-template-columns:1fr;gap:30px}
 .split2.reverse .media{order:0}
 .form-grid,.info-grid{grid-template-columns:1fr}
 .svc-section{grid-template-columns:auto 1fr;gap:18px}
 .svc-section .s-price{grid-column:2;text-align:left}
}

@media(max-width:560px){
 .page-hero{padding:44px 0 26px}
 .form-card{padding:24px 18px}
 .prose p{font-size:1rem}
 .prose h2{font-size:1.45rem}
 .split2 .ph{min-height:240px}
 .svc-section{padding:26px 0}
 .svc-section .s-ico{width:48px;height:48px;font-size:1.3rem}
 .svc-section h2{font-size:1.3rem}
 .info-card{padding:20px}
 .segtabs{width:100%}
 .segtabs button{flex:1 1 auto;text-align:center}
 /* prijstabel wordt op mobiel een lijst van overzichtelijke kaarten i.p.v. een brede tabel */
 .ptable-wrap{border:0;border-radius:0;overflow:visible;background:transparent}
 table.ptable{min-width:0;display:block}
 table.ptable thead{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}
 table.ptable tbody{display:block}
 table.ptable tbody tr{display:block;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);margin-bottom:12px;overflow:hidden}
 table.ptable tbody tr:hover{background:var(--surface)}
 table.ptable td{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 16px;border-bottom:1px solid var(--line)}
 table.ptable td:last-child{border-bottom:0}
 table.ptable td.model{font-family:var(--font-display);font-size:1.08rem;font-weight:700;background:var(--surface-2);padding:13px 16px}
 table.ptable td.price{justify-content:space-between}
 table.ptable td.price::before{content:attr(data-label);font-family:var(--font-mono);font-size:.66rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-2);font-weight:700}
 table.ptable td.price .oa{font-size:.95rem}
}
.soc-ico{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:11px;border:1px solid var(--line);background:var(--surface);color:var(--text-2);transition:.15s}
.soc-ico:hover{color:var(--brand);border-color:var(--brand);transform:translateY(-1px)}
.soc-ico svg{width:20px;height:20px;display:block}
