/* ═══════════════════════════════════════════════════════
   VoresByer Plugin — Design System
   Farver: Teal #417572, Gold #B8952A, Cream #FDFAF4
═══════════════════════════════════════════════════════ */

:root {
    --vb-teal:        #417572;
    --vb-teal-mid:    #4f8d89;
    --vb-teal-light:  #e8f0f0;
    --vb-gold:        #B8952A;
    --vb-gold-mid:    #D4A843;
    --vb-gold-light:  #F5EDD6;
    --vb-cream:       #FDFAF4;
    --vb-border:      rgba(184,149,42,0.18);
    --vb-border-mid:  rgba(184,149,42,0.35);
    --vb-text:        #1E1E1E;
    --vb-muted:       #6B6B5A;
    --vb-radius:      10px;
    --vb-radius-lg:   16px;
    --vb-sidebar-w:   210px;
    --vb-shadow:      0 1px 4px rgba(0,0,0,0.06);
}

/* ── Reset ──────────────────────────────────────────── */
.vb-page *, .vb-dash * { box-sizing: border-box; }
.vb-page, .vb-dash { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; color: var(--vb-text); font-size: 14px; line-height: 1.5; }

/* ══════════════════════════════════════════════════════
   SIGNUP PAGE
══════════════════════════════════════════════════════ */
.vb-page { background: var(--vb-cream); min-height: 500px; }
.vb-page--narrow { max-width: 480px; margin: 40px auto; padding: 0 16px; }

/* Stepper */
.vb-stepper { display: flex; align-items: center; background: #fff; border-bottom: 0.5px solid var(--vb-border); padding: 18px 28px; }
.vb-step { display: flex; align-items: center; gap: 8px; flex: 1; }
.vb-step__num {
    width: 28px; height: 28px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 12px; font-weight: 600; flex-shrink: 0;
    border: 1.5px solid var(--vb-border);
    color: #888; background: #fff;
}
.vb-step--active .vb-step__num { background: var(--vb-teal); border-color: var(--vb-teal); color: #fff; }
.vb-step--done   .vb-step__num { background: var(--vb-gold); border-color: var(--vb-gold); color: #fff; }
.vb-step__label { font-size: 12px; color: #888; }
.vb-step--active .vb-step__label { color: var(--vb-teal); font-weight: 600; }
.vb-step--done   .vb-step__label { color: var(--vb-gold); }
.vb-step-line { flex: 1; height: 1px; background: var(--vb-border); margin: 0 8px; }
.vb-step-line--done { background: var(--vb-gold); }

/* Form area */
.vb-form-area { max-width: 620px; margin: 0 auto; padding: 28px 20px 40px; }

/* Cards */
.vb-card {
    background: #fff; border: 0.5px solid var(--vb-border);
    border-radius: var(--vb-radius-lg); padding: 22px;
    margin-bottom: 14px;
}
.vb-card--cream { background: var(--vb-cream); }
.vb-card--center { text-align: center; padding: 48px 28px; }
.vb-card--center h2 { font-size: 20px; margin: 0 0 10px; color: var(--vb-teal); }
.vb-card--center p { color: var(--vb-muted); margin-bottom: 24px; }

.vb-card__title {
    font-size: 11px; font-weight: 600; letter-spacing: 0.08em;
    text-transform: uppercase; color: var(--vb-gold);
    margin-bottom: 18px; display: flex; align-items: center; gap: 8px;
}

/* Form fields */
.vb-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 14px; }
.vb-form-row--full { grid-template-columns: 1fr; }
.vb-field { display: flex; flex-direction: column; gap: 5px; }
.vb-field label { font-size: 12px; font-weight: 600; color: var(--vb-muted); }
.vb-field input,
.vb-field select,
.vb-field textarea {
    border: 1px solid var(--vb-border);
    border-radius: 8px; padding: 10px 12px;
    font-size: 13px; color: var(--vb-text);
    background: var(--vb-cream); outline: none;
    font-family: inherit; transition: border-color 0.15s;
    width: 100%;
}
.vb-field input:focus,
.vb-field select:focus,
.vb-field textarea:focus { border-color: var(--vb-teal); background: #fff; }
.vb-field textarea { resize: vertical; }
.vb-hint { font-size: 11px; color: #aaa; }

/* Category grid */
.vb-cat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-top: 8px; }
.vb-cat-opt {
    border: 1px solid var(--vb-border); border-radius: 8px;
    padding: 12px 8px; text-align: center; cursor: pointer;
    font-size: 12px; color: var(--vb-muted); background: var(--vb-cream);
    transition: all 0.15s; display: flex; flex-direction: column; align-items: center; gap: 6px;
}
.vb-cat-opt .dashicons { font-size: 20px; color: var(--vb-gold); }
.vb-cat-opt:hover { border-color: var(--vb-gold); }
.vb-cat-opt--selected { border-color: var(--vb-teal); background: var(--vb-teal); color: #fff; }
.vb-cat-opt--selected .dashicons { color: var(--vb-gold-mid); }

/* Geo */
.vb-geo-wrap { position: relative; }
.vb-geo-icon {
    position: absolute; right: 10px; top: 50%;
    transform: translateY(-50%); color: #ccc; font-size: 18px;
}
.vb-autocomplete {
    position: absolute; z-index: 100; width: 100%;
    background: #fff; border: 1px solid var(--vb-border);
    border-top: none; border-radius: 0 0 8px 8px;
    list-style: none; padding: 0; margin: 0;
    max-height: 240px; overflow-y: auto;
}
.vb-autocomplete li {
    padding: 10px 14px; cursor: pointer; font-size: 13px;
    border-bottom: 0.5px solid var(--vb-border);
}
.vb-autocomplete li:hover { background: var(--vb-cream); }
.vb-geo-result {
    display: flex; align-items: center; gap: 8px;
    background: var(--vb-gold-light); border: 0.5px solid var(--vb-gold);
    border-radius: 8px; padding: 8px 12px;
    font-size: 12px; color: var(--vb-teal); margin-top: 6px;
}
.vb-geo-result .dashicons { color: var(--vb-gold); font-size: 18px; }

/* Summary table */
.vb-summary-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.vb-summary-table tr td:first-child { color: var(--vb-muted); padding: 7px 0; border-bottom: 0.5px solid var(--vb-border); }
.vb-summary-table tr td:last-child { font-weight: 600; padding: 7px 0; border-bottom: 0.5px solid var(--vb-border); text-align: right; }
.vb-summary-table tr:last-child td { border: none; }

/* Buttons */
.vb-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 10px 20px; border-radius: 8px; font-size: 13px;
    font-weight: 600; cursor: pointer; border: none;
    text-decoration: none; transition: opacity 0.15s;
}
.vb-btn:hover { opacity: 0.88; }
.vb-btn--primary { background: var(--vb-teal); color: #fff; }
.vb-btn--secondary { background: #fff; color: var(--vb-muted); border: 0.5px solid var(--vb-border); }
.vb-btn--secondary:hover { border-color: var(--vb-gold); color: var(--vb-teal); }
.vb-btn--full { width: 100%; justify-content: center; }
.vb-btn--sm { padding: 7px 14px; font-size: 12px; }
.vb-btn-icon { background: none; border: none; cursor: pointer; color: var(--vb-muted); padding: 4px; border-radius: 4px; }
.vb-btn-icon:hover { color: var(--vb-teal); background: var(--vb-teal-light); }

.vb-btn-row { display: flex; justify-content: space-between; align-items: center; margin-top: 18px; }
.vb-terms { font-size: 12px; color: #aaa; text-align: center; margin-top: 10px; }
.vb-terms a { color: var(--vb-gold); }

/* Success icon */
.vb-success-icon {
    width: 64px; height: 64px; border-radius: 50%;
    background: var(--vb-gold-light); border: 2px solid var(--vb-gold);
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 20px;
}
.vb-success-icon .dashicons { font-size: 28px; color: var(--vb-gold); }

/* Info / error boxes */
.vb-info-box {
    background: var(--vb-gold-light); border-radius: 8px;
    padding: 10px 14px; font-size: 12px; color: var(--vb-teal);
    display: flex; align-items: flex-start; gap: 8px;
}
.vb-info-box .dashicons { color: var(--vb-gold); font-size: 17px; flex-shrink: 0; margin-top: 1px; }
.vb-error { background: #fcebeb; border: 0.5px solid #f09595; border-radius: 8px; padding: 10px 14px; font-size: 13px; color: #A32D2D; margin-top: 12px; }
.vb-success { background: #eaf3de; border: 0.5px solid #97c459; border-radius: 8px; padding: 10px 14px; font-size: 13px; color: #3B6D11; margin-top: 12px; }
.vb-notice { background: var(--vb-gold-light); border-radius: 8px; padding: 14px 18px; font-size: 13px; }
.vb-notice a { color: var(--vb-teal); }

/* Login page */
.vb-login-header { text-align: center; margin-bottom: 24px; }
.vb-login-logo { font-size: 22px; font-weight: 700; color: var(--vb-teal); margin-bottom: 6px; }
.vb-login-logo strong { color: var(--vb-text); }
.vb-login-header p { color: var(--vb-muted); font-size: 13px; }
.vb-remember-row { display: flex; justify-content: space-between; align-items: center; margin: 10px 0 14px; font-size: 12px; color: var(--vb-muted); }
.vb-remember-row a { color: var(--vb-gold); text-decoration: none; }
.vb-login-footer { text-align: center; margin-top: 16px; font-size: 13px; color: var(--vb-muted); }
.vb-login-footer a { color: var(--vb-teal); text-decoration: none; }

/* ══════════════════════════════════════════════════════
   DASHBOARD
══════════════════════════════════════════════════════ */
.vb-dash { display: flex; min-height: 90vh; background: var(--vb-cream); }

/* Sidebar */
.vb-sidebar {
    width: var(--vb-sidebar-w); background: var(--vb-teal);
    display: flex; flex-direction: column; flex-shrink: 0;
    position: sticky; top: 0; height: 100vh; overflow-y: auto;
}
.vb-sb-logo { padding: 18px 18px 14px; font-size: 15px; font-weight: 700; color: var(--vb-gold-mid); border-bottom: 0.5px solid rgba(255,255,255,0.08); }
.vb-sb-logo strong { color: #fff; }
.vb-sb-biz { padding: 14px 16px; border-bottom: 0.5px solid rgba(255,255,255,0.08); }
.vb-sb-biz-name { font-size: 13px; font-weight: 600; color: #fff; margin-bottom: 2px; }
.vb-sb-biz-meta { font-size: 11px; color: rgba(255,255,255,0.5); }
.vb-pkg-badge { display: inline-flex; align-items: center; gap: 4px; margin-top: 7px; font-size: 10px; padding: 2px 9px; border-radius: 4px; background: var(--vb-gold); color: #fff; font-weight: 600; }
.vb-sb-section { padding: 14px 16px 4px; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(255,255,255,0.35); display: block; }
.vb-sb-nav { list-style: none; padding: 0 8px; margin: 0 0 4px; }
.vb-sb-nav li a {
    display: flex; align-items: center; gap: 9px;
    padding: 9px 10px; border-radius: 8px;
    font-size: 13px; color: rgba(255,255,255,0.65);
    text-decoration: none; cursor: pointer; transition: background 0.1s;
}
.vb-sb-nav li a .dashicons { font-size: 16px; color: rgba(255,255,255,0.4); }
.vb-sb-nav li a:hover { background: rgba(255,255,255,0.08); color: #fff; }
.vb-sb-nav li a:hover .dashicons { color: var(--vb-gold-mid); }
.vb-sb-nav li a.vb-nav-link--active { background: rgba(255,255,255,0.12); color: #fff; }
.vb-sb-nav li a.vb-nav-link--active .dashicons { color: var(--vb-gold-mid); }
.vb-sb-bottom { margin-top: auto; padding: 10px 8px; border-top: 0.5px solid rgba(255,255,255,0.08); }

/* Main */
.vb-main { flex: 1; display: flex; flex-direction: column; min-width: 0; overflow: hidden; }
.vb-topbar { background: #fff; border-bottom: 0.5px solid var(--vb-border); padding: 0 22px; height: 52px; display: flex; align-items: center; justify-content: space-between; flex-shrink: 0; }
.vb-topbar-title { font-size: 15px; font-weight: 600; color: var(--vb-teal); }
.vb-topbar-right { display: flex; align-items: center; gap: 10px; }
.vb-content { padding: 20px 22px; flex: 1; overflow-y: auto; }

/* Stat grid */
.vb-stat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-bottom: 16px; }
.vb-stat-card { background: #fff; border: 0.5px solid var(--vb-border); border-radius: var(--vb-radius); padding: 14px 16px; }
.vb-stat-label { font-size: 11px; color: var(--vb-muted); margin-bottom: 6px; display: flex; align-items: center; gap: 6px; }
.vb-stat-label .dashicons { font-size: 15px; color: var(--vb-gold); }
.vb-stat-val { font-size: 24px; font-weight: 700; color: var(--vb-teal); }
.vb-stat-change { font-size: 11px; color: var(--vb-muted); margin-top: 3px; }

/* Quick actions */
.vb-quick-actions { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin-bottom: 16px; }
.vb-qa-btn { background: #fff; border: 0.5px solid var(--vb-border); border-radius: var(--vb-radius); padding: 14px 8px; text-align: center; cursor: pointer; font-size: 12px; color: var(--vb-muted); transition: border-color 0.15s; }
.vb-qa-btn:hover { border-color: var(--vb-gold); color: var(--vb-teal); }
.vb-qa-btn .dashicons { display: block; font-size: 22px; color: var(--vb-gold); margin: 0 auto 6px; }

/* Two-col */
.vb-two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 14px; }
.vb-card-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.vb-card-title { font-size: 13px; font-weight: 600; color: var(--vb-teal); display: flex; align-items: center; gap: 7px; }
.vb-card-title .dashicons { font-size: 17px; color: var(--vb-gold); }
.vb-card-link { font-size: 12px; color: var(--vb-gold); cursor: pointer; text-decoration: none; }

/* Cover / avatar */
.vb-cover-wrap { position: relative; margin-bottom: 14px; }
.vb-cover-img { height: 76px; border-radius: 8px; background: var(--vb-teal); display: flex; align-items: center; justify-content: center; font-size: 12px; color: rgba(255,255,255,0.55); border: 2px dashed rgba(255,255,255,0.25); cursor: pointer; }
.vb-cover-img .dashicons { margin-right: 6px; }
.vb-avatar { position: absolute; bottom: -16px; left: 12px; width: 44px; height: 44px; border-radius: 10px; background: var(--vb-gold-light); border: 2px solid #fff; display: flex; align-items: center; justify-content: center; font-size: 20px; color: var(--vb-gold); cursor: pointer; }

/* Profile info */
.vb-profile-info { margin-top: 24px; }
.vb-profile-row { display: flex; justify-content: space-between; font-size: 12px; padding: 6px 0; border-bottom: 0.5px solid var(--vb-border); }
.vb-profile-row:last-child { border: none; }
.vb-profile-row span:first-child { color: var(--vb-muted); }
.vb-profile-row span:last-child, .vb-profile-row a { font-weight: 600; color: var(--vb-text); text-decoration: none; }
.vb-profile-row a { color: var(--vb-gold); }

/* Gallery */
.vb-gallery-mini, .vb-gallery-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; }
.vb-gal-item { aspect-ratio: 1; border-radius: 7px; background: var(--vb-cream); border: 1px dashed var(--vb-border); display: flex; align-items: center; justify-content: center; font-size: 20px; color: var(--vb-border); position: relative; overflow: hidden; }
.vb-gal-item--empty .dashicons { color: rgba(184,149,42,0.3); }
.vb-gal-item--upload { cursor: pointer; }
.vb-gal-item--upload .dashicons { color: var(--vb-gold); }
.vb-gal-delete { position: absolute; top: 4px; right: 4px; background: rgba(0,0,0,0.6); border: none; border-radius: 50%; width: 22px; height: 22px; cursor: pointer; color: #fff; display: flex; align-items: center; justify-content: center; padding: 0; }
.vb-gal-delete .dashicons { font-size: 13px; }

/* Upload area */
.vb-upload-area { border: 2px dashed var(--vb-border); border-radius: 10px; padding: 24px; text-align: center; cursor: pointer; position: relative; color: var(--vb-muted); transition: border-color 0.15s; }
.vb-upload-area:hover { border-color: var(--vb-gold); }
.vb-upload-area .dashicons { font-size: 28px; color: var(--vb-gold); display: block; margin-bottom: 6px; }
.vb-upload-area p { font-size: 13px; margin: 0; }
.vb-file-input { position: absolute; inset: 0; opacity: 0; cursor: pointer; width: 100%; height: 100%; }

/* Annonce cards */
.vb-ann-card { display: flex; align-items: center; gap: 10px; padding: 12px 14px; border-radius: 10px; background: var(--vb-cream); border: 0.5px solid var(--vb-border); margin-bottom: 8px; }
.vb-ann-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--vb-border); flex-shrink: 0; }
.vb-ann-dot--active { background: var(--vb-gold); }
.vb-ann-info { flex: 1; min-width: 0; }
.vb-ann-name { font-size: 13px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.vb-ann-meta { font-size: 11px; color: var(--vb-muted); }
.vb-ann-actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }

/* Badges */
.vb-badge { font-size: 11px; padding: 3px 9px; border-radius: 5px; font-weight: 600; display: inline-flex; align-items: center; gap: 4px; }
.vb-badge--green { background: #eaf3de; color: #3B6D11; }
.vb-badge--gray  { background: var(--vb-cream); color: var(--vb-muted); border: 0.5px solid var(--vb-border); }
.vb-badge--gold  { background: var(--vb-gold-light); color: var(--vb-gold); border: 0.5px solid rgba(184,149,42,0.3); }
.vb-badge .dashicons { font-size: 13px; }

/* Hours */
.vb-hours-row { display: flex; align-items: center; gap: 16px; padding: 10px 0; border-bottom: 0.5px solid var(--vb-border); }
.vb-hours-row:last-of-type { border: none; }
.vb-hours-day { width: 80px; font-size: 13px; font-weight: 600; flex-shrink: 0; }
.vb-toggle { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--vb-muted); flex-shrink: 0; width: 90px; }
.vb-hours-times { display: flex; align-items: center; gap: 8px; font-size: 13px; }
.vb-hours-times input { width: 96px; padding: 6px 10px; border: 1px solid var(--vb-border); border-radius: 6px; font-size: 13px; }
.vb-hidden { opacity: 0.3; pointer-events: none; }

/* Payment table */
.vb-pay-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.vb-pay-table th { text-align: left; color: var(--vb-muted); font-weight: 600; padding: 0 0 10px; border-bottom: 0.5px solid var(--vb-border); }
.vb-pay-table td { padding: 9px 0; border-bottom: 0.5px solid var(--vb-border); }
.vb-pay-table tr:last-child td { border: none; }

/* Panel title */
.vb-panel-title { font-size: 17px; font-weight: 600; color: var(--vb-teal); margin: 0 0 18px; }
.vb-empty { color: var(--vb-muted); font-size: 13px; padding: 16px 0; }

/* Admin styles */
.vb-admin { max-width: 900px; }
.vb-admin-stats { display: flex; gap: 20px; margin: 20px 0; }
.vb-admin-stat { background: var(--vb-teal); color: #fff; border-radius: 10px; padding: 18px 24px; text-align: center; }
.vb-admin-stat .num { font-size: 28px; font-weight: 700; display: block; }
.vb-admin-stat .lbl { font-size: 12px; opacity: 0.8; }

/* Responsive */
@media (max-width: 700px) {
    .vb-dash { flex-direction: column; }
    .vb-sidebar { width: 100%; height: auto; position: relative; }
    .vb-stat-grid { grid-template-columns: 1fr 1fr; }
    .vb-quick-actions { grid-template-columns: 1fr 1fr; }
    .vb-two-col { grid-template-columns: 1fr; }
    .vb-form-row { grid-template-columns: 1fr; }
    .vb-cat-grid { grid-template-columns: repeat(2, 1fr); }
}
