/* Cambodia Administrative Directory - Leang Teth clean v5 */
.cd-container {
    --cd-bg: #FAF8F4;
    --cd-card: #ffffff;
    --cd-text: #161616;
    --cd-muted: #69707D;
    --cd-soft: #F5F1EA;
    --cd-border: #E7E2D9;
    --cd-dark: #161616;
    --cd-dark-2: #202020;
    --cd-shadow: 0 22px 70px rgba(22, 22, 22, 0.075);

    font-family: 'Inter', 'Kantumruy Pro', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    color: var(--cd-text);
    max-width: 1040px;
    margin: 28px auto 0;
    box-sizing: border-box;
    position: relative;
}

.cd-container * { box-sizing: border-box; }
.cd-container :where(h1,h2,h3,p) { margin-top: 0; }

.cd-finder-card {
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, #ffffff 0%, #FBF9F5 100%);
    border: 1px solid var(--cd-border);
    border-radius: 28px;
    padding: clamp(24px, 4vw, 42px);
    box-shadow: var(--cd-shadow);
}

.cd-card-glow {
    position: absolute;
    width: 190px;
    height: 190px;
    right: -72px;
    top: -86px;
    border-radius: 50%;
    background: color-mix(in srgb, var(--cd-accent) 18%, transparent);
    pointer-events: none;
}

.cd-finder-head {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(340px, .85fr);
    gap: clamp(22px, 4vw, 44px);
    align-items: end;
    margin-bottom: 26px;
}

.cd-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--cd-accent) !important;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .16em;
    text-transform: uppercase;
    margin-bottom: 14px;
}
.cd-eyebrow:before { content: ""; width: 24px; height: 1px; background: currentColor; }

.cd-finder-copy h2 {
    color: var(--cd-text) !important;
    font-size: clamp(34px, 4.5vw, 60px);
    line-height: .95;
    letter-spacing: -.045em;
    font-weight: 800;
    max-width: 680px;
    margin-bottom: 16px;
}
.cd-finder-copy p {
    color: var(--cd-muted) !important;
    font-size: 16px;
    line-height: 1.75;
    max-width: 680px;
    margin-bottom: 0;
}

.cd-stats {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}
.cd-stats div {
    background: rgba(255,255,255,.82);
    border: 1px solid var(--cd-border);
    border-radius: 18px;
    padding: 18px 18px 16px;
    min-height: 104px;
    box-shadow: 0 12px 30px rgba(22,22,22,.04);
}
.cd-stats strong {
    display: block;
    color: var(--cd-text) !important;
    font-size: clamp(28px, 3vw, 42px);
    line-height: .92;
    letter-spacing: -.055em;
    margin-bottom: 9px;
    font-weight: 900;
}
.cd-stats span {
    display: block;
    color: var(--cd-muted) !important;
    font-size: 11px;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: .12em;
}

.cd-search-panel {
    position: relative;
    z-index: 1;
    background: var(--cd-dark);
    border: 1px solid rgba(255,255,255,.10);
    border-radius: 22px;
    padding: clamp(18px, 3vw, 28px);
    box-shadow: 0 22px 50px rgba(22,22,22,.14);
}
.cd-search-wrapper { margin-bottom: 18px; position: relative; }
.cd-search-label,
.cd-filter-group label {
    display: block;
    color: rgba(255,255,255,.78) !important;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .11em;
    text-transform: uppercase;
    margin-bottom: 9px;
}
.cd-search-input,
.cd-filter-group select {
    width: 100%;
    min-height: 54px;
    padding: 0 17px;
    border: 1px solid rgba(255,255,255,.16);
    border-radius: 14px;
    background-color: #ffffff !important;
    color: #161616 !important;
    font-family: 'Inter', 'Kantumruy Pro', sans-serif;
    font-size: 15px;
    font-weight: 650;
    transition: border-color .2s ease, box-shadow .2s ease, background-color .2s ease;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
}
.cd-search-input { font-size: 16px; min-height: 62px; background-color: #ffffff !important; }
.cd-filter-group select {
    padding-right: 48px !important;
    background-image: linear-gradient(45deg, transparent 50%, #777777 50%), linear-gradient(135deg, #777777 50%, transparent 50%) !important;
    background-position: calc(100% - 22px) 50%, calc(100% - 16px) 50% !important;
    background-size: 6px 6px, 6px 6px !important;
    background-repeat: no-repeat !important;
}
.cd-filter-group select::-ms-expand { display: none; }
.cd-search-input::placeholder { color: #777777; }
.cd-search-input:focus,
.cd-filter-group select:focus {
    outline: none;
    border-color: var(--cd-accent);
    box-shadow: 0 0 0 5px color-mix(in srgb, var(--cd-accent) 24%, transparent);
    background-color: #ffffff !important;
}
.cd-filter-group select option {
    background: #ffffff !important;
    color: #161616 !important;
    font-family: 'Inter', 'Kantumruy Pro', sans-serif;
    font-size: 15px;
    font-weight: 500;
}
.cd-filter-group select option:disabled {
    color: #777777 !important;
}
.cd-filters { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.cd-filter-group select:disabled { opacity: .72; cursor: not-allowed; background-color: #F1F1F1 !important; color: #777777 !important; background-image: linear-gradient(45deg, transparent 50%, #8A8A8A 50%), linear-gradient(135deg, #8A8A8A 50%, transparent 50%) !important; }

.cd-results { margin-top: 24px; animation: cdFadeIn .35s ease both; }
@keyframes cdFadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.cd-results-head { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 14px; }
.cd-title { color: var(--cd-text) !important; font-size: clamp(24px, 2.2vw, 34px); line-height: 1.1; font-weight: 850; letter-spacing: -.035em; margin-bottom: 0; }
.cd-badge { background: var(--cd-accent); color: #fff !important; padding: 10px 14px; border-radius: 999px; font-size: 13px; font-weight: 850; white-space: nowrap; }

.cd-table-responsive {
    overflow-x: auto;
    max-height: 640px;
    overflow-y: auto;
    border: 1px solid var(--cd-border);
    border-radius: 22px;
    background: var(--cd-card);
    box-shadow: 0 18px 44px rgba(22,22,22,.05);
}
.cd-table { width: 100%; border-collapse: separate; border-spacing: 0; background: transparent; min-width: 860px; }
.cd-table th,
.cd-table td { padding: 16px 18px; text-align: left; border-bottom: 1px solid var(--cd-border); color: var(--cd-text) !important; vertical-align: middle; }
.cd-table th {
    background-color: var(--cd-dark);
    color: #fff !important;
    font-size: 12px;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: .08em;
    white-space: nowrap;
    position: sticky;
    top: 0;
    z-index: 10;
}
.cd-table tbody tr { transition: background-color .18s ease; }
.cd-table tbody tr:hover { background-color: #FAF8F4; }
.cd-table tbody tr:last-child td { border-bottom: 0; }
.cd-location-muted { opacity: .78; font-size: 14px; }
.cd-village-kh { font-family: 'Kantumruy Pro', 'Inter', sans-serif; font-weight: 800; font-size: 16px; }
.cd-copy-cell { cursor: pointer; white-space: nowrap; position: relative; font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace; font-weight: 800; color: var(--cd-accent) !important; }
.cd-copy-pill { display: inline-flex; align-items: center; gap: 8px; padding: 8px 10px; border-radius: 999px; background: color-mix(in srgb, var(--cd-accent) 11%, transparent); }
.cd-copy-icon { font-size: .9em; opacity: .72; transition: transform .2s ease, opacity .2s ease; }
.cd-copy-cell:hover .cd-copy-icon { opacity: 1; transform: translateY(-1px); }
.cd-help-text { color: var(--cd-muted) !important; font-size: 13px; margin: 12px 0 0; }

@media (max-width: 900px) {
    .cd-finder-head { grid-template-columns: 1fr; align-items: start; }
    .cd-stats { grid-template-columns: repeat(4, minmax(0, 1fr)); }
    .cd-stats div { min-height: 88px; }
    .cd-filters { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
    .cd-container { margin-top: 22px; }
    .cd-finder-card { border-radius: 22px; padding: 20px; }
    .cd-search-panel { border-radius: 18px; }
    .cd-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .cd-results-head { align-items: flex-start; flex-direction: column; }
    .cd-table th, .cd-table td { padding: 14px; }
}
