/* OneKampung public styles. Colours come from inline :root vars (admin-set). */
:root{
  --ok-primary:#1f8a70; --ok-accent:#f4a52f;
  --ok-hero-bg:#1f8a70; --ok-hero-text:#fff;
  --ok-primary-dark:#166454; --ok-primary-light:#e7f4f0;
  --ok-ink:#1f2a37; --ok-muted:#667085; --ok-line:#e6e9ee;
  --ok-card:#fff; --ok-radius:14px; --ok-danger:#d63638;
  --ok-shadow:0 1px 3px rgba(16,24,40,.06),0 8px 24px rgba(16,24,40,.06);
}
.ok-wrap{max-width:560px;margin:0 auto;padding:8px 0 40px;color:var(--ok-ink)}
.ok-wrap *{box-sizing:border-box}
.ok-card{background:var(--ok-card);border:1px solid var(--ok-line);border-radius:16px;box-shadow:var(--ok-shadow);padding:30px}
.ok-head{text-align:center;margin-bottom:22px}
.ok-head .ok-logo{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,var(--ok-primary),var(--ok-accent));display:grid;place-items:center;color:#fff;font-size:22px;margin:0 auto 14px}
.ok-head h2{font-size:23px;margin:0 0 4px}
.ok-head p{color:var(--ok-muted);margin:0}
.ok-field{margin-bottom:16px}
.ok-field label{display:block;font-weight:600;font-size:13.5px;margin-bottom:6px}
.ok-field .ok-req{color:var(--ok-danger)}
.ok-field input,.ok-field select,.ok-field textarea{width:100%;border:1px solid var(--ok-line);border-radius:10px;padding:11px 13px;font-size:14px;font-family:inherit;background:#fff;color:var(--ok-ink)}
.ok-field input:focus,.ok-field select:focus,.ok-field textarea:focus{outline:none;border-color:var(--ok-primary);box-shadow:0 0 0 3px var(--ok-primary-light)}
.ok-field .ok-hint{font-size:12px;color:var(--ok-muted);margin-top:5px}
.ok-row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:520px){.ok-row2{grid-template-columns:1fr}}
.ok-hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}
.ok-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;font-weight:600;font-size:14px;padding:11px 18px;border-radius:10px;font-family:inherit;text-decoration:none}
.ok-btn-primary{background:var(--ok-primary);color:#fff}
.ok-btn-primary:hover{background:var(--ok-primary-dark);color:#fff}
.ok-btn-ghost{background:#fff;color:var(--ok-ink);border:1px solid var(--ok-line)}
.ok-btn-block{width:100%}
.ok-btn-sm{padding:7px 13px;font-size:13px;border-radius:8px}
.ok-foot{text-align:center;margin-top:18px;color:var(--ok-muted);font-size:13.5px}
.ok-foot a{color:var(--ok-primary)}
.ok-check{display:flex;gap:9px;font-size:13px;color:var(--ok-muted);margin:4px 0 18px;align-items:flex-start}
.ok-notice{display:flex;gap:11px;align-items:flex-start;border-radius:11px;padding:13px 16px;margin-bottom:18px;font-size:14px;line-height:1.5}
.ok-notice-error{background:#fdecec;border:1px solid #f3c2c2;color:#a3231f}
.ok-notice-success{background:#e8f7ee;border:1px solid #b6e4c6;color:#0f7a37}
.ok-notice-info{background:#eef6ff;border:1px solid #bcd9f5;color:#1c5d97}
.ok-notice ul{margin:6px 0 0;padding-left:18px}
.ok-verify-box{text-align:center}
.ok-verify-icon{width:74px;height:74px;border-radius:50%;background:var(--ok-primary-light);color:var(--ok-primary);display:grid;place-items:center;font-size:30px;margin:0 auto 18px}
.ok-mailto{background:#f4f6f8;border-radius:10px;padding:11px;font-weight:600;margin:14px 0}
.ok-divider{display:flex;align-items:center;gap:12px;color:var(--ok-muted);font-size:12px;margin:18px 0}
.ok-divider:before,.ok-divider:after{content:"";height:1px;background:var(--ok-line);flex:1}

/* Brand icons */
.ok-ico-wrap{display:inline-flex;align-items:center;color:var(--ok-muted)}
.ok-ico-wrap.ok-ico-whatsapp{color:#25d366}
.ok-ico-wrap.ok-ico-facebook{color:#1877f2}
.ok-ico-wrap.ok-ico-instagram{color:#e1306c}
.ok-ico-wrap.ok-ico-tiktok{color:#111}

/* Photo previews (add-listing) */
.ok-photo-preview{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}
.ok-photo-preview:empty{margin-top:0}
.ok-preview-item{position:relative;width:84px;height:84px;border-radius:10px;overflow:hidden;border:1px solid var(--ok-line);background:#f1f4f7}
.ok-preview-item img{width:100%;height:100%;object-fit:cover;display:block}
.ok-preview-item.ok-preview-over{outline:2px solid var(--ok-danger);outline-offset:-2px}
.ok-preview-tag{position:absolute;left:0;right:0;bottom:0;background:var(--ok-danger);color:#fff;font-size:10px;font-weight:700;text-align:center;padding:2px}
.ok-preview-warn{flex-basis:100%;font-size:12.5px;color:#9a6a00;background:#fff7e6;border:1px solid #f5d98a;border-radius:8px;padding:7px 10px}

/* Dashboard */
.ok-dash{max-width:980px;margin:0 auto;padding:8px 0 50px;color:var(--ok-ink)}
.ok-dash *{box-sizing:border-box}
.ok-dash-head{display:flex;align-items:center;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.ok-avatar{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,var(--ok-primary),var(--ok-accent));color:#fff;display:grid;place-items:center;font-weight:700;font-size:19px}
.ok-dash-head h2{font-size:22px;margin:0}
.ok-dash-head .ok-sub{color:var(--ok-muted);font-size:13.5px}
.ok-dash-head .ok-spacer{flex:1}
.ok-dash-tabs{display:flex;gap:4px;border-bottom:1px solid var(--ok-line);margin-bottom:20px}
.ok-dash-tabs a{padding:11px 18px;font-weight:600;color:var(--ok-muted);border-bottom:3px solid transparent;text-decoration:none;cursor:pointer}
.ok-dash-tabs a.on{color:var(--ok-primary);border-bottom-color:var(--ok-primary)}
.ok-dash-grid{display:grid;grid-template-columns:240px 1fr;gap:26px;align-items:start}
@media(max-width:760px){.ok-dash-grid{grid-template-columns:1fr}}
.ok-dash-side{align-self:start}
.ok-side-user{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.ok-side-user strong{display:block;font-size:15px}
.ok-side-nav{display:flex;flex-direction:column;margin-top:16px;border:1px solid var(--ok-line);border-radius:12px;overflow:hidden;background:#fff}
.ok-side-nav a{padding:12px 16px;color:var(--ok-ink);text-decoration:none;font-weight:600;font-size:14px;border-bottom:1px solid var(--ok-line)}
.ok-side-nav a:last-child{border-bottom:none}
.ok-side-nav a:hover{background:#fafbfc}
.ok-side-nav a.on{background:var(--ok-primary-light);color:var(--ok-primary-dark);box-shadow:inset 3px 0 0 var(--ok-primary)}
.ok-dash-main{min-width:0}
.ok-pane-title{font-size:22px;margin:0 0 16px}
.ok-plan-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.ok-plan-card{background:#fff;border:1px solid var(--ok-line);border-radius:12px;padding:16px;box-shadow:var(--ok-shadow)}
.ok-plan-card .ok-plan-name{font-size:18px;font-weight:800;color:var(--ok-primary-dark);margin:6px 0 4px}
.ok-plan-card .ok-plan-name .ok-muted{font-size:13px;font-weight:600}
.ok-plan-card .ok-plan-usage{font-size:13px;color:var(--ok-muted);margin-bottom:12px}
.ok-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--ok-line);border-radius:12px;overflow:hidden}
.ok-table th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--ok-muted);background:#fafbfc;padding:12px 14px;border-bottom:1px solid var(--ok-line)}
.ok-table td{padding:13px 14px;border-bottom:1px solid var(--ok-line);font-size:14px;vertical-align:middle}
.ok-table tr:last-child td{border-bottom:none}
.ok-thumb{width:46px;height:46px;border-radius:9px;object-fit:cover;background:#dfe5ea}
.ok-thumb-ph{display:grid;place-items:center;color:#aeb6c2;font-size:12px}
.ok-pill{font-size:11.5px;font-weight:700;padding:4px 10px;border-radius:20px;display:inline-block;white-space:nowrap}
.ok-pill-publish{background:#e3f6ea;color:#137a3c}
.ok-pill-pending{background:#fef3da;color:#9a6a00}
.ok-pill-rejected{background:#fdecec;color:#c0392b}
.ok-pill-draft{background:#eef1f4;color:#5a6573}
.ok-pill-expired{background:#f0e9fb;color:#6b4eff}
.ok-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.ok-actions form{margin:0;display:inline-flex}
.ok-actions a{color:var(--ok-primary);font-weight:600;font-size:13px;text-decoration:none}
.ok-actions a.ok-danger{color:var(--ok-danger)}
.ok-empty{background:#fff;border:1px dashed var(--ok-line);border-radius:12px;padding:34px;text-align:center;color:var(--ok-muted)}

/* ---------- Directory grid + cards ---------- */
.ok-directory{max-width:1180px;margin:0 auto;padding:8px 0 50px;color:var(--ok-ink)}
.ok-directory *{box-sizing:border-box}
.ok-grid{display:grid;gap:22px}
.ok-grid-cols-3{grid-template-columns:repeat(3,1fr)}
.ok-grid-cols-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:920px){.ok-grid-cols-3,.ok-grid-cols-2{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.ok-grid-cols-3,.ok-grid-cols-2{grid-template-columns:1fr}}
.ok-lcard{background:#fff;border:1px solid var(--ok-line);border-radius:var(--ok-radius);overflow:hidden;box-shadow:var(--ok-shadow);display:flex;flex-direction:column;transition:transform .15s,box-shadow .15s}
.ok-lcard:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(16,24,40,.12)}
.ok-lcard-ph{position:relative;aspect-ratio:16/10;background:#dfe5ea;overflow:hidden}
.ok-lcard-ph img{width:100%;height:100%;object-fit:cover}
.ok-lcard-ph .ok-ph-empty{width:100%;height:100%;display:grid;place-items:center;color:#aeb6c2}
.ok-badge{position:absolute;top:12px;left:12px;display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;padding:5px 11px;border-radius:30px;color:#fff;box-shadow:0 2px 6px rgba(0,0,0,.18)}
.ok-verified{position:absolute;top:12px;right:12px;display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;padding:4px 9px;border-radius:30px;background:#2f80c8;color:#fff}
.ok-lcard-body{padding:15px 16px 16px;display:flex;flex-direction:column;flex:1}
.ok-lcard-body h3{font-size:17px;margin:0 0 6px}
.ok-lcard-body h3 a{color:var(--ok-ink);text-decoration:none}
.ok-meta{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:9px}
.ok-chip{font-size:12px;color:var(--ok-primary-dark);background:var(--ok-primary-light);padding:3px 9px;border-radius:20px;font-weight:600;display:inline-flex;align-items:center;gap:5px;background:color-mix(in srgb,var(--ok-cat-color,#1f8a70) 14%,#fff);color:color-mix(in srgb,var(--ok-cat-color,#1f8a70) 78%,#000)}
.ok-chip-loc{color:#7a4f12;background:#fdf1dd;background:color-mix(in srgb,var(--ok-loc-color,#d98a1f) 16%,#fff);color:color-mix(in srgb,var(--ok-loc-color,#d98a1f) 72%,#000)}
.ok-exc{color:var(--ok-muted);font-size:13.5px;margin:0 0 14px;flex:1}
.ok-rating{display:flex;align-items:center;gap:5px;font-size:13px;margin-bottom:8px;color:var(--ok-ink)}
.ok-rating .ok-stars{color:#f4a52f}
.ok-contact-icons{display:flex;gap:9px;margin-bottom:14px;flex-wrap:wrap}
.ok-contact-icons a{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;background:#f1f4f7;color:#475467}
.ok-contact-icons a:hover{background:var(--ok-primary);color:#fff}
.ok-contact-icons a.ok-ic-whatsapp:hover{background:#25d366}
.ok-contact-icons a.ok-ic-facebook:hover{background:#1877f2}
.ok-contact-icons a.ok-ic-instagram:hover{background:#e1306c}
.ok-lcard-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;border-top:1px solid var(--ok-line);padding-top:13px}
.ok-ph-count{font-size:12px;color:var(--ok-muted)}

/* clickable chips */
a.ok-chip{text-decoration:none;cursor:pointer;transition:filter .12s}
a.ok-chip:hover{filter:brightness(.95)}

/* sort toolbar */
.ok-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.ok-toolbar .ok-sub{color:var(--ok-muted);font-size:14px}
.ok-sortlabel{font-size:13px;color:var(--ok-muted);display:inline-flex;align-items:center;gap:8px}
.ok-sort-select{border:1px solid var(--ok-line);border-radius:9px;padding:8px 12px;font-size:13px;font-family:inherit;background:#fff;color:var(--ok-ink)}

/* Section heading + toolbar */
.ok-dir-head{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.ok-dir-head h2{font-size:23px;margin:0}
.ok-dir-head .ok-sub{color:var(--ok-muted);font-size:14px}

/* Search form */
.ok-searchform{background:#fff;border:1px solid var(--ok-line);border-radius:14px;padding:12px;display:flex;gap:8px;flex-wrap:wrap;box-shadow:var(--ok-shadow);margin-bottom:26px}
.ok-searchform input[type=text],.ok-searchform select{border:1px solid var(--ok-line);border-radius:10px;padding:11px 13px;font-size:14px;font-family:inherit;color:var(--ok-ink);background:#fff;box-sizing:border-box}
.ok-searchform input[type=text]{flex:1 1 200px;width:auto;min-width:180px}
.ok-searchform select{flex:1 1 150px;width:auto;min-width:130px;max-width:100%}
.ok-searchform button,.ok-searchform .ok-btn{flex:0 0 auto}

/* Pagination */
.ok-pagination{display:flex;gap:6px;justify-content:center;margin-top:30px;flex-wrap:wrap}
.ok-pagination a,.ok-pagination span{padding:8px 13px;border-radius:9px;border:1px solid var(--ok-line);background:#fff;color:var(--ok-ink);text-decoration:none;font-size:14px}
.ok-pagination .current{background:var(--ok-primary);color:#fff;border-color:var(--ok-primary)}

/* Categories / locations grids */
.ok-tax-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}
.ok-tax-card{display:flex;align-items:center;justify-content:space-between;gap:10px;background:#fff;border:1px solid var(--ok-line);border-radius:12px;padding:16px 18px;box-shadow:var(--ok-shadow);text-decoration:none;color:var(--ok-ink)}
.ok-tax-card:hover{border-color:var(--ok-primary)}
.ok-tax-card .ok-count{font-size:12px;font-weight:700;color:var(--ok-primary-dark);background:var(--ok-primary-light);padding:3px 10px;border-radius:20px}
.ok-tax-left{display:inline-flex;align-items:center;gap:10px;font-weight:600}
.ok-tax-ic{width:24px;height:24px;object-fit:contain;border-radius:6px;flex:none}

/* ---------- Single listing ---------- */
.ok-single{max-width:1180px;margin:0 auto;padding:8px 0 60px;color:var(--ok-ink)}
.ok-single *{box-sizing:border-box}
.ok-crumb{font-size:13px;color:var(--ok-muted);margin-bottom:14px}
.ok-crumb a{color:var(--ok-muted)}
.ok-gallery{position:relative;display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:1fr 1fr;gap:8px;height:380px;border-radius:14px;overflow:hidden;margin-bottom:8px}
.ok-gallery .ok-g{overflow:hidden;background:#dfe5ea}
.ok-gallery .ok-g img{width:100%;height:100%;object-fit:cover}
.ok-gallery .ok-g0{grid-row:1/3}
/* Layouts for 1–4 photos so partial galleries don't leave broken empty cells. */
.ok-gallery.ok-g-1{grid-template-columns:1fr;grid-template-rows:1fr;height:360px}
.ok-gallery.ok-g-2{grid-template-columns:1fr 1fr;grid-template-rows:1fr;height:340px}
.ok-gallery.ok-g-3{grid-template-columns:2fr 1fr;grid-template-rows:1fr 1fr;height:380px}
.ok-gallery.ok-g-4{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;height:380px}
.ok-gallery.ok-g-1 .ok-g0,.ok-gallery.ok-g-2 .ok-g0,.ok-gallery.ok-g-4 .ok-g0{grid-row:auto}
.ok-gallery .ok-g-more{position:relative}
.ok-gallery .ok-g-more .ok-ov{position:absolute;inset:0;background:rgba(15,22,33,.55);color:#fff;display:grid;place-items:center;font-weight:700}
@media(max-width:760px){.ok-gallery{grid-template-columns:1fr 1fr;grid-auto-rows:120px;height:auto}.ok-gallery .ok-g0{grid-column:1/3;height:220px}}
.ok-single-layout{display:grid;grid-template-columns:1fr 340px;gap:30px;margin-top:22px}
@media(max-width:880px){.ok-single-layout{grid-template-columns:1fr}}
.ok-single-main h1{font-size:30px;margin:0;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.ok-single-meta{display:flex;gap:9px;margin:12px 0 22px;flex-wrap:wrap}
.ok-prose{color:#344054;font-size:15.5px;line-height:1.7}
.ok-prose h3{font-size:18px;margin:26px 0 8px;color:var(--ok-ink)}
.ok-social-row{display:flex;gap:11px;margin-top:8px}
.ok-social-row a{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;color:#fff}
.ok-social-row a.ok-s-fb{background:#1877f2}.ok-social-row a.ok-s-ig{background:#e1306c}.ok-social-row a.ok-s-tt{background:#111}
.ok-sidecard{background:#fff;border:1px solid var(--ok-line);border-radius:14px;padding:20px;box-shadow:var(--ok-shadow)}

/* directory filter bar */
.ok-dir-filter{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:0 0 18px;background:#fff;border:1px solid var(--ok-line);border-radius:12px;padding:12px}
.ok-dir-filter .ok-dir-kw{flex:1 1 220px;width:auto;min-width:160px;max-width:100%;padding:9px 12px;border:1px solid var(--ok-line);border-radius:9px;font-size:14px;box-sizing:border-box}
.ok-dir-filter select{flex:1 1 150px;width:auto;min-width:120px;max-width:100%;padding:9px 10px;border:1px solid var(--ok-line);border-radius:9px;font-size:14px;background:#fff;box-sizing:border-box}
.ok-dir-filter .ok-btn{flex:0 0 auto}
@media(max-width:680px){.ok-dir-filter .ok-dir-kw{flex-basis:100%}.ok-dir-filter select{flex:1 1 45%}}

/* category image cards */
.ok-cat-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px;margin-top:8px}
.ok-cat-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;padding:26px 20px;background:#fff;border:1px solid var(--ok-line);border-radius:14px;text-decoration:none;color:inherit;box-shadow:var(--ok-shadow);transition:box-shadow .15s,transform .15s}
.ok-cat-card:hover{box-shadow:0 10px 26px rgba(0,0,0,.10);transform:translateY(-2px)}
.ok-cat-img{width:88px;height:88px;border-radius:14px;background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;background-color:var(--ok-primary-light);color:var(--ok-primary)}
.ok-cat-name{font-size:18px;font-weight:800;color:var(--ok-primary-dark)}
.ok-cat-count{font-size:12px;color:var(--ok-muted);text-transform:uppercase;letter-spacing:.04em}
.ok-cat-desc{font-size:14px;color:var(--ok-muted);line-height:1.5}

/* chip icons */
.ok-chip-ic{display:inline-flex;align-items:center;margin-right:4px;vertical-align:-1px}
.ok-chip-ic svg{width:13px;height:13px}

/* save button + monthly views */
.ok-save-btn{margin-top:10px;cursor:pointer}
.ok-save-btn.on{color:#e0245e;border-color:#e0245e}
.ok-save-ico{font-size:15px;line-height:1}
.ok-views-month{margin-top:10px;font-size:12px;color:var(--ok-muted);display:flex;align-items:center;gap:5px}
.ok-views-month svg{opacity:.65}

/* password peek */
.ok-pw-wrap{position:relative;display:block}
.ok-pw-wrap input{width:100%;padding-right:40px}
.ok-pw-eye{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:none;border:0;cursor:pointer;font-size:15px;line-height:1;opacity:.55;padding:4px;filter:grayscale(1)}
.ok-pw-eye.on,.ok-pw-eye:hover{opacity:1;filter:none}

/* avatars + public profile */
.ok-avatar-img{border-radius:50%;object-fit:cover;display:inline-block;vertical-align:middle;background:#eef1f4}
.ok-av-link{display:inline-flex;text-decoration:none}
.ok-avatar-edit{display:flex;align-items:center;gap:14px}
.ok-reply-head{display:flex;align-items:center;gap:8px}
.ok-reply-head .ok-avatar,.ok-reply-head .ok-avatar-img{flex:0 0 auto}
.ok-profile-page{max-width:1080px}
.ok-profile-head{display:flex;align-items:center;gap:18px}
.ok-profile-head .ok-avatar,.ok-profile-head .ok-avatar-img{flex:0 0 auto}
.ok-profile-name{font-size:26px;font-weight:800;margin:0 0 4px}
.ok-sidecard h4{font-size:13px;text-transform:uppercase;letter-spacing:.6px;color:var(--ok-muted);margin:0 0 14px}
.ok-kv{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--ok-line)}
.ok-kv:last-of-type{border-bottom:none}
.ok-kv .ok-kv-ic{width:38px;height:38px;border-radius:10px;background:var(--ok-primary-light);color:var(--ok-primary-dark);display:grid;place-items:center;flex:none}
.ok-kv small{display:block;color:var(--ok-muted);font-size:11.5px}
.ok-kv a,.ok-kv b{font-size:14px;font-weight:600;color:var(--ok-ink);text-decoration:none;word-break:break-word}

/* ---------- Reviews & ratings ---------- */
.ok-muted{color:var(--ok-muted)}
.ok-stars{position:relative;display:inline-block;line-height:1;white-space:nowrap;letter-spacing:2px;font-size:15px;color:#f4a52f}
.ok-stars-bg{color:#d9dee5}
.ok-stars-fill{position:absolute;left:0;top:0;overflow:hidden;color:#f4a52f}
.ok-star-empty{color:#d9dee5}
.ok-rating{display:inline-flex;align-items:center;gap:5px;font-size:13px;color:var(--ok-ink);margin-bottom:8px}
.ok-rating .ok-stars{font-size:14px}
.ok-reviews{margin-top:42px}
.ok-reviews-title{font-size:21px;display:flex;align-items:center;gap:10px;margin:0 0 4px}
.ok-reviews-summary{display:flex;align-items:center;gap:18px;background:#fff;border:1px solid var(--ok-line);border-radius:12px;padding:16px 20px;margin:12px 0 14px;box-shadow:var(--ok-shadow)}
.ok-reviews-avg{text-align:center}
.ok-avg-num{font-size:32px;font-weight:800;line-height:1}
.ok-avg-stars{font-size:15px;margin-top:2px}
.ok-reviews-cta{margin-left:auto}
.ok-review-form{background:#fff;border:1px solid var(--ok-line);border-radius:12px;padding:18px;margin-bottom:18px}
.ok-star-input{display:inline-flex;flex-direction:row-reverse;justify-content:flex-end}
.ok-star-input input{position:absolute;opacity:0;width:0;height:0}
.ok-star-input label{font-size:30px;color:#d9dee5;cursor:pointer;padding:0 2px;line-height:1}
.ok-star-input label:hover,.ok-star-input label:hover ~ label,.ok-star-input input:checked ~ label{color:#f4a52f}
.ok-review{background:#fff;border:1px solid var(--ok-line);border-radius:12px;padding:16px;margin-bottom:14px}
.ok-review-head{display:flex;align-items:center;gap:12px;margin-bottom:9px}
.ok-review-stars{font-size:13px}
.ok-review-date{margin-left:auto;font-size:12px;white-space:nowrap}
.ok-review-body{margin:0;color:#344054;font-size:14px;line-height:1.6}
.ok-review-reply{margin:12px 0 0 14px;border-left:3px solid var(--ok-primary-light);padding:9px 14px;background:#f7fbfa;border-radius:0 10px 10px 0}
.ok-reply-head{font-size:13px;color:var(--ok-primary-dark);display:flex;align-items:center;gap:6px}
.ok-review-reply p{margin:4px 0 0;font-size:13.5px;color:#475467}
.ok-reply-form{margin-top:10px}
.ok-reply-form textarea{width:100%;border:1px solid var(--ok-line);border-radius:8px;padding:9px;font-family:inherit;font-size:13.5px;margin-bottom:8px}

/* ---------- Products ---------- */
.ok-pcard .ok-price{font-weight:800;color:var(--ok-primary-dark);font-size:16px;margin-bottom:6px}
.ok-pcard-biz{font-size:13px;color:var(--ok-muted);margin-bottom:12px}
.ok-pcard-biz a{color:var(--ok-primary)}
.ok-price-lg{font-size:26px;font-weight:800;color:var(--ok-primary-dark);margin:6px 0 14px}
.ok-carousel{display:flex;gap:18px;overflow-x:auto;padding-bottom:10px;scroll-snap-type:x mandatory}
.ok-carousel-item{flex:0 0 270px;scroll-snap-align:start}
@media(max-width:600px){.ok-carousel-item{flex:0 0 78%}}

/* ---------- Share ---------- */
.ok-share{display:flex;align-items:center;gap:9px;margin:22px 0}
.ok-share-label{font-size:13px;color:var(--ok-muted);font-weight:600}
.ok-share-btn{width:36px;height:36px;border-radius:9px;border:1px solid var(--ok-line);background:#fff;display:grid;place-items:center;color:#475467;cursor:pointer;text-decoration:none;transition:background .12s,color .12s}
.ok-share-btn:hover{color:#fff}
.ok-share-btn.sh-wa:hover{background:#25d366;border-color:#25d366}
.ok-share-btn.sh-fb:hover{background:#1877f2;border-color:#1877f2}
.ok-share-btn.sh-tg:hover{background:#229ed9;border-color:#229ed9}
.ok-share-btn.sh-copy:hover{background:var(--ok-primary);border-color:var(--ok-primary)}
.ok-share-btn.copied{background:var(--ok-primary);border-color:var(--ok-primary);color:#fff}

/* clickable dashboard rows */
.ok-table tr[data-ok-href]{cursor:pointer}
.ok-table tr[data-ok-href]:hover td{background:#fafbfc}

/* mini action buttons */
.ok-btn-mini{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;font-weight:600;padding:5px 11px;border-radius:7px;border:1px solid var(--ok-line);background:#fff;cursor:pointer;font-family:inherit;color:var(--ok-ink);text-decoration:none;vertical-align:middle}
.ok-btn-mini:hover{border-color:#8c97a8}
.ok-btn-mini.danger{color:var(--ok-danger);border-color:#f0c9c9}
.ok-btn-mini.danger:hover{background:var(--ok-danger);color:#fff;border-color:var(--ok-danger)}

/* featured toggle button */
.ok-feat-btn{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;font-weight:700;padding:5px 12px;border-radius:20px;border:1px dashed #cdd3db;background:#fff;color:var(--ok-muted);cursor:pointer;font-family:inherit}
.ok-feat-btn:hover{border-style:solid;border-color:#6b4eff;color:#6b4eff}
.ok-feat-btn.on{background:#f0e9fb;border:1px solid #dcd0f5;color:#6b4eff}

/* copy tooltip */
.ok-copy-tip{position:absolute;transform:translate(-50%,-100%);background:#1f2a37;color:#fff;font-size:12px;font-weight:600;padding:5px 9px;border-radius:6px;white-space:nowrap;opacity:0;transition:opacity .15s;pointer-events:none;z-index:99999}
.ok-copy-tip.show{opacity:1}

/* home hero */
.ok-home-hero{background:var(--ok-hero-bg,#1f8a70);color:var(--ok-hero-text,#fff);padding:54px 16px 48px;margin-bottom:30px;border-radius:0 0 18px 18px}
.ok-home-hero-inner{max-width:760px;margin:0 auto;text-align:center}
.ok-home-hero h1{font-size:34px;font-weight:800;margin:0 0 8px;color:var(--ok-hero-text,#fff)}
.ok-home-hero p{font-size:17px;opacity:.92;margin:0 0 22px;color:var(--ok-hero-text,#fff)}
.ok-home-hero .ok-searchform{box-shadow:0 12px 32px rgba(0,0,0,.16)}

/* plans / upgrade page */
.ok-plans-page{max-width:1040px}
.ok-plans-title{font-size:28px;font-weight:800;text-align:center;margin:6px 0 22px}
.ok-plan-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;align-items:stretch}
.ok-plan-col{position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid var(--ok-line);border-radius:14px;padding:24px 20px;box-shadow:var(--ok-shadow)}
.ok-plan-col-hi{border-color:var(--ok-primary);box-shadow:0 12px 30px rgba(0,0,0,.10)}
.ok-plan-col-current{outline:2px solid var(--ok-primary);outline-offset:-2px}
.ok-plan-tag{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:#1f2a37;color:#fff;font-size:11px;font-weight:700;letter-spacing:.02em;padding:4px 12px;border-radius:20px;white-space:nowrap}
.ok-plan-tag-hi{background:var(--ok-primary)}
.ok-plan-h{font-size:20px;font-weight:800;margin:6px 0 2px}
.ok-plan-price{font-size:30px;font-weight:800;color:var(--ok-primary-dark);margin:2px 0 10px}
.ok-plan-price span{font-size:14px;font-weight:600;color:var(--ok-muted)}
.ok-plan-desc{font-size:13px;color:var(--ok-muted);margin:0 0 14px}
.ok-plan-feats{list-style:none;margin:0 0 18px;padding:0;flex:1}
.ok-plan-feats li{position:relative;padding:6px 0 6px 24px;font-size:14px;border-bottom:1px solid #f1f3f5}
.ok-plan-feats li:before{content:"✓";position:absolute;left:0;top:6px;color:var(--ok-primary);font-weight:800}
.ok-plan-col .ok-btn-block{margin-top:auto}

/* stories */
.ok-stories{max-width:1080px}
.ok-stories-hero{background:linear-gradient(135deg,#4b3aa3,#6b4eff 60%,#8a6dff);color:#fff;padding:48px 16px;margin-bottom:26px;border-radius:0 0 18px 18px;text-align:center}
.ok-stories-hero-inner{max-width:720px;margin:0 auto}
.ok-stories-hero h1{font-size:32px;font-weight:800;margin:0 0 8px}
.ok-stories-hero p{font-size:16px;opacity:.92;margin:0}
.ok-story-badge{position:absolute;top:12px;left:12px;background:#6b4eff;color:#fff;font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px}

/* single story */
.ok-story-hero{margin:0 0 22px;border-radius:14px;overflow:hidden;max-height:360px}
.ok-story-hero img{width:100%;height:100%;display:block;object-fit:cover}
.ok-story-body{font-size:16px;line-height:1.7}

/* featured-business tile (story single, right column) */
.ok-fb-tile{display:block;text-decoration:none;color:inherit;transition:box-shadow .15s,transform .15s}
.ok-fb-tile:hover{box-shadow:0 10px 26px rgba(0,0,0,.12);transform:translateY(-1px)}
.ok-fb-head{display:flex;gap:12px;align-items:center;margin-bottom:14px}
.ok-fb-thumb{flex:0 0 54px;width:54px;height:54px;border-radius:10px;background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;background-color:var(--ok-primary-light);color:var(--ok-primary)}
.ok-fb-head strong{display:block;font-size:15px;line-height:1.25}
.ok-fb-head small{display:block;color:var(--ok-muted);font-size:12px;margin-top:2px}

/* featured-story tile (listing single, right column, above contact) */
.ok-fs-tile{display:block;position:static;text-decoration:none;color:inherit;margin-bottom:18px;transition:box-shadow .15s,transform .15s}
.ok-fs-tile:hover{box-shadow:0 10px 26px rgba(0,0,0,.12);transform:translateY(-1px)}
.ok-fs-tile h4{margin:0 0 12px}
.ok-fs-img{display:block;width:100%;height:120px;border-radius:10px;background-size:cover;background-position:center;margin-bottom:10px}
.ok-fs-title{display:block;font-size:15px;line-height:1.3;margin-bottom:5px}
.ok-fs-exc{display:block;color:var(--ok-muted);font-size:13px;line-height:1.5}
.ok-fs-read{display:inline-block;margin-top:10px;color:#6b4eff;font-weight:700;font-size:13px}

/* analytics + captcha */
.ok-stats-card .ok-stat{display:flex;align-items:baseline;gap:6px;padding:3px 0}
.ok-stats-card .ok-stat-n{font-size:22px;font-weight:800;color:var(--ok-primary-dark)}
.ok-stats-card .ok-stat-l{font-size:13px;color:var(--ok-muted)}
.ok-captcha{margin:8px 0 2px}

/* site header */
.ok-site-header{position:sticky;top:0;z-index:1000;background:#fff;border-bottom:1px solid var(--ok-line)}
.ok-sh-wrap{max-width:1180px;margin:0 auto;display:flex;align-items:center;gap:18px;padding:11px 16px}
.ok-sh-logo{display:flex;align-items:center;gap:9px;font-weight:800;font-size:18px;color:inherit;text-decoration:none}
.ok-sh-logo img{max-height:36px;width:auto;display:block}
.ok-sh-mark{width:30px;height:30px;border-radius:8px;background:var(--ok-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:800}
.ok-sh-nav{display:flex;gap:2px;flex-wrap:wrap}
.ok-sh-nav ul{list-style:none;display:flex;gap:2px;flex-wrap:wrap;margin:0;padding:0}
.ok-sh-nav li{margin:0}
.ok-sh-nav a{padding:8px 12px;border-radius:8px;color:inherit;text-decoration:none;font-weight:600;font-size:14px}
.ok-sh-nav a:hover{background:rgba(0,0,0,.06)}
.ok-sh-nav a.on,.ok-sh-nav .current-menu-item>a,.ok-sh-nav .current_page_item>a{color:var(--ok-primary-dark);background:var(--ok-primary-light)}
.ok-sh-spacer{flex:1}
.ok-sh-actions{display:flex;gap:8px;align-items:center}
@media(max-width:760px){
	.ok-sh-wrap{flex-wrap:wrap;gap:10px;justify-content:center;text-align:center}
	.ok-sh-spacer{display:none}
	.ok-sh-logo{order:1;width:100%;justify-content:center}
	.ok-sh-actions{order:2;width:100%;justify-content:center;margin-left:0}
	.ok-sh-nav{order:3;width:100%;justify-content:center}
	.ok-sh-nav ul{width:100%;justify-content:center}
}

/* Edit mode: existing photo thumbnails with remove checkbox */
.ok-edit-photos{display:flex;flex-wrap:wrap;gap:12px;margin:6px 0 4px}
.ok-edit-photo{display:flex;flex-direction:column;gap:5px;align-items:center;font-size:12px;color:var(--ok-muted)}
.ok-edit-photo img{width:84px;height:84px;object-fit:cover;border-radius:8px;border:1px solid var(--ok-border)}
.ok-edit-photo-rm{display:inline-flex;align-items:center;gap:5px;cursor:pointer}

/* Themes like Astra underline links in the content area by default. Scope to the
   plugin's root containers + !important so it overrides the theme regardless of
   load order or specificity. In-prose description links keep their underline. */
.ok-single-page a,.ok-single a,.ok-directory a,.ok-dash a,.ok-wrap a,.ok-home-hero a,.ok-site-header a,.ok-reviews a,
.ok-cat-card,.ok-tax-card,.ok-chip,.ok-badge,.ok-verified,.ok-btn,.ok-side-nav a,.ok-crumb a{text-decoration:none!important}
.ok-prose a{text-decoration:underline!important}

/* Single CPT pages render via our own template directly inside Astra's flex
   .ast-container, which stops our content from centering. Force it back to a
   normal full-width block on our singles so .ok-single (max-width+auto) centers.
   Theme-specific selectors → harmless on non-Astra themes. */
.single-ok_listing #content > .ast-container,
.single-ok_product #content > .ast-container,
.single-ok_story #content > .ast-container{display:block;max-width:100%;width:100%}

/* Contact form ([ok_contact_form]) */
.ok-contact-form{max-width:560px}
.ok-contact-form .ok-btn-primary{margin-top:4px}
