/* ── EVOAK Plugin CSS — Mahonie palette ─────────────────────────────────── */
:root {
  --ev-noir:    #0E0A06;
  --ev-mahonie: #2A1F14;
  --ev-goud:    #B09878;
  --ev-midden:  #8A7860;
  --ev-ivoor:   #D4C5A8;
  --ev-licht:   #F0E8D8;
  --ev-kers:    #6B1020;
  --ev-wit:     #FFFFFF;
  --ev-radius:  6px;
  --ev-font:    'Cormorant Garamond', Georgia, serif;
  --ev-heading: 'Cinzel Decorative', serif;
}

.evoak-wrap { font-family: var(--ev-font); color: var(--ev-noir); max-width: 760px; margin: 2rem auto; padding: 0 1rem; }
.evoak-wrap * { box-sizing: border-box; }
.hidden { display: none !important; }

/* ── STEP INDICATOR ────────────────────────────────────────────────────── */
.evoak-steps { display: flex; gap: .25rem; margin-bottom: 2rem; flex-wrap: wrap; }
.evoak-steps .step { padding: .4rem 1rem; border-radius: 2rem; font-size: .85rem; background: var(--ev-licht); color: var(--ev-midden); border: 1px solid var(--ev-ivoor); }
.evoak-steps .step.active { background: var(--ev-mahonie); color: var(--ev-ivoor); }
.evoak-steps .step.done  { background: var(--ev-ivoor); color: var(--ev-mahonie); }

/* ── HEADINGS ──────────────────────────────────────────────────────────── */
.evoak-wrap h2 { font-family: var(--ev-heading); color: var(--ev-mahonie); margin-bottom: .25rem; font-size: 1.5rem; }
.evoak-wrap h3 { color: var(--ev-mahonie); margin: 1.5rem 0 .5rem; font-size: 1.1rem; }
.evoak-sub   { color: var(--ev-midden); margin-bottom: 1.25rem; font-size: .95rem; font-style: italic; }

/* ── ZONE CARDS ─────────────────────────────────────────────────────────── */
.evoak-zones { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 1rem; margin-bottom: 1.5rem; }
.evoak-zone-card { border: 1.5px solid var(--ev-ivoor); border-radius: var(--ev-radius); padding: 1.25rem 1rem; cursor: pointer; background: var(--ev-wit); transition: border-color .2s, background .2s; }
.evoak-zone-card:hover { border-color: var(--ev-goud); background: var(--ev-licht); }
.evoak-zone-card.selected { border-color: var(--ev-mahonie); background: var(--ev-licht); box-shadow: 0 0 0 2px var(--ev-mahonie); }
.evoak-zone-card .zone-name  { font-weight: 600; color: var(--ev-mahonie); margin-bottom: .25rem; }
.evoak-zone-card .zone-meta  { font-size: .85rem; color: var(--ev-midden); margin-bottom: .4rem; }
.evoak-zone-card .zone-price { font-size: .9rem; color: var(--ev-kers); font-weight: 600; }

/* ── SLOT BUTTONS ───────────────────────────────────────────────────────── */
.evoak-slots { display: flex; flex-wrap: wrap; gap: .5rem; margin: 1rem 0; }
.evoak-slot-btn { padding: .5rem 1.25rem; border: 1.5px solid var(--ev-ivoor); border-radius: 2rem; cursor: pointer; background: var(--ev-wit); font-family: var(--ev-font); font-size: .95rem; transition: all .15s; }
.evoak-slot-btn:hover   { border-color: var(--ev-goud); background: var(--ev-licht); }
.evoak-slot-btn.selected{ border-color: var(--ev-mahonie); background: var(--ev-licht); font-weight: 600; box-shadow: 0 0 0 1.5px var(--ev-mahonie); }
.evoak-empty { color: var(--ev-midden); font-style: italic; }

/* ── OPTION CARDS (duration / addon) ───────────────────────────────────── */
.evoak-options { display: flex; flex-wrap: wrap; gap: .75rem; margin-bottom: 1.25rem; }
.evoak-option-card { border: 1.5px solid var(--ev-ivoor); border-radius: var(--ev-radius); padding: .8rem 1.25rem; cursor: pointer; background: var(--ev-wit); transition: all .15s; display: flex; flex-direction: column; gap: .2rem; min-width: 140px; }
.evoak-option-card:hover   { border-color: var(--ev-goud); background: var(--ev-licht); }
.evoak-option-card.selected{ border-color: var(--ev-mahonie); background: var(--ev-licht); box-shadow: 0 0 0 1.5px var(--ev-mahonie); }
.evoak-option-card strong  { color: var(--ev-mahonie); }
.evoak-option-card span, .addon-price { font-size: .82rem; color: var(--ev-midden); }

/* ── PRICE PREVIEW ──────────────────────────────────────────────────────── */
.evoak-price-box { background: var(--ev-licht); border: 1px solid var(--ev-ivoor); border-radius: var(--ev-radius); padding: 1rem 1.25rem; margin: 1.25rem 0; }
.price-row { display: flex; justify-content: space-between; padding: .3rem 0; font-size: .95rem; }
.price-row.bonus { color: var(--ev-kers); }
.price-row.total { border-top: 1px solid var(--ev-ivoor); margin-top: .5rem; padding-top: .5rem; font-size: 1.05rem; }
.veldgroei { color: var(--ev-kers); font-weight: 600; }

/* ── FORM FIELDS ────────────────────────────────────────────────────────── */
.evoak-field { margin-bottom: 1rem; }
.evoak-field label { display: block; font-size: .85rem; color: var(--ev-midden); margin-bottom: .3rem; }
.evoak-field input, .evoak-field textarea, .evoak-field select { width: 100%; padding: .6rem .9rem; border: 1.5px solid var(--ev-ivoor); border-radius: var(--ev-radius); font-family: var(--ev-font); font-size: 1rem; background: var(--ev-wit); color: var(--ev-noir); transition: border-color .15s; }
.evoak-field input:focus, .evoak-field textarea:focus { outline: none; border-color: var(--ev-mahonie); }

/* ── CHECK LABELS ───────────────────────────────────────────────────────── */
label.evoak-check { display: flex; align-items: center; gap: .6rem; margin-bottom: .6rem; cursor: pointer; font-size: .95rem; }
label.evoak-check input[type=checkbox] { width: 1.1rem; height: 1.1rem; accent-color: var(--ev-mahonie); }

/* ── BUTTONS ────────────────────────────────────────────────────────────── */
.evoak-btn { display: inline-block; padding: .7rem 1.75rem; border-radius: 2rem; border: none; cursor: pointer; font-family: var(--ev-font); font-size: 1rem; transition: all .15s; margin-top: 1rem; }
.evoak-btn:not(.secondary):not(.primary) { background: var(--ev-mahonie); color: var(--ev-ivoor); }
.evoak-btn:not(.secondary):not(.primary):hover { background: var(--ev-noir); }
.evoak-btn.secondary { background: transparent; color: var(--ev-midden); border: 1.5px solid var(--ev-ivoor); margin-right: .5rem; }
.evoak-btn.secondary:hover { border-color: var(--ev-mahonie); color: var(--ev-mahonie); }
.evoak-btn.primary  { background: var(--ev-kers); color: var(--ev-wit); font-weight: 600; }
.evoak-btn.primary:hover { background: #550d19; }
.evoak-btn:disabled { opacity: .45; cursor: not-allowed; }

/* ── SUMMARY ────────────────────────────────────────────────────────────── */
.evoak-summary-table { width: 100%; border-collapse: collapse; margin-bottom: 1.25rem; }
.evoak-summary-table td { padding: .5rem .75rem; border-bottom: 1px solid var(--ev-licht); font-size: .95rem; }
.evoak-summary-table td:first-child { color: var(--ev-midden); width: 40%; }
.evoak-summary-table .total-row td { border-top: 2px solid var(--ev-ivoor); padding-top: .75rem; font-size: 1.05rem; }

/* ── INFO BOX ───────────────────────────────────────────────────────────── */
.evoak-info-box { background: var(--ev-licht); border-left: 3px solid var(--ev-goud); border-radius: 0 var(--ev-radius) var(--ev-radius) 0; padding: .9rem 1.1rem; margin-bottom: 1.25rem; font-size: .9rem; color: var(--ev-mahonie); }
.evoak-info-box p { margin: .2rem 0; }

/* ── MESSAGES ───────────────────────────────────────────────────────────── */
.evoak-error   { color: var(--ev-kers); background: #fdf0f0; border: 1px solid #f5c6c6; border-radius: var(--ev-radius); padding: .75rem 1rem; margin: .75rem 0; font-size: .9rem; }
.evoak-success { color: #2a5c2a; background: #f0faf0; border: 1px solid #a8d8a8; border-radius: var(--ev-radius); padding: .75rem 1rem; margin: .75rem 0; }
.evoak-message { padding: 1.25rem; border-radius: var(--ev-radius); margin: 1rem 0; }

/* ── LOADING ────────────────────────────────────────────────────────────── */
.evoak-loading { text-align: center; padding: 2rem; color: var(--ev-midden); }
.evoak-spinner { width: 36px; height: 36px; border: 3px solid var(--ev-ivoor); border-top-color: var(--ev-mahonie); border-radius: 50%; animation: ev-spin .7s linear infinite; margin: 0 auto 1rem; }
@keyframes ev-spin { to { transform: rotate(360deg); } }

/* ── PORTAL ─────────────────────────────────────────────────────────────── */
.evoak-box { background: var(--ev-licht); border-radius: var(--ev-radius); padding: 2rem; max-width: 480px; }
.portal-header { margin-bottom: 1.5rem; }
.portal-stats  { display: flex; gap: 1.5rem; margin-top: .75rem; }
.portal-stats .stat { display: flex; flex-direction: column; }
.portal-stats .stat span { font-size: 1.4rem; font-weight: 600; color: var(--ev-mahonie); }
.portal-stats .stat small { font-size: .8rem; color: var(--ev-midden); }
.evoak-table { width: 100%; border-collapse: collapse; font-size: .9rem; }
.evoak-table th { text-align: left; padding: .4rem .6rem; background: var(--ev-mahonie); color: var(--ev-ivoor); }
.evoak-table td { padding: .45rem .6rem; border-bottom: 1px solid var(--ev-licht); }
.evoak-table tr:hover td { background: var(--ev-licht); }

/* ── ADMIN ──────────────────────────────────────────────────────────────── */
.evoak-admin .evoak-stats { display: flex; gap: 1.5rem; margin-bottom: 2rem; flex-wrap: wrap; }
.evoak-admin .stat { background: #fff; border: 1px solid #e0e0e0; border-radius: 4px; padding: 1.25rem 1.75rem; min-width: 160px; }
.evoak-admin .stat .num { display: block; font-size: 1.75rem; font-weight: 700; color: #2A1F14; }
.evoak-admin .stat .lbl { font-size: .8rem; color: #888; }
.status-confirmed { color: green; } .status-pending { color: orange; } .status-cancelled { color: red; } .status-completed { color: #555; }
