/*
Theme Name: KamerBusiness
Theme URI: https://kamerbusiness.com/
Author: GRIOTYS GROUP SARL
Author URI: https://griotys.com/
Description: Professional, SEO-friendly, Elementor-compatible WordPress theme for KamerBusiness directories, business mini-sites, local listings, jobs, products, services, WordPress-native company news, events and advertising placements. Version 2.3 adds Core v2.3 support, homepage customization, aligned ads, enriched job/event display and country-free frontend filters.
Version: 2.3.0
Requires at least: 6.5
Tested up to: 6.9
Requires PHP: 8.0
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: kamerbusiness
Tags: custom-logo, custom-colors, custom-menu, featured-images, translation-ready, wide-blocks, editor-style, grid-layout, one-column, two-columns
*/

:root {
  --kb-primary: #0e71b2;
  --kb-primary-dark: #075184;
  --kb-secondary: #fcf100;
  --kb-accent: #64a7d4;
  --kb-text: #182230;
  --kb-muted: #667085;
  --kb-bg: #ffffff;
  --kb-surface: #f8fafc;
  --kb-border: #e4e7ec;
  --kb-button: #0e71b2;
  --kb-whatsapp: #25d366;
  --kb-badge-premium: #f59e0b;
  --kb-badge-verified: #10b981;
  --kb-success: #12b76a;
  --kb-danger: #f04438;
  --kb-radius: 18px;
  --kb-radius-sm: 12px;
  --kb-shadow: 0 14px 34px rgba(16, 24, 40, .08);
  --kb-container: 1180px;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; color: var(--kb-text); background: var(--kb-bg); line-height: 1.6; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
a { color: var(--kb-primary); text-decoration: none; }
a:hover, a:focus { color: var(--kb-primary-dark); text-decoration: underline; }
img { max-width: 100%; height: auto; display: block; }
button, input, select, textarea { font: inherit; }
.screen-reader-text { position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden; }
.screen-reader-text:focus { position: static; width:auto; height:auto; padding:.5rem; background:#fff; z-index:9999; }
.kb-container { width: min(100% - 32px, var(--kb-container)); margin-inline: auto; }
.kb-section { padding: clamp(34px, 4.5vw, 68px) 0; }
.kb-section--soft { background: var(--kb-surface); }
.kb-grid { display: grid; gap: 20px; }
.kb-grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.kb-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.kb-grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.kb-muted { color: var(--kb-muted); }
.kb-rich-text > *:first-child { margin-top: 0; }

.kb-site-header { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,.97); backdrop-filter: blur(14px); border-bottom: 1px solid var(--kb-border); }
.admin-bar .kb-site-header { top: 32px; }
.kb-header-inner { min-height: 72px; display:flex; align-items:center; justify-content:space-between; gap:18px; }
.kb-brand { display:flex; align-items:center; gap:12px; color:var(--kb-text); font-weight:800; font-size:1.28rem; letter-spacing:-.03em; }
.kb-brand:hover { text-decoration:none; }
.kb-brand-mark { width:42px; height:42px; border-radius:12px; background:linear-gradient(135deg,var(--kb-primary),var(--kb-accent)); display:grid; place-items:center; color:#fff; font-weight:900; }
.custom-logo-link img { max-height:48px; width:auto; }
.kb-nav { display:flex; align-items:center; gap:18px; }
.kb-nav ul { list-style:none; display:flex; gap:16px; padding:0; margin:0; align-items:center; }
.kb-nav a { color:var(--kb-text); font-weight:650; font-size:.94rem; }
.kb-nav a:hover { color:var(--kb-primary); text-decoration:none; }
.kb-header-actions { display:flex; align-items:center; gap:10px; }
.kb-mobile-toggle { display:none; border:1px solid var(--kb-border); background:#fff; border-radius:10px; padding:8px 11px; }

.kb-user-menu { position: relative; }
.kb-user-toggle { border: 1px solid var(--kb-border); background:#fff; border-radius: 999px; padding: 6px 12px 6px 6px; display:flex; align-items:center; gap:8px; cursor:pointer; font-weight:700; }
.kb-user-toggle img { border-radius:50%; }
.kb-user-dropdown { display:none; position:absolute; right:0; top:calc(100% + 10px); min-width:220px; background:#fff; border:1px solid var(--kb-border); border-radius:14px; box-shadow:var(--kb-shadow); padding:8px; z-index:60; }
.kb-user-menu.is-open .kb-user-dropdown { display:grid; }
.kb-user-dropdown a { color:var(--kb-text); padding:10px 12px; border-radius:10px; font-weight:650; }
.kb-user-dropdown a:hover { background:var(--kb-surface); text-decoration:none; }

.kb-btn, .wp-block-button__link { display:inline-flex; align-items:center; justify-content:center; gap:8px; padding: 11px 17px; border-radius: 999px; background: var(--kb-button); color:#fff; font-weight:750; border:1px solid transparent; box-shadow: 0 8px 18px rgba(14,113,178,.16); transition: transform .18s ease, box-shadow .18s ease, background .18s ease; cursor:pointer; }
.kb-btn:hover, .kb-btn:focus, .wp-block-button__link:hover { transform:translateY(-1px); color:#fff; text-decoration:none; background:var(--kb-primary-dark); box-shadow:0 12px 24px rgba(14,113,178,.22); }
.kb-btn--outline { background:#fff; color:var(--kb-primary); border-color:var(--kb-border); box-shadow:none; }
.kb-btn--outline:hover { background:var(--kb-surface); color:var(--kb-primary-dark); }
.kb-btn--secondary { background:var(--kb-secondary); color:#111827; box-shadow:none; }
.kb-btn--secondary:hover { background:#e5db00; color:#111827; }
.kb-btn--whatsapp { background: var(--kb-whatsapp); color:#fff; box-shadow:0 8px 20px rgba(37,211,102,.22); }
.kb-btn--whatsapp:hover { background:#1dad54; color:#fff; }
.kb-wa-icon { width:20px; height:20px; }
.kb-btn--phone.is-revealed { padding:0; overflow:hidden; }
.kb-btn--phone.is-revealed a { color:#fff; padding:11px 17px; display:block; }
.kb-link-button { border:0; background:transparent; color:var(--kb-primary); cursor:pointer; font-weight:700; padding:0; }

.kb-hero { padding: clamp(46px, 6vw, 92px) 0; background: radial-gradient(circle at top left, rgba(100,167,212,.25), transparent 38%), linear-gradient(135deg, #f8fbff 0%, #ffffff 62%, rgba(252,241,0,.1) 100%); overflow:hidden; }
.kb-hero-layout { display:grid; grid-template-columns: 1.15fr .85fr; gap:34px; align-items:center; }
.kb-eyebrow { color:var(--kb-primary); font-weight:800; text-transform:uppercase; letter-spacing:.08em; font-size:.8rem; }
.kb-hero h1 { font-size: clamp(2.1rem, 4.7vw, 4.2rem); line-height:1.04; margin: 10px 0 16px; letter-spacing:-.055em; }
.kb-hero p { font-size: clamp(1rem, 1.45vw, 1.16rem); color:var(--kb-muted); max-width: 700px; }
.kb-search-panel { margin-top: 24px; background:#fff; border:1px solid var(--kb-border); border-radius: var(--kb-radius); padding: 14px; box-shadow: var(--kb-shadow); display:grid; grid-template-columns: 1.3fr repeat(5, minmax(120px, .7fr)) .7fr auto; gap:10px; align-items:end; }
.kb-search-panel input, .kb-search-panel select { border:1px solid var(--kb-border); border-radius:999px; padding:12px 14px; min-width:0; background:#fff; width:100%; }
.kb-filter-field { display:grid; gap:5px; }
.kb-filter-field span { font-size:.74rem; color:var(--kb-muted); font-weight:800; text-transform:uppercase; letter-spacing:.05em; padding-left:6px; }
.kb-filter-field--wide { min-width: 190px; }
.kb-hero-card { background:#fff; border:1px solid var(--kb-border); border-radius:26px; box-shadow: var(--kb-shadow); padding:24px; position:relative; }
.kb-stat-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
.kb-stat { border:1px solid var(--kb-border); border-radius:16px; padding:17px; background:var(--kb-surface); }
.kb-stat strong { display:block; font-size:1.65rem; color:var(--kb-primary); line-height:1.1; }
.kb-stat span { color:var(--kb-muted); font-size:.9rem; }

.kb-section-head { display:flex; align-items:flex-end; justify-content:space-between; gap:20px; margin-bottom:22px; }
.kb-section-head--compact { margin-bottom:14px; }
.kb-section-head h2 { margin:0; font-size: clamp(1.45rem, 2.5vw, 2.15rem); letter-spacing:-.04em; }
.kb-section-head p { margin:.35rem 0 0; color:var(--kb-muted); }
.kb-card { background:#fff; border:1px solid var(--kb-border); border-radius: var(--kb-radius); padding:20px; box-shadow: 0 6px 18px rgba(16,24,40,.04); transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.kb-card:hover { transform:translateY(-2px); box-shadow: var(--kb-shadow); border-color: rgba(14,113,178,.28); }
.kb-card h3 { margin: 0 0 8px; font-size:1.1rem; line-height:1.28; }
.kb-card p { margin: 0; color:var(--kb-muted); }
.kb-card img { border-radius:14px; margin-bottom:14px; width:100%; aspect-ratio: 16/10; object-fit:cover; }
.kb-card-meta { display:flex; flex-wrap:wrap; gap:8px; margin:10px 0; color:var(--kb-muted); font-size:.86rem; }
.kb-pill { display:inline-flex; border:1px solid var(--kb-border); border-radius:999px; padding:4px 10px; background:var(--kb-surface); font-size:.8rem; color:var(--kb-muted); font-weight:650; }
.kb-business-name-with-badges { display:inline-flex; align-items:center; gap:6px; }
.kb-badge-icon { display:inline-grid; place-items:center; font-size:1.05em; line-height:1; filter: drop-shadow(0 1px 0 rgba(0,0,0,.08)); }
.kb-badge-icon--verified { color:var(--kb-badge-verified); }
.kb-badge-icon--premium { color:var(--kb-badge-premium); }

.kb-ad-slot { margin: 24px auto; border:1px dashed #b8c4d4; background: repeating-linear-gradient(45deg,#f8fafc,#f8fafc 10px,#f2f4f7 10px,#f2f4f7 20px); border-radius: var(--kb-radius-sm); padding: 18px; text-align:center; color:var(--kb-muted); font-size:.92rem; }
.kb-ad-slot ins { display:block; }
.kb-ad-label { display:block; font-size:.75rem; letter-spacing:.08em; text-transform:uppercase; color:#98a2b3; margin-bottom:6px; }

.kb-business-single { background:var(--kb-surface); }
.kb-business-cover { min-height:260px; background:linear-gradient(135deg,var(--kb-primary),var(--kb-accent)); border-radius: 0 0 30px 30px; position:relative; overflow:hidden; }
.kb-business-cover img { width:100%; height:100%; object-fit:cover; position:absolute; inset:0; }
.kb-business-profile { margin-top:-76px; position:relative; z-index:2; padding-bottom:42px; }
.kb-business-panel { background:#fff; border:1px solid var(--kb-border); border-radius:26px; padding:24px; box-shadow:var(--kb-shadow); display:grid; grid-template-columns:auto 1fr minmax(180px, 260px); gap:20px; align-items:center; }
.kb-business-logo { width:108px; height:108px; border-radius:22px; background:#fff; border:1px solid var(--kb-border); display:grid; place-items:center; overflow:hidden; box-shadow:0 8px 24px rgba(16,24,40,.08); }
.kb-business-logo img { width:100%; height:100%; object-fit:contain; padding:10px; }
.kb-business-title h1 { margin:0; font-size:clamp(1.75rem,2.8vw,2.65rem); letter-spacing:-.04em; line-height:1.1; }
.kb-business-slogan { color:var(--kb-primary); font-weight:750; margin:.3rem 0; }
.kb-action-row { display:flex; gap:10px; flex-wrap:wrap; margin-top:14px; }
.kb-action-row--stack { display:grid; }
.kb-secondary-phone { margin-top:10px; }
.kb-business-content-layout { display:grid; grid-template-columns: minmax(0, 1fr) 320px; gap:24px; margin-top:24px; align-items:start; }
.kb-business-main-content { display:grid; gap:22px; }
.kb-business-section, .kb-business-accordions { background:#fff; border:1px solid var(--kb-border); border-radius:22px; padding:22px; box-shadow:0 6px 16px rgba(16,24,40,.035); }
.kb-video-embed iframe, .kb-video-embed embed, .kb-video-embed object { width:100%; aspect-ratio:16/9; height:auto; border:0; border-radius:18px; }
.kb-map-embed iframe { width:100%; min-height:340px; border:0; border-radius:18px; }
.kb-business-sidebar { display:grid; gap:18px; }
.kb-sticky-card { position:sticky; top:96px; }
.admin-bar .kb-sticky-card { top:128px; }
.kb-accordion-item { border:1px solid var(--kb-border); border-radius:16px; overflow:hidden; margin-bottom:12px; background:#fff; }
.kb-accordion-toggle { width:100%; display:flex; justify-content:space-between; align-items:center; border:0; background:var(--kb-surface); padding:16px 18px; color:var(--kb-text); font-weight:800; cursor:pointer; }
.kb-accordion-toggle span { font-size:1.2rem; color:var(--kb-primary); }
.kb-accordion-panel { display:none; padding:18px; }
.kb-accordion-panel.is-open { display:block; }
.kb-contact-form { display:grid; gap:14px; }
.kb-form-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px; }
.kb-contact-form label { display:grid; gap:6px; font-weight:650; }
.kb-contact-form input, .kb-contact-form select, .kb-contact-form textarea { border:1px solid var(--kb-border); border-radius:12px; padding:11px 12px; width:100%; }

.kb-tabs { margin-top:24px; background:#fff; border:1px solid var(--kb-border); border-radius:24px; overflow:hidden; }
.kb-tabs-nav { display:flex; gap:0; overflow:auto; border-bottom:1px solid var(--kb-border); background:#fff; }
.kb-tab-btn { border:0; background:#fff; padding:15px 18px; font-weight:750; color:var(--kb-muted); cursor:pointer; white-space:nowrap; }
.kb-tab-btn[aria-selected="true"] { color:var(--kb-primary); box-shadow: inset 0 -3px 0 var(--kb-primary); }
.kb-tab-panel { padding:26px; display:none; }
.kb-tab-panel.is-active { display:block; }

.kb-content { padding: 42px 0; }
.kb-content-layout { display:grid; grid-template-columns: minmax(0, 1fr) 330px; gap:34px; align-items:start; }
.kb-entry { background:#fff; border:1px solid var(--kb-border); border-radius:var(--kb-radius); padding:clamp(22px,4vw,38px); }
.kb-entry h1 { line-height:1.1; letter-spacing:-.04em; }
.kb-entry-content > *:first-child { margin-top:0; }
.kb-sidebar { display:grid; gap:20px; }
.kb-widget { background:#fff; border:1px solid var(--kb-border); border-radius:var(--kb-radius); padding:20px; }

.kb-cta-card { display:flex; justify-content:space-between; gap:20px; align-items:center; flex-wrap:wrap; }
.kb-section--filters { padding:24px 0; background:#fff; border-bottom:1px solid var(--kb-border); }
.kb-section--filters .kb-search-panel { margin-top:8px; }

.kb-home-prefooter { background:#fff; border-top:1px solid var(--kb-border); padding:44px 0 20px; }
.kb-home-prefooter-inner { display:grid; grid-template-columns:1fr 1fr; gap:30px; align-items:start; }
.kb-home-prefooter h2 { margin-top:0; font-size:clamp(1.45rem, 2.5vw, 2rem); letter-spacing:-.035em; }
.kb-prefooter-text { color:var(--kb-muted); }
.kb-category-cloud { display:flex; flex-wrap:wrap; gap:9px; }
.kb-category-cloud a { border:1px solid var(--kb-border); background:var(--kb-surface); border-radius:999px; padding:7px 12px; color:var(--kb-text); font-weight:650; font-size:.9rem; }
.kb-category-cloud a:hover { color:#fff; background:var(--kb-primary); text-decoration:none; border-color:var(--kb-primary); }

.kb-site-footer { background:#0b1727; color:#d0d5dd; padding:46px 0 20px; margin-top:0; }
.kb-site-footer a { color:#fff; }
.kb-footer-grid { display:grid; grid-template-columns: 1.2fr repeat(3,1fr); gap:28px; }
.kb-footer-logo { max-height:58px; width:auto; object-fit:contain; }
.kb-footer-text { margin-top:16px; color:#b8c1cc; }
.kb-social-links { display:flex; gap:9px; flex-wrap:wrap; margin-top:16px; }
.kb-social-links a { width:36px; height:36px; display:grid; place-items:center; border-radius:50%; background:rgba(255,255,255,.1); font-weight:800; }
.kb-social-links a:hover { background:var(--kb-primary); text-decoration:none; }
.kb-app-badges { display:flex; flex-wrap:wrap; gap:10px; margin-top:16px; }
.kb-store-badge { display:inline-flex; align-items:center; border-radius:10px; background:#111827; border:1px solid rgba(255,255,255,.2); padding:9px 12px; font-weight:800; }
.kb-store-badge:hover { text-decoration:none; background:#000; }
.kb-footer-bottom { border-top:1px solid rgba(255,255,255,.12); margin-top:30px; padding-top:20px; color:#98a2b3; font-size:.9rem; display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; }
.kb-made-with-love { color:#fff; font-weight:750; }

.kb-auth-modal[hidden] { display:none; }
.kb-auth-modal { position:fixed; inset:0; z-index:9999; display:grid; place-items:center; padding:20px; }
.kb-auth-backdrop { position:absolute; inset:0; background:rgba(11,23,39,.58); }
.kb-auth-dialog { position:relative; width:min(100%, 460px); background:#fff; border-radius:24px; box-shadow:0 30px 80px rgba(0,0,0,.25); padding:22px; }
.kb-auth-close { position:absolute; top:10px; right:12px; border:0; background:transparent; font-size:1.8rem; cursor:pointer; }
.kb-auth-tabs { display:flex; gap:8px; margin-bottom:18px; padding-right:32px; }
.kb-auth-tabs button { flex:1; border:1px solid var(--kb-border); background:#fff; border-radius:999px; padding:10px; font-weight:800; cursor:pointer; }
.kb-auth-tabs button.is-active { background:var(--kb-primary); color:#fff; border-color:var(--kb-primary); }
.kb-auth-panel { display:none; }
.kb-auth-panel.is-active { display:block; }
.kb-auth-panel input[type="text"], .kb-auth-panel input[type="password"] { width:100%; border:1px solid var(--kb-border); border-radius:12px; padding:11px 12px; }

.kb-pagination { margin-top:24px; }

@media (max-width: 1180px) {
  .kb-search-panel { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .kb-filter-field--wide { grid-column: span 2; }
}
@media (max-width: 980px) {
  .kb-grid-4, .kb-grid-3, .kb-grid-2, .kb-hero-layout, .kb-content-layout, .kb-footer-grid, .kb-business-content-layout, .kb-home-prefooter-inner { grid-template-columns:1fr; }
  .kb-business-panel { grid-template-columns:1fr; text-align:left; }
  .kb-business-side-ad { width:100%; }
  .kb-business-logo { width:96px; height:96px; }
  .kb-sticky-card { position:static; }
  .kb-nav { display:none; position:absolute; top:100%; left:0; right:0; background:#fff; border-bottom:1px solid var(--kb-border); padding:18px 24px; }
  .kb-nav.is-open { display:block; }
  .kb-nav ul { flex-direction:column; align-items:flex-start; }
  .kb-mobile-toggle { display:inline-flex; }
  .kb-header-inner { flex-wrap:wrap; }
  .kb-header-actions { margin-left:auto; }
}
@media (max-width: 782px) { .admin-bar .kb-site-header { top: 46px; } }
@media (max-width: 700px) {
  .kb-container { width:min(100% - 22px, var(--kb-container)); }
  .kb-search-panel, .kb-form-grid { grid-template-columns:1fr; }
  .kb-filter-field--wide { grid-column:auto; }
  .kb-hero-card { padding:18px; }
  .kb-stat-grid { grid-template-columns:1fr 1fr; }
  .kb-section-head { align-items:flex-start; flex-direction:column; }
  .kb-header-actions .kb-btn { display:none; }
  .kb-user-toggle span { display:none; }
  .kb-business-cover { min-height:190px; }
  .kb-business-profile { margin-top:-54px; }
  .kb-business-section, .kb-business-accordions, .kb-card { padding:17px; }
  .kb-action-row .kb-btn { width:100%; }
  .kb-footer-bottom { display:grid; }
}
@media (max-width: 600px) { .admin-bar .kb-site-header { top: 0; } }

/* KamerBusiness v2.3 refinements */
.kb-hero-v23{background-size:cover;background-position:center;}
.kb-home-editable-content .kb-page-content{background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:22px;padding:24px;box-shadow:0 12px 35px rgba(15,23,42,.06)}
.kb-ad-container{margin-top:18px;margin-bottom:18px;}
.kb-ad-slot{position:relative;max-width:100%;border:1px dashed rgba(14,113,178,.25);background:rgba(248,250,252,.92);border-radius:18px;min-height:92px;display:flex;align-items:center;justify-content:center;gap:10px;text-align:center;color:#64748b;padding:18px;overflow:hidden;}
.kb-ad-label{position:absolute;transform:translateY(-44px);font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:#64748b;background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:999px;padding:3px 9px;}
.kb-ad-slot ins,.kb-ad-slot iframe,.kb-ad-slot img{max-width:100%!important;}
.kb-business-single-v23 .kb-business-section{scroll-margin-top:100px;}
.kb-map-embed--city-zoom iframe{min-height:390px;}
.kb-job-card-details,.kb-event-card-details{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0;color:#475569;font-size:.92rem;}
.kb-job-card-details span,.kb-event-card-details span{background:#f8fafc;border:1px solid rgba(15,23,42,.08);border-radius:999px;padding:5px 10px;}
.kb-btn--small{padding:8px 12px;font-size:.9rem;min-height:auto;}
.kb-search-panel--advanced .kb-filter-field select,.kb-search-panel--advanced .kb-filter-field input{min-height:46px;}
.kb-business-name-with-badges{display:inline-flex;align-items:center;gap:5px;vertical-align:middle;}
.kb-card h3 .kb-business-name-with-badges{align-items:flex-start;}
.kb-badge-icon{line-height:1;font-size:1rem;filter:drop-shadow(0 1px 0 rgba(255,255,255,.5));}
.kb-btn--whatsapp{background:var(--kb-whatsapp,#25d366)!important;color:#fff!important;border-color:var(--kb-whatsapp,#25d366)!important;}
.kb-btn--whatsapp:hover{filter:brightness(.95);}
.kb-wa-icon{width:18px;height:18px;display:inline-block;margin-right:6px;vertical-align:-3px;}
.kb-btn--phone.is-revealed a{color:inherit;text-decoration:none;font-weight:700;}
@media (max-width: 760px){
  .kb-hero-layout{gap:18px;}
  .kb-hero h1{line-height:1.08;}
  .kb-business-content-layout{display:block;}
  .kb-business-sidebar{margin-top:20px;}
  .kb-ad-slot{min-height:72px;padding:14px;font-size:.9rem;}
  .kb-ad-label{position:static;transform:none;margin-right:6px;}
}
