/* ============================================================
   Niche Directory — public stylesheet
   All rules scoped to .nd-* to avoid theme conflicts.
   Accent colour injected as --nd-accent via wp_add_inline_style
   ============================================================ */

:root {
    --nd-accent:        #1a6ef5;
    --nd-accent-hover:  #1558cc;
    --nd-text:          #1a1a1a;
    --nd-text-muted:    #6b7280;
    --nd-border:        #e5e7eb;
    --nd-bg:            #ffffff;
    --nd-bg-subtle:     #f9fafb;
    --nd-radius:        8px;
    --nd-radius-lg:     12px;
    --nd-shadow:        0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);
    --nd-shadow-hover:  0 4px 12px rgba(0,0,0,.10);
    --nd-font:          inherit;
    --nd-star-filled:   #f59e0b;
    --nd-star-empty:    #d1d5db;
    --nd-claimed-bg:    #ecfdf5;
    --nd-claimed-color: #065f46;
}

/* ── Utilities ─────────────────────────────────────────── */
.nd-sr-only {
    position: absolute; width: 1px; height: 1px;
    padding: 0; margin: -1px; overflow: hidden;
    clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
.nd-container {
    width: 100%; max-width: 1200px;
    margin-inline: auto; padding-inline: 1.25rem;
}

/* ── Buttons ────────────────────────────────────────────── */
.nd-btn {
    display: inline-flex; align-items: center; justify-content: center;
    gap: .375rem; padding: .6rem 1.25rem;
    font-size: .9rem; font-weight: 500; line-height: 1.2;
    border-radius: var(--nd-radius); border: 1.5px solid transparent;
    cursor: pointer; text-decoration: none; transition: background .15s, border-color .15s, color .15s;
    white-space: nowrap;
}
.nd-btn--primary {
    background: var(--nd-accent); color: #fff; border-color: var(--nd-accent);
}
.nd-btn--primary:hover { background: var(--nd-accent-hover); border-color: var(--nd-accent-hover); color: #fff; }
.nd-btn--outline {
    background: transparent; color: var(--nd-accent); border-color: var(--nd-accent);
}
.nd-btn--outline:hover { background: var(--nd-accent); color: #fff; }
.nd-btn--full  { width: 100%; }
.nd-btn--sm    { padding: .35rem .75rem; font-size: .8rem; }

/* ── Hero ────────────────────────────────────────────────── */
.nd-hero {
    background: var(--nd-bg-subtle);
    border-bottom: 1px solid var(--nd-border);
    padding: 3rem 0 2.5rem;
    text-align: center;
}
.nd-hero__title {
    font-size: clamp(1.75rem, 4vw, 2.75rem);
    font-weight: 700; margin: 0 0 .75rem; color: var(--nd-text);
}
.nd-hero__sub {
    font-size: 1.1rem; color: var(--nd-text-muted); margin: 0;
}

/* ── Breadcrumb ──────────────────────────────────────────── */
.nd-breadcrumb-bar { padding: 1.25rem 0 .5rem; }
.nd-breadcrumb { font-size: .85rem; color: var(--nd-text-muted); display: flex; flex-wrap: wrap; gap: .3rem .5rem; align-items: center; }
.nd-breadcrumb a { color: var(--nd-accent); text-decoration: none; }
.nd-breadcrumb a:hover { text-decoration: underline; }
.nd-tax-title { font-size: 1.6rem; margin: .5rem 0 .25rem; }
.nd-tax-desc  { color: var(--nd-text-muted); margin: 0; }

/* ── Archive layout ──────────────────────────────────────── */
.nd-layout {
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: 2rem;
    padding-top: 2rem;
    padding-bottom: 3rem;
    align-items: start;
}
@media (max-width: 768px) {
    .nd-layout { grid-template-columns: 1fr; }
}

/* ── Sidebar ─────────────────────────────────────────────── */
.nd-sidebar { position: sticky; top: 1.5rem; display: flex; flex-direction: column; gap: 1.25rem; }

.nd-filter-block {
    border: 1px solid var(--nd-border);
    border-radius: var(--nd-radius-lg);
    padding: 1.1rem 1.25rem;
    background: var(--nd-bg);
}
.nd-filter-block__title {
    font-size: .8rem; font-weight: 600; letter-spacing: .06em;
    text-transform: uppercase; color: var(--nd-text-muted);
    margin: 0 0 .75rem;
}
.nd-cat-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: .1rem; }
.nd-cat-list a {
    display: flex; justify-content: space-between; align-items: center;
    padding: .35rem .5rem; border-radius: 6px;
    font-size: .9rem; color: var(--nd-text); text-decoration: none;
    transition: background .12s;
}
.nd-cat-list a:hover, .nd-cat-list a.nd-active { background: var(--nd-bg-subtle); color: var(--nd-accent); }
.nd-cat-count { font-size: .78rem; color: var(--nd-text-muted); }

.nd-sidebar-cta {
    border: 1px dashed var(--nd-border);
    border-radius: var(--nd-radius-lg);
    padding: 1.1rem 1.25rem;
    text-align: center;
    font-size: .9rem; color: var(--nd-text-muted);
}
.nd-sidebar-cta p { margin: 0 0 .75rem; }

/* ── Results bar ─────────────────────────────────────────── */
.nd-results-bar {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 1rem; font-size: .9rem; color: var(--nd-text-muted);
}
.nd-sort-select {
    border: 1px solid var(--nd-border); border-radius: var(--nd-radius);
    padding: .35rem .65rem; font-size: .875rem; background: var(--nd-bg); cursor: pointer;
}

/* ── Listing grid ────────────────────────────────────────── */
.nd-listing-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 1.25rem;
}

/* ── Listing card ────────────────────────────────────────── */
.nd-card {
    background: var(--nd-bg);
    border: 1px solid var(--nd-border);
    border-radius: var(--nd-radius-lg);
    overflow: hidden;
    transition: box-shadow .18s, transform .18s;
    display: flex; flex-direction: column;
}
.nd-card:hover { box-shadow: var(--nd-shadow-hover); transform: translateY(-2px); }
.nd-card--claimed { border-color: #6ee7b7; }

.nd-card__thumb {
    position: relative; aspect-ratio: 16/9; overflow: hidden;
    background: var(--nd-bg-subtle);
}
.nd-card__thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.nd-card__thumb-placeholder {
    width: 100%; height: 100%;
    display: flex; align-items: center; justify-content: center;
    font-size: 2.5rem; font-weight: 700;
    color: var(--nd-accent); background: color-mix(in srgb, var(--nd-accent) 10%, white);
}
.nd-card__claimed-badge {
    position: absolute; top: .5rem; right: .5rem;
    background: var(--nd-claimed-bg); color: var(--nd-claimed-color);
    font-size: .7rem; font-weight: 600; padding: .2rem .5rem;
    border-radius: 999px;
}
.nd-card__link { display: block; text-decoration: none; }

.nd-card__body { padding: 1rem; display: flex; flex-direction: column; gap: .4rem; flex: 1; }
.nd-card__title { font-size: 1rem; font-weight: 600; margin: 0; }
.nd-card__title a { color: var(--nd-text); text-decoration: none; }
.nd-card__title a:hover { color: var(--nd-accent); }
.nd-card__cats { display: flex; flex-wrap: wrap; gap: .25rem; }
.nd-card__excerpt { font-size: .85rem; color: var(--nd-text-muted); margin: 0; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.nd-card__footer { margin-top: auto; display: flex; flex-direction: column; gap: .25rem; }
.nd-card__address { font-size: .8rem; color: var(--nd-text-muted); font-style: normal; }
.nd-card__phone   { font-size: .85rem; color: var(--nd-accent); text-decoration: none; }
.nd-card__claim-prompt { font-size: .78rem; color: var(--nd-text-muted); text-decoration: none; margin-top: .5rem; }
.nd-card__claim-prompt:hover { color: var(--nd-accent); }

/* ── Stars ───────────────────────────────────────────────── */
.nd-stars { color: var(--nd-star-filled); letter-spacing: .05em; }
.nd-card__rating { display: flex; align-items: center; gap: .35rem; }
.nd-rating-value { font-size: .8rem; color: var(--nd-text-muted); }

/* ── Pills ───────────────────────────────────────────────── */
.nd-cat-pill {
    display: inline-block; padding: .2rem .6rem;
    background: color-mix(in srgb, var(--nd-accent) 10%, white);
    color: var(--nd-accent); border-radius: 999px;
    font-size: .75rem; font-weight: 500; text-decoration: none;
}
.nd-cat-pill--sm { font-size: .7rem; padding: .15rem .5rem; }

/* ── Badge ───────────────────────────────────────────────── */
.nd-badge {
    display: inline-block; padding: .2rem .6rem;
    border-radius: 999px; font-size: .72rem; font-weight: 600;
}
.nd-badge--claimed { background: var(--nd-claimed-bg); color: var(--nd-claimed-color); }

/* ── Search form ─────────────────────────────────────────── */
.nd-search-form { display: flex; flex-direction: column; gap: .65rem; }
.nd-search-input-wrap { position: relative; }
.nd-search-input {
    width: 100%; padding: .6rem 2.5rem .6rem .85rem;
    border: 1px solid var(--nd-border); border-radius: var(--nd-radius);
    font-size: .9rem; background: var(--nd-bg);
}
.nd-search-input:focus { outline: 2px solid var(--nd-accent); outline-offset: 1px; border-color: transparent; }
.nd-search-btn {
    position: absolute; right: .5rem; top: 50%; transform: translateY(-50%);
    background: none; border: none; cursor: pointer; color: var(--nd-text-muted);
    padding: .25rem; display: flex; align-items: center;
}
.nd-search-btn:hover { color: var(--nd-accent); }
.nd-select {
    width: 100%; padding: .6rem .85rem;
    border: 1px solid var(--nd-border); border-radius: var(--nd-radius);
    font-size: .9rem; background: var(--nd-bg); cursor: pointer;
}
.nd-search-field { display: flex; flex-direction: column; gap: .35rem; }
.nd-search-submit-btn { width: 100%; margin-top: .25rem; }

/* ── Pagination ──────────────────────────────────────────── */
.nd-pagination { margin-top: 2rem; display: flex; justify-content: center; gap: .35rem; flex-wrap: wrap; }
.nd-pagination .page-numbers {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 2.2rem; height: 2.2rem; padding: 0 .6rem;
    border: 1px solid var(--nd-border); border-radius: var(--nd-radius);
    font-size: .875rem; color: var(--nd-text); text-decoration: none; transition: background .12s;
}
.nd-pagination .page-numbers.current,
.nd-pagination .page-numbers:hover { background: var(--nd-accent); color: #fff; border-color: var(--nd-accent); }

/* ── Single listing ──────────────────────────────────────── */
.nd-single { padding: 0 0 3rem; }
.nd-single__layout { display: grid; grid-template-columns: 1fr 320px; gap: 2.5rem; margin-top: 1.5rem; align-items: start; }
@media (max-width: 900px) { .nd-single__layout { grid-template-columns: 1fr; } }

.nd-single__hero-img { border-radius: var(--nd-radius-lg); overflow: hidden; margin-bottom: 1.5rem; }
.nd-single__hero-img img { width: 100%; height: auto; display: block; max-height: 420px; object-fit: cover; }

.nd-single__header { margin-bottom: 1.5rem; }
.nd-single__title-row { display: flex; align-items: center; gap: .75rem; flex-wrap: wrap; }
.nd-single__title { font-size: clamp(1.4rem, 3vw, 2rem); margin: 0; }
.nd-single__cats  { display: flex; flex-wrap: wrap; gap: .35rem; margin: .5rem 0; }
.nd-single__rating { display: flex; align-items: center; gap: .4rem; margin-top: .5rem; }
.nd-single__description { line-height: 1.75; color: var(--nd-text); margin-bottom: 2rem; }
.nd-single__hours { margin-bottom: 2rem; }
.nd-hours-text { font-size: .9rem; color: var(--nd-text-muted); line-height: 1.9; }

.nd-section-title { font-size: 1.1rem; font-weight: 600; margin: 0 0 1rem; }
.nd-form-section-title { font-size: .95rem; font-weight: 600; margin: 1.5rem 0 .75rem; color: var(--nd-text-muted); border-bottom: 1px solid var(--nd-border); padding-bottom: .5rem; }

/* ── Contact card ────────────────────────────────────────── */
.nd-contact-card {
    border: 1px solid var(--nd-border); border-radius: var(--nd-radius-lg);
    overflow: hidden; margin-bottom: 1.25rem; background: var(--nd-bg);
}
.nd-contact-row {
    display: flex; align-items: flex-start; gap: .75rem; padding: .85rem 1rem;
    border-bottom: 1px solid var(--nd-border);
    font-size: .9rem; text-decoration: none; color: var(--nd-text);
    transition: background .12s;
}
.nd-contact-row:last-child { border-bottom: none; }
.nd-contact-row:hover { background: var(--nd-bg-subtle); }
.nd-contact-row--phone, .nd-contact-row--website { color: var(--nd-accent); }
.nd-contact-icon { flex-shrink: 0; font-style: normal; }
.nd-social-row { flex-wrap: wrap; gap: .5rem; }
.nd-social-link {
    display: inline-block; padding: .25rem .65rem;
    border: 1px solid var(--nd-border); border-radius: var(--nd-radius);
    font-size: .78rem; font-weight: 600; text-decoration: none;
    color: var(--nd-text-muted); text-transform: uppercase; letter-spacing: .05em;
}
.nd-social-link:hover { background: var(--nd-accent); color: #fff; border-color: var(--nd-accent); }

/* ── Map ─────────────────────────────────────────────────── */
.nd-map {
    width: 100%; height: 240px;
    border-radius: var(--nd-radius-lg); overflow: hidden;
    border: 1px solid var(--nd-border); margin-bottom: 1.25rem;
    background: var(--nd-bg-subtle);
}

/* ── Claim / owner CTAs ──────────────────────────────────── */
.nd-claim-cta, .nd-owner-actions {
    border: 1px solid var(--nd-border); border-radius: var(--nd-radius-lg);
    padding: 1.1rem; text-align: center;
    font-size: .875rem; color: var(--nd-text-muted);
}
.nd-claim-cta p { margin: 0 0 .75rem; }

/* ── Reviews ─────────────────────────────────────────────── */
.nd-single__reviews { margin-top: 2.5rem; }
.nd-reviews-list { display: flex; flex-direction: column; gap: 1.25rem; margin-bottom: 2rem; }
.nd-reviews-empty { color: var(--nd-text-muted); }

.nd-review-item { border: 1px solid var(--nd-border); border-radius: var(--nd-radius-lg); padding: 1.1rem; background: var(--nd-bg); }
.nd-review-header { display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; gap: .5rem; margin-bottom: .75rem; }
.nd-review-author-wrap { display: flex; align-items: center; gap: .6rem; }
.nd-review-avatar {
    width: 2rem; height: 2rem; border-radius: 50%;
    background: color-mix(in srgb, var(--nd-accent) 15%, white);
    color: var(--nd-accent); font-weight: 700; font-size: .875rem;
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.nd-review-author { font-weight: 600; font-size: .9rem; }
.nd-review-meta-right { display: flex; flex-direction: column; align-items: flex-end; gap: .2rem; }
.nd-review-date { font-size: .78rem; color: var(--nd-text-muted); }
.nd-review-body { font-size: .9rem; line-height: 1.65; margin: 0; color: var(--nd-text); }
.nd-review-owner-reply {
    margin-top: .85rem; padding: .75rem;
    background: var(--nd-bg-subtle); border-radius: var(--nd-radius);
    font-size: .875rem;
}
.nd-review-owner-reply p { margin: .25rem 0 0; }
.nd-review-reply-wrap { margin-top: .85rem; }
.nd-reply-textarea { width: 100%; padding: .5rem .75rem; border: 1px solid var(--nd-border); border-radius: var(--nd-radius); font-size: .875rem; resize: vertical; font-family: inherit; }
.nd-reply-textarea:focus { outline: 2px solid var(--nd-accent); outline-offset: 1px; border-color: transparent; }
.nd-reply-feedback { font-size: .8rem; margin: .35rem 0 0; }

/* ── Star rating picker ──────────────────────────────────── */
.nd-star-picker { display: flex; flex-direction: row-reverse; justify-content: flex-end; gap: .1rem; }
.nd-star-picker input { position: absolute; opacity: 0; width: 0; height: 0; }
.nd-star-picker label {
    font-size: 1.6rem; cursor: pointer; color: var(--nd-star-empty);
    transition: color .1s;
}
.nd-star-picker input:checked ~ label,
.nd-star-picker label:hover,
.nd-star-picker label:hover ~ label { color: var(--nd-star-filled); }

/* ── Forms ───────────────────────────────────────────────── */
.nd-form-wrap { max-width: 680px; }
.nd-form-row { display: flex; flex-direction: column; gap: .35rem; margin-bottom: 1rem; }
.nd-form-row label { font-size: .875rem; font-weight: 500; color: var(--nd-text); }
.nd-form-row input[type="text"],
.nd-form-row input[type="email"],
.nd-form-row input[type="tel"],
.nd-form-row input[type="url"],
.nd-form-row input[type="search"],
.nd-form-row textarea,
.nd-form-row select {
    width: 100%; padding: .6rem .85rem;
    border: 1px solid var(--nd-border); border-radius: var(--nd-radius);
    font-size: .9rem; font-family: inherit; background: var(--nd-bg);
    transition: border-color .12s;
}
.nd-form-row input:focus,
.nd-form-row textarea:focus,
.nd-form-row select:focus { outline: 2px solid var(--nd-accent); outline-offset: 1px; border-color: transparent; }
.nd-form-row small { font-size: .78rem; color: var(--nd-text-muted); }
.nd-form-note  { font-size: .85rem; color: var(--nd-text-muted); margin-bottom: 1rem; }
.nd-form-feedback { font-size: .85rem; margin-top: .35rem; min-height: 1.2em; }
.nd-form-feedback.nd-success { color: #065f46; }
.nd-form-feedback.nd-error   { color: #991b1b; }
.nd-form-actions { display: flex; gap: .75rem; flex-wrap: wrap; margin-top: .5rem; }
.nd-checkbox-label { display: flex; align-items: flex-start; gap: .5rem; cursor: pointer; font-weight: 400 !important; }
.nd-checkbox-label input { margin-top: .2rem; flex-shrink: 0; }
.nd-form-row--required label::after { content: ' *'; color: #991b1b; }

/* ── Owner dashboard ─────────────────────────────────────── */
.nd-analytics-strip { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; margin-bottom: 2rem; }
@media (max-width: 600px) { .nd-analytics-strip { grid-template-columns: 1fr 1fr; } }
.nd-analytics-card {
    background: var(--nd-bg-subtle); border: 1px solid var(--nd-border);
    border-radius: var(--nd-radius-lg); padding: 1.1rem;
    display: flex; flex-direction: column; gap: .2rem;
}
.nd-analytics-num   { font-size: 1.75rem; font-weight: 700; color: var(--nd-accent); }
.nd-analytics-label { font-size: .8rem; color: var(--nd-text-muted); }

.nd-owner-layout { display: grid; grid-template-columns: 1fr 300px; gap: 2rem; align-items: start; }
@media (max-width: 900px) { .nd-owner-layout { grid-template-columns: 1fr; } }
.nd-owner-pending-reviews { margin-top: 2rem; }
.nd-owner-current-thumb { margin-bottom: 1rem; border-radius: var(--nd-radius-lg); overflow: hidden; }
.nd-owner-current-thumb img { width: 100%; height: auto; display: block; }
.nd-photo-label { display: inline-flex; align-items: center; gap: .5rem; cursor: pointer; }
.nd-photo-label input[type="file"] { font-size: .85rem; }

/* ── Claim form ──────────────────────────────────────────── */
.nd-claim-listing-preview { background: var(--nd-bg-subtle); border: 1px solid var(--nd-border); border-radius: var(--nd-radius); padding: 1rem; margin-bottom: 1.5rem; }
.nd-claim-intro { font-size: .875rem; color: var(--nd-text-muted); margin: 0 0 .25rem; }
.nd-claim-listing-name { font-size: 1.1rem; font-weight: 600; }

/* ── Notice ──────────────────────────────────────────────── */
.nd-notice {
    padding: .85rem 1rem; border-radius: var(--nd-radius);
    font-size: .9rem; margin-bottom: 1rem;
    background: var(--nd-bg-subtle); border: 1px solid var(--nd-border);
}
.nd-notice--success { background: #ecfdf5; border-color: #6ee7b7; color: #065f46; }
.nd-notice--error   { background: #fef2f2; border-color: #fca5a5; color: #991b1b; }

/* ── Loading spinner ─────────────────────────────────────── */
.nd-spinner {
    display: inline-block; width: 1.1rem; height: 1.1rem;
    border: 2px solid var(--nd-border);
    border-top-color: var(--nd-accent);
    border-radius: 50%; animation: nd-spin .7s linear infinite;
    vertical-align: middle; margin-right: .4rem;
}
@keyframes nd-spin { to { transform: rotate(360deg); } }

/* ── Loading skeleton ────────────────────────────────────── */
.nd-skeleton { background: linear-gradient(90deg, var(--nd-border) 25%, var(--nd-bg-subtle) 50%, var(--nd-border) 75%); background-size: 400%; animation: nd-shimmer 1.4s infinite; border-radius: var(--nd-radius); }
@keyframes nd-shimmer { 0% { background-position: 100% 50%; } 100% { background-position: 0% 50%; } }
