/* Cohsar Geo & Currency — Frontend Styles v2.0 */

/* ── Notification bar ─────────────────────────────────────────── */
#cgc-bar {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 99999;
    background: #1565c0;
    color: #fff;
    font-size: 14px;
    font-weight: 500;
    padding: 10px 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 8px;
    box-shadow: 0 3px 12px rgba(0,0,0,.28);
}
.admin-bar #cgc-bar { top: 32px; }
@media (max-width: 782px) { .admin-bar #cgc-bar { top: 46px; } }
#cgc-bar strong { font-weight: 800; }

#cgc-bar-confirm {
    background: #fff; border: none; color: #1565c0;
    padding: 5px 16px; border-radius: 16px; cursor: pointer;
    font-size: 13px; font-weight: 700; transition: background .15s;
}
#cgc-bar-confirm:hover { background: #e3f2fd; }

#cgc-bar-change {
    background: rgba(255,255,255,.15);
    border: 1px solid rgba(255,255,255,.45); color: #fff;
    padding: 5px 14px; border-radius: 16px; cursor: pointer;
    font-size: 13px; transition: background .15s;
}
#cgc-bar-change:hover { background: rgba(255,255,255,.28); }

#cgc-bar-close {
    background: none; border: none; color: rgba(255,255,255,.75);
    font-size: 20px; cursor: pointer; padding: 0 4px;
    line-height: 1; margin-left: 4px; transition: color .15s;
}
#cgc-bar-close:hover { color: #fff; }

/* ── Overlay ────────────────────────────────────────────────────── */
#cgc-overlay {
    position: fixed; inset: 0; z-index: 999997;
    background: rgba(0,0,0,.60); backdrop-filter: blur(3px);
}

/* ── Popup ───────────────────────────────────────────────────────── */
#cgc-popup {
    position: fixed; top: 50%; left: 50%; z-index: 999998;
    transform: translate(-50%, -50%);
    background: #fff; border-radius: 14px;
    padding: 34px 28px 26px; max-width: 440px; width: 90%;
    box-shadow: 0 24px 60px rgba(0,0,0,.28); text-align: center;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
#cgc-popup h2 { font-size: 21px; font-weight: 700; color: #1a1a1a; margin: 0 0 8px; }
#cgc-popup p  { font-size: 14px; color: #666; margin: 0 0 18px; line-height: 1.5; }
.cgc-strict-note { font-size: 12px; color: #1976d2; margin: -8px 0 14px; }
.cgc-popup-footer { font-size: 12px; color: #aaa; margin: 12px 0 0 !important; }

#cgc-popup-submit {
    width: 100%; padding: 12px; background: #1976d2; color: #fff;
    border: none; border-radius: 8px; font-size: 15px; font-weight: 700;
    cursor: pointer; transition: background .2s, opacity .2s; margin-top: 12px;
}
#cgc-popup-submit:not([disabled]):hover { background: #1565c0; }
#cgc-popup-submit[disabled] { opacity: .45; cursor: not-allowed; }

/* ── Searchable Country Select ──────────────────────────────────── */
.cgc-search-wrap {
    position: relative;
    display: inline-block;  /* never forces a new row */
    width: auto;
    min-width: 140px;
    max-width: 200px;
    text-align: left;
}

.cgc-search-input {
    width: 100%;
    padding: 10px 36px 10px 14px;
    font-size: 15px;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    background: #f9f9f9;
    color: #333;
    outline: none;
    transition: border-color .2s, box-shadow .2s;
    box-sizing: border-box;
    cursor: text;
}
.cgc-search-input:focus {
    border-color: #1976d2;
    box-shadow: 0 0 0 3px rgba(25,118,210,.12);
    background: #fff;
}
.cgc-search-input::placeholder { color: #aaa; }

/* Search icon — always visible */
.cgc-search-wrap::after {
    content: '\1F50D'; /* 🔍 */
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 13px;
    pointer-events: none;
    line-height: 1;
    opacity: .5;
}

/* Clear button hidden — feature removed per user request */
.cgc-search-clear { display: none !important; }

.cgc-search-dropdown {
    position: absolute;
    top: calc(100% + 4px);
    left: 0; right: 0;
    background: #fff;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    box-shadow: 0 8px 32px rgba(0,0,0,.16);
    z-index: 1000001;
    max-height: 220px;
    overflow: hidden;
    display: none;
}
.cgc-search-dropdown.cgc-open { display: block; }

.cgc-search-list {
    list-style: none;
    margin: 0; padding: 4px 0;
    max-height: 220px;
    overflow-y: auto;
    overscroll-behavior: contain;
}
.cgc-search-list li {
    padding: 9px 16px;
    font-size: 14px;
    color: #333;
    cursor: pointer;
    transition: background .1s;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.cgc-search-list li:hover,
.cgc-search-list li.cgc-highlight { background: #e3f2fd; color: #1565c0; }
.cgc-search-list li.cgc-selected { font-weight: 600; }
.cgc-search-list li.cgc-hidden   { display: none; }

.cgc-search-no-results {
    padding: 12px 16px;
    font-size: 13px;
    color: #aaa;
    text-align: center;
    display: none;
}

/* ── Shortcode: Change / Cancel / Save ──────────────────────────── */
.cgc-sc-wrap {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-size: 13px;
}

.cgc-sc-label {
    font-weight: 600;
    color: #555;
    white-space: nowrap;
}

/* Display mode */
.cgc-sc-display {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.cgc-sc-name {
    font-weight: 600;
    color: #222;
    white-space: nowrap;
}

/* Edit mode */
.cgc-sc-editor {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    flex-wrap: nowrap;
}

/* Tighter search wrap inside shortcode */
.cgc-sc-editor .cgc-search-wrap {
    min-width: 160px;
    max-width: 220px;
}
.cgc-sc-editor .cgc-search-input {
    padding: 6px 32px 6px 10px;
    font-size: 13px;
    border-width: 1px;
    border-radius: 6px;
    width: 100%;
}

/* Buttons */
.cgc-sc-btn-change,
.cgc-sc-btn-save,
.cgc-sc-btn-cancel {
    padding: 5px 13px;
    font-size: 13px;
    font-weight: 600;
    border-radius: 5px;
    border: 1px solid transparent;
    cursor: pointer;
    white-space: nowrap;
    transition: background .15s, border-color .15s, opacity .15s;
    line-height: 1.4;
}

.cgc-sc-btn-change {
    background: #fff;
    border-color: #1976d2;
    color: #1976d2;
}
.cgc-sc-btn-change:hover {
    background: #e3f2fd;
}

.cgc-sc-btn-save {
    background: #1976d2;
    border-color: #1976d2;
    color: #fff;
}
.cgc-sc-btn-save:not([disabled]):hover {
    background: #1565c0;
    border-color: #1565c0;
}
.cgc-sc-btn-save[disabled] {
    opacity: .45;
    cursor: not-allowed;
}

.cgc-sc-btn-cancel {
    background: #fff;
    border-color: #ccc;
    color: #555;
}
.cgc-sc-btn-cancel:hover {
    background: #f5f5f5;
    border-color: #aaa;
}

.cgc-spinner { font-size: 12px; color: #888; }

/* ── Fraud alert message ─────────────────────────────────────────── */
.cgc-fraud-alert {
    background: #fff3cd; border: 1px solid #ffc107;
    color: #856404; border-radius: 8px;
    padding: 10px 16px; font-size: 14px; margin-top: 8px;
    text-align: left;
}

/* ── Hidden price placeholder ───────────────────────────────────── */
.cgc-price-hidden {
    color: #999; font-style: italic; font-size: 0.88em;
    cursor: pointer; text-decoration: underline dotted;
}
.cgc-price-hidden:hover { color: #1976d2; }

/* ── Admin page ─────────────────────────────────────────────────── */
.cgc-admin-wrap h3 { margin-top: 28px; border-bottom: 1px solid #e0e0e0; padding-bottom: 8px; }

/* ── Rates Dashboard Table ──────────────────────────────────────── */
.cgc-rates-table th { font-size: 12px; white-space: nowrap; }
.cgc-rates-table td { vertical-align: middle; }
.cgc-rates-table input[type="number"] {
    padding: 4px 8px; border: 1px solid #ccc; border-radius: 4px;
    font-size: 13px; transition: border-color .2s;
}
.cgc-rates-table input[type="number"]:focus { border-color: #1976d2; outline: none; }
#cgc-override-save-bar { z-index: 100; }

/* ── Page card shortcode [cgc_country_currency-page] ────────────── */
.cgc-page-card {
    background: var(--color-background-primary, #fff);
    border-radius: 12px;
    padding: 1.5rem;
    max-width: 460px;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.cgc-page-heading {
    font-size: 15px;
    font-weight: 600;
    color: var(--color-text-primary, #111);
    margin: 0 0 3px;
}

.cgc-page-subtext {
    font-size: 13px;
    color: var(--color-text-secondary, #666);
    margin: 0 0 1.25rem;
    line-height: 1.5;
}

/* Display mode */
.cgc-page-display {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    background: var(--color-background-secondary, #f5f5f5);
    border: 0.5px solid var(--color-border-tertiary, #e0e0e0);
    border-radius: 10px;
    padding: 14px 16px;
}

.cgc-page-current {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

.cgc-page-flag {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: #E6F1FB;
    border: 0.5px solid #B5D4F4;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 700;
    color: #185FA5;
    flex-shrink: 0;
    letter-spacing: .04em;
}

.cgc-page-country-info {
    display: flex;
    flex-direction: column;
    gap: 5px;
    min-width: 0;
}

.cgc-page-country-name {
    font-size: 15px;
    font-weight: 600;
    color: var(--color-text-primary, #111);
    line-height: 1.2;
}

.cgc-page-status {
    display: inline-block;
    font-size: 11px;
    font-weight: 500;
    padding: 2px 9px;
    border-radius: 20px;
    width: fit-content;
}

.cgc-page-status--confirmed {
    background: #EAF3DE;
    color: #3B6D11;
    border: 0.5px solid #C0DD97;
}

.cgc-page-status--detected {
    background: #E6F1FB;
    color: #185FA5;
    border: 0.5px solid #B5D4F4;
}

.cgc-page-btn-change {
    font-size: 13px;
    font-weight: 500;
    padding: 9px 20px;
    border-radius: 8px;
    border: 1px solid #1976d2;
    color: #1565c0;
    background: #fff;
    cursor: pointer;
    white-space: nowrap;
    transition: background .15s;
    flex-shrink: 0;
}
.cgc-page-btn-change:hover { background: #E6F1FB; }

/* Edit mode */
.cgc-page-editor {
    margin-top: 10px;
    background: var(--color-background-secondary, #f5f5f5);
    border: 0.5px solid var(--color-border-tertiary, #e0e0e0);
    border-radius: 10px;
    padding: 16px;
}

.cgc-page-editor-label {
    font-size: 11px;
    font-weight: 600;
    color: var(--color-text-secondary, #666);
    margin: 0 0 8px;
    text-transform: uppercase;
    letter-spacing: .05em;
}

.cgc-page-editor .cgc-search-wrap {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    display: block;
}

.cgc-page-editor .cgc-search-input {
    width: 100%;
    padding: 10px 36px 10px 12px;
    font-size: 14px;
    border: 1px solid #d0d0d0;
    border-radius: 8px;
    box-sizing: border-box;
    background: #fff;
}
.cgc-page-editor .cgc-search-input:focus {
    border-color: #1976d2;
    outline: none;
    box-shadow: 0 0 0 3px rgba(25,118,210,.1);
}

.cgc-page-editor .cgc-search-dropdown { width: 100%; }

.cgc-page-btn-row {
    display: flex;
    gap: 8px;
    margin-top: 12px;
}

.cgc-page-save-wrap {
    flex: 1;
    position: relative;
    display: flex;
}

.cgc-page-btn-save {
    flex: 1;
    width: 100%;
    padding: 10px;
    font-size: 14px;
    font-weight: 600;
    border-radius: 8px;
    border: none;
    background: #1976d2;
    color: #fff;
    cursor: pointer;
    transition: background .15s, opacity .15s;
}
.cgc-page-btn-save:not([disabled]):hover { background: #1565c0; }
.cgc-page-btn-save[disabled] {
    opacity: .4;
    cursor: not-allowed;
    pointer-events: auto;
}

.cgc-save-tooltip {
    display: none;
    position: absolute;
    bottom: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%);
    background: #222;
    color: #fff;
    font-size: 12px;
    padding: 5px 11px;
    border-radius: 6px;
    white-space: nowrap;
    pointer-events: none;
    z-index: 10;
}
.cgc-save-tooltip::after {
    content: '';
    position: absolute;
    top: 100%; left: 50%;
    transform: translateX(-50%);
    border: 5px solid transparent;
    border-top-color: #222;
}
.cgc-page-save-wrap:hover .cgc-save-tooltip { display: block; }

.cgc-page-btn-cancel {
    flex: 1;
    padding: 10px;
    font-size: 14px;
    font-weight: 500;
    border-radius: 8px;
    border: 1px solid #d0d0d0;
    background: #fff;
    color: var(--color-text-secondary, #555);
    cursor: pointer;
    transition: background .15s, border-color .15s;
    text-align: center;
}
.cgc-page-btn-cancel:hover { background: #f5f5f5; border-color: #aaa; }

.cgc-page-blocked {
    margin-top: 10px;
    background: #fff8e1;
    border: 0.5px solid #ffc107;
    color: #7a5c00;
    border-radius: 8px;
    padding: 10px 14px;
    font-size: 13px;
    line-height: 1.5;
}

/* ── Page card alignment modifiers ──────────────────────────── */
.cgc-page-card--align-left   { margin-left: 0; margin-right: auto; }
.cgc-page-card--align-center { margin-left: auto; margin-right: auto; }
.cgc-page-card--align-right  { margin-left: auto; margin-right: 0; }

/* ── Stacked layout (country + currency rows) ───────────────── */
.cgc-page-display--stacked {
    display: flex;
    flex-direction: column;
    gap: 14px;
    background: transparent;
    border: none;
    padding: 0;
}

.cgc-page-row {
    background: var(--color-background-secondary, #f5f5f5);
    border: 0.5px solid var(--color-border-tertiary, #e0e0e0);
    border-radius: 10px;
    padding: 12px 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.cgc-page-row-label {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--color-text-secondary, #666);
}

.cgc-page-row-body {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

/* Inside a stacked row, override the inner display card styling */
.cgc-page-row .cgc-page-current {
    background: transparent;
    border: none;
    padding: 0;
    flex: 1;
    min-width: 0;
}

/* Currency symbol circle — matches flag circle styling */
.cgc-page-currency-symbol {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: #E6F1FB;
    border: 0.5px solid #B5D4F4;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    font-weight: 600;
    color: #0B57D0;
    flex-shrink: 0;
    line-height: 1;
}

/* Responsive — stack button under content on narrow widths */
@media (max-width: 560px) {
    .cgc-page-row-body {
        flex-direction: column;
        align-items: stretch;
        gap: 10px;
    }
    .cgc-page-row-body .cgc-page-btn-change {
        width: 100%;
        text-align: center;
    }
}

/* ── Page card style variants ───────────────────────────────── */
/* "flat" — no outer padding/background, just the inner display card */
.cgc-page-card--flat {
    background: transparent;
    padding: 0;
    border-radius: 0;
}

/* "compact" — tighter padding and smaller flag for dense layouts */
.cgc-page-card--compact { padding: 0.75rem; }
.cgc-page-card--compact .cgc-page-display { padding: 10px 12px; }
.cgc-page-card--compact .cgc-page-flag { width: 32px; height: 32px; font-size: 10px; }
.cgc-page-card--compact .cgc-page-country-name { font-size: 14px; }
.cgc-page-card--compact .cgc-page-heading { font-size: 14px; }
.cgc-page-card--compact .cgc-page-subtext { font-size: 12px; margin-bottom: 0.75rem; }

/* ── Page card responsive ───────────────────────────────────── */
@media (max-width: 480px) {
    .cgc-page-card {
        padding: 1rem;
        max-width: 100%;
    }

    /* Stack country info and Change button vertically on small screens */
    .cgc-page-display {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
        padding: 12px;
    }

    .cgc-page-btn-change {
        width: 100%;
        text-align: center;
    }

    /* Editor padding tighter */
    .cgc-page-editor {
        padding: 12px;
    }

    /* Save and Cancel stack vertically on very small screens */
    .cgc-page-btn-row {
        flex-direction: column;
        gap: 8px;
    }

    .cgc-page-save-wrap {
        width: 100%;
    }

    .cgc-page-btn-cancel {
        width: 100%;
    }

    /* Tooltip repositioned for mobile — show above, wider */
    .cgc-save-tooltip {
        font-size: 11px;
        white-space: normal;
        width: 180px;
        text-align: center;
        left: 0;
        transform: none;
    }
    .cgc-save-tooltip::after {
        left: 24px;
        transform: none;
    }
}

/* Inline selector responsive */
@media (max-width: 480px) {
    .cgc-sc-wrap {
        flex-wrap: wrap;
        gap: 6px;
    }

    .cgc-sc-editor {
        flex-wrap: wrap;
    }

    .cgc-sc-editor .cgc-search-wrap {
        min-width: 0;
        max-width: 100%;
        width: 100%;
    }
}

/* ── Popular Countries Shortlist ──────────────────────────── */
.cgc-group-label {
    padding: 4px 10px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #999;
    background: #f8f8f8;
    cursor: default;
    pointer-events: none;
}
.cgc-group-separator {
    border-top: 1px solid #eee;
    margin: 4px 0;
    padding: 0;
    pointer-events: none;
}
.cgc-popular-item {
    font-weight: 500;
}
.cgc-popular-item::before {
    content: '⭐ ';
    font-size: 10px;
    opacity: 0.6;
}
/* Hide group labels when search is active */
.cgc-search-wrap.cgc-searching .cgc-group-label,
.cgc-search-wrap.cgc-searching .cgc-group-separator {
    display: none;
}

/* ═══════════════════════════════════════════════════════════════
   FORM — [cgc_country_change_form]
   Fills 100% of its parent container. No fixed widths or heights.
═══════════════════════════════════════════════════════════════ */
.cgc-form {
    width: 100%;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    gap: 16px;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    color: #111;
}
.cgc-form *, .cgc-form *::before, .cgc-form *::after { box-sizing: border-box; }

/* ── Info panel ─────────────────────────────────────────────── */
.cgc-form-info {
    background: #ececec;
    border-radius: 12px;
    padding: 18px 20px;
}
.cgc-form-info-heading {
    font-size: 13px;
    font-weight: 600;
    color: #666;
    letter-spacing: 0.08em;
    margin-bottom: 12px;
}
.cgc-form-info-row {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
}

.cgc-form-flag {
    width: 34px;
    height: 22px;
    border-radius: 4px;
    object-fit: cover;
    flex-shrink: 0;
    box-shadow: 0 0 0 1px rgba(0,0,0,0.06);
}
.cgc-form-flag--placeholder {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 22px;
    background: #E6F1FB;
    border: 0.5px solid #B5D4F4;
    color: #0B57D0;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.04em;
}

.cgc-form-currency-icon {
    width: 48px;
    height: 48px;
    background: #dce6f2;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    font-weight: 600;
    color: #2c6ed5;
    flex-shrink: 0;
    line-height: 1;
}

.cgc-form-text {
    min-width: 0;
    flex: 1;
    font-size: 15px;
    line-height: 1.45;
}
.cgc-form-text-primary {
    font-weight: 600;
    color: #111;
    word-break: break-word;
}
.cgc-form-text-secondary {
    font-size: 13px;
    color: #555;
    margin-top: 2px;
    word-break: break-word;
}

/* ── Search label ───────────────────────────────────────────── */
.cgc-form-search-label {
    display: block;
    font-size: 12px;
    font-weight: 600;
    color: #555;
    letter-spacing: 0.08em;
    margin-bottom: -4px; /* pull search input up closer to its label */
}

/* ── Searchable select (scoped overrides so inputs go full width) ── */
.cgc-form .cgc-search-wrap { width: 100%; }
.cgc-form .cgc-search-input {
    width: 100%;
    padding: 12px 40px 12px 14px;
    border: 1px solid #ddd;
    border-radius: 10px;
    font-size: 15px;
    background: #fff;
    transition: border-color 0.15s ease;
}
.cgc-form .cgc-search-input:focus {
    border-color: #87a9c7;
    outline: none;
    box-shadow: 0 0 0 3px rgba(135,169,199,0.18);
}
.cgc-form .cgc-search-dropdown { width: 100%; }

/* ── Actions ────────────────────────────────────────────────── */
.cgc-form-actions {
    display: flex;
    gap: 12px;
}
.cgc-form-btn {
    flex: 1;
    padding: 13px 16px;
    border-radius: 10px;
    border: none;
    font-size: 15px;
    font-weight: 500;
    cursor: pointer;
    transition: background 0.15s ease, border-color 0.15s ease, opacity 0.15s ease;
    line-height: 1.2;
}
.cgc-form-btn-save {
    background: #87a9c7;
    color: #fff;
}
.cgc-form-btn-save:not(:disabled):hover { background: #6f93b3; }
.cgc-form-btn-save:disabled {
    background: #c9d4df;
    cursor: not-allowed;
}
.cgc-form-btn-cancel {
    background: #fff;
    border: 1px solid #ddd;
    color: #444;
}
.cgc-form-btn-cancel:hover { background: #f7f7f7; border-color: #c7c7c7; }

/* ── Narrow wrappers — stack buttons ────────────────────────── */
@media (max-width: 380px) {
    .cgc-form-actions { flex-direction: column; }
}
