/* ============================================
   MODERN DESIGN OVERRIDES
   Escort Uruguay — 2026 Redesign
   ============================================ */

/* --- CSS Custom Properties --- */
:root {
    --primary: #e91e63;
    --primary-dark: #c2185b;
    --primary-light: #f8bbd0;
    --primary-glow: rgba(233, 30, 99, 0.15);
    --accent: #ff6f00;
    --accent-light: #fff3e0;
    --success: #00c853;
    --success-bg: #e8f5e9;
    --danger: #ef5350;
    --danger-bg: #ffebee;
    --warning: #ff9800;
    --warning-bg: #fff8e1;

    --bg-body: #0e0e12;
    --bg-surface: #1a1a22;
    --bg-card: #22222e;
    --bg-elevated: #2a2a38;
    --bg-input: #1e1e2a;

    --text-primary: #f0f0f5;
    --text-secondary: #9e9eb8;
    --text-muted: #6b6b80;
    --text-on-primary: #fff;

    --border-color: #2e2e3e;
    --border-light: #3a3a4e;

    --radius-sm: 6px;
    --radius-md: 10px;
    --radius-lg: 16px;
    --radius-xl: 24px;
    --radius-full: 50px;

    --shadow-sm: 0 1px 3px rgba(0,0,0,0.3);
    --shadow-md: 0 4px 16px rgba(0,0,0,0.4);
    --shadow-lg: 0 8px 32px rgba(0,0,0,0.5);
    --shadow-glow: 0 0 20px rgba(233, 30, 99, 0.2);

    --font-sans: 'Inter', 'Open Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-display: 'Inter', 'Open Sans', -apple-system, BlinkMacSystemFont, sans-serif;

    --transition: 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    --header-h: 70px;
}

/* --- Global Reset & Base --- */
* { box-sizing: border-box; }

body {
    font-family: var(--font-sans) !important;
    background: var(--bg-body) !important;
    color: var(--text-primary) !important;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    padding-top: 0 !important;
}

a {
    color: var(--primary);
    transition: color var(--transition);
}
a:hover {
    color: var(--primary-dark);
}

::selection {
    background: var(--primary);
    color: #fff;
}

/* --- Typography --- */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-display) !important;
    font-weight: 700 !important;
    letter-spacing: -0.02em;
    color: var(--text-primary) !important;
}

h3 {
    font-size: 1.5em !important;
    margin-bottom: 0.5em;
}

/* --- Header --- */
header {
    background: rgba(14, 14, 18, 0.92) !important;
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border-bottom: 1px solid var(--border-color);
    box-shadow: 0 1px 20px rgba(0,0,0,0.5) !important;
    height: var(--header-h) !important;
    top: 0 !important;
    left: 0 !important;
}

.header-top-bar {
    height: var(--header-h) !important;
}

.main-logo img {
    height: 2.2em !important;
    filter: brightness(1.1);
    transition: filter var(--transition);
}
.main-logo:hover img {
    filter: brightness(1.3);
}

/* Navigation links */
.header-menu > li > a {
    font-size: 0.88em !important;
    font-weight: 500 !important;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    padding: 8px 14px !important;
    border-radius: var(--radius-sm) !important;
    transition: all var(--transition) !important;
    color: var(--text-secondary) !important;
}
.header-menu > li > a:hover,
.header-menu > li > a.active {
    background: var(--primary-glow) !important;
    color: var(--primary) !important;
}

/* Header dropdown */
.header-top-bar .header-nav .header-menu ul {
    background: var(--bg-elevated) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: var(--radius-md) !important;
    box-shadow: var(--shadow-lg) !important;
    padding: 6px !important;
    min-width: 180px !important;
}
.header-top-bar .header-nav .header-menu ul li a,
.header-top-bar .header-nav .header-menu .current_page_item ul li a {
    background: transparent !important;
    color: var(--text-secondary) !important;
    padding: 8px 12px !important;
    border-radius: var(--radius-sm) !important;
    font-size: 0.85em !important;
}
.header-top-bar .header-nav .header-menu ul li a:hover {
    background: var(--primary-glow) !important;
    color: var(--primary) !important;
}

/* Auth buttons in header */
.subnav-menu-btn a {
    border-radius: var(--radius-full) !important;
    font-size: 0.82em !important;
    font-weight: 600 !important;
    letter-spacing: 0.03em;
    transition: all var(--transition) !important;
}
.subnav-menu-btn.register-btn a {
    background: linear-gradient(135deg, var(--primary), var(--primary-dark)) !important;
    border: none !important;
    box-shadow: 0 2px 12px rgba(233, 30, 99, 0.3) !important;
}
.subnav-menu-btn.register-btn a:hover {
    box-shadow: 0 4px 20px rgba(233, 30, 99, 0.5) !important;
    transform: translateY(-1px);
}
.subnav-menu-btn.login-btn a {
    background: var(--bg-elevated) !important;
    border: 1px solid var(--border-light) !important;
    color: var(--text-secondary) !important;
}
.subnav-menu-btn.login-btn a:hover {
    border-color: var(--primary) !important;
    color: var(--primary) !important;
}

/* Mobile menu */
#menuToggle span {
    background: var(--text-secondary) !important;
}
#menu {
    background: var(--bg-surface) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: var(--radius-md) !important;
    box-shadow: var(--shadow-lg) !important;
}
#menu li a {
    color: var(--text-secondary) !important;
    border-bottom-color: var(--border-color) !important;
}
#menu li a:hover {
    color: var(--primary) !important;
}

/* --- Main Content Area --- */
/* .all {
    padding-top: var(--header-h) !important;
}
 */
.all.all-body {
    background: var(--bg-body) !important;
}

.maincontainer {
    padding: 0 12px !important;
}

/* Content boxes */
.bodybox {
    background: var(--bg-surface) !important;
    border-radius: var(--radius-lg) !important;
    padding: 24px !important;
    box-shadow: var(--shadow-sm) !important;
    border: 1px solid var(--border-color) !important;
    margin-bottom: 16px !important;
}

.bodybox-homepage {
    padding: 20px !important;
}

.bodybox h3 {
    color: var(--text-primary) !important;
    font-size: 1.3em !important;
    padding-bottom: 12px !important;
    position: relative;
}

.bodybox h3::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 3px;
    background: var(--primary);
    border-radius: 2px;
}

.bodybox h3.l::after {
    width: 40px;
}

.bodybox h3.l::after {
    left: 0;
}

/* --- Profile Cards --- */
.girl {
    padding: 6px !important;
}

.thumb {
    background: var(--bg-card) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: var(--radius-md) !important;
    overflow: hidden;
    transition: all var(--transition) !important;
}

.thumb:hover {
    border-color: var(--primary) !important;
    box-shadow: var(--shadow-glow), var(--shadow-md) !important;
    transform: translateY(-4px);
}

.thumb.girlpremium {
    border-color: var(--accent) !important;
    background: var(--bg-card) !important;
    box-shadow: 0 0 15px rgba(255, 111, 0, 0.15) !important;
}
.thumb.girlpremium:hover {
    box-shadow: 0 0 25px rgba(255, 111, 0, 0.3), var(--shadow-md) !important;
}

.thumbwrapper {
    border-radius: var(--radius-md) !important;
    overflow: hidden !important;
    aspect-ratio: 3 / 4;
    position: relative;
}

.thumbwrapper a {
    display: block;
    width: 100%;
    height: 100%;
    border-radius: var(--radius-md) !important;
}

.thumbwrapper img.mobile-ready-img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
    object-position: center 20%;
    border-radius: var(--radius-md) !important;
    transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

/* Video play icon on catalog cards */
.girl .thumb .thumbwrapper .label-video {
    position: absolute !important;
    top: 50% !important;
    left: 50%;
    transform: translate(-50%, -50%);
    width: auto !important;
    text-align: center;
    z-index: 5;
    pointer-events: none;
}
.girl .thumb .thumbwrapper .label-video img {
    display: none !important;
}
.girl .thumb .thumbwrapper .label-video::after {
    content: "\25B6";
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    background: rgba(0,0,0,0.55);
    border: 2px solid rgba(255,255,255,0.8);
    border-radius: 50%;
    color: #fff;
    font-size: 20px;
    padding-left: 3px;
}

.thumb:hover .thumbwrapper img.mobile-ready-img {
    transform: scale(1.05);
}

/* Card overlay */
.model-info .desc {
    background: linear-gradient(transparent, rgba(0,0,0,0.85)) !important;
    border-radius: 0 0 var(--radius-md) var(--radius-md) !important;
    padding: 30px 10px 10px !important;
}

.thumb:hover .model-info .desc {
    background: linear-gradient(transparent, rgba(233, 30, 99, 0.85)) !important;
}

.girl-name {
    font-size: 1em !important;
    font-weight: 600 !important;
    letter-spacing: 0.01em;
    text-shadow: 0 1px 4px rgba(0,0,0,0.6) !important;
}

.girl-desc-location {
    font-size: 0.72em !important;
    opacity: 0.85;
}

/* Labels/badges */
.labels .label {
    border-radius: var(--radius-sm) !important;
    font-size: 0.65em !important;
    font-weight: 700 !important;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    padding: 2px 6px !important;
    backdrop-filter: blur(8px);
}

/* Premium ribbon */
.premiumlabel {
    right: -5px !important;
    top: -5px !important;
}
.premiumlabel span {
    background: linear-gradient(135deg, #FFD700, #FF8C00) !important;
    font-size: 10px !important;
    letter-spacing: 0.08em;
    box-shadow: 0 2px 8px rgba(255, 140, 0, 0.4) !important;
}

/* Online label */
.model-info .online-label,
.model-info .label-online {
    background: rgba(0, 200, 83, 0.85) !important;
    border-radius: var(--radius-sm) !important;
    font-size: 0.65em !important;
    font-weight: 700 !important;
    letter-spacing: 0.05em;
}

/* --- Profile Page --- */
.profile-page {
    background: var(--bg-surface) !important;
}

.profile-header h3,
.profile-header h1 {
    color: var(--text-primary) !important;
}

.girlinfo {
    background: transparent !important;
    border-radius: 0 !important;
    border: none !important;
    padding: 0 !important;
    color: var(--text-primary) !important;
}

.girlinfo .b {
    color: var(--text-muted) !important;
    font-size: 0.8em !important;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: 600 !important;
}

.girlinfo .valuecolumn {
    color: var(--text-primary) !important;
}

/* Profile images */
.profile-img-thumb-wrapper img,
.girlimg img {
    border-radius: var(--radius-md) !important;
    transition: transform var(--transition);
}
.profile-img-thumb-wrapper:hover img,
.girlimg:hover img {
    transform: scale(1.03);
}

/* Phone box */
.phonebox a {
    color: var(--primary) !important;
    font-weight: 700 !important;
}
.phonebox a:hover {
    color: var(--primary-dark) !important;
}

/* Rates table */
.rateswrapper {
    background: var(--bg-card) !important;
    border-radius: var(--radius-md) !important;
    border: 1px solid var(--border-color) !important;
    overflow: hidden;
}

.rateswrapper table {
    color: var(--text-primary) !important;
}

.rateswrapper table th {
    background: var(--bg-elevated) !important;
    color: var(--text-secondary) !important;
    font-size: 0.8em;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 10px !important;
}

.rateswrapper table td {
    border-color: var(--border-color) !important;
    padding: 10px !important;
}

/* Services list */
.girl-services li,
.services-list li {
    background: var(--bg-elevated) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: var(--radius-sm) !important;
    color: var(--text-secondary) !important;
    padding: 4px 10px !important;
    margin: 3px !important;
    font-size: 0.85em !important;
}

/* Reviews */
.onereviewtext {
    border-bottom-color: var(--border-color) !important;
}
.onereviewtext .reviewtext {
    color: var(--text-secondary) !important;
}

#addreviewsection {
    background: var(--bg-card) !important;
    border-radius: var(--radius-md) !important;
    padding: 24px !important;
    border: 1px solid var(--border-color) !important;
    margin-top: 16px !important;
}

#addreviewsection h4 {
    color: var(--text-primary) !important;
}

/* --- Buttons --- */
.pinkbutton {
    background: linear-gradient(135deg, var(--primary), var(--primary-dark)) !important;
    border: none !important;
    border-radius: var(--radius-full) !important;
    color: #fff !important;
    font-weight: 600 !important;
    font-size: 0.9em !important;
    letter-spacing: 0.02em;
    padding: 10px 24px !important;
    cursor: pointer;
    transition: all var(--transition) !important;
    box-shadow: 0 2px 12px rgba(233, 30, 99, 0.25) !important;
    text-decoration: none !important;
    display: inline-block;
}
.pinkbutton:hover {
    box-shadow: 0 4px 20px rgba(233, 30, 99, 0.45) !important;
    transform: translateY(-2px);
}

.redbutton {
    background: linear-gradient(135deg, #ef5350, #c62828) !important;
    border: none !important;
    border-radius: var(--radius-full) !important;
    color: #fff !important;
    font-weight: 600 !important;
    padding: 10px 24px !important;
    cursor: pointer;
    transition: all var(--transition) !important;
    box-shadow: 0 2px 12px rgba(239, 83, 80, 0.25) !important;
}
.redbutton:hover {
    box-shadow: 0 4px 20px rgba(239, 83, 80, 0.45) !important;
    transform: translateY(-2px);
}

.greenbutton {
    background: linear-gradient(135deg, #00c853, #00a844) !important;
    border-radius: var(--radius-full) !important;
    box-shadow: 0 2px 12px rgba(0, 200, 83, 0.25) !important;
}

.bluebutton {
    background: linear-gradient(135deg, #2196F3, #1565C0) !important;
    border-radius: var(--radius-full) !important;
    box-shadow: 0 2px 12px rgba(33, 150, 243, 0.25) !important;
}

.blueishbutton {
    background: var(--bg-elevated) !important;
    border: 1px solid var(--border-light) !important;
    border-radius: var(--radius-full) !important;
    color: var(--text-secondary) !important;
    transition: all var(--transition) !important;
}
.blueishbutton:hover {
    border-color: var(--primary) !important;
    color: var(--primary) !important;
    background: var(--primary-glow) !important;
}

/* --- Forms --- */
.forminput,
input.input,
textarea.textarea,
select {
    background: var(--bg-input) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: var(--radius-sm) !important;
    color: var(--text-primary) !important;
    font-family: var(--font-sans) !important;
    font-size: 0.95em !important;
    padding: 10px 14px !important;
    transition: border-color var(--transition), box-shadow var(--transition) !important;
}

.forminput:focus,
input.input:focus,
textarea.textarea:focus,
select:focus {
    border-color: var(--primary) !important;
    box-shadow: 0 0 0 3px var(--primary-glow) !important;
    outline: none !important;
}

input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="tel"],
input[type="url"] {
    height: 44px !important;
    line-height: 44px !important;
}

textarea {
    line-height: 1.5 !important;
}

.form-label label {
    color: var(--text-secondary) !important;
    font-weight: 600 !important;
    font-size: 0.85em !important;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

fieldset {
    background: var(--bg-card) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: var(--radius-md) !important;
    padding: 16px !important;
}

legend {
    background: var(--bg-elevated) !important;
    border: 1px solid var(--border-color) !important;
    color: var(--primary) !important;
    border-radius: var(--radius-sm) !important;
    padding: 4px 10px !important;
    font-weight: 600 !important;
}

/* Select2 overrides */
.select2-container--default .select2-selection--single {
    background: var(--bg-input) !important;
    border-color: var(--border-color) !important;
    border-radius: var(--radius-sm) !important;
    height: 44px !important;
    color: var(--text-primary) !important;
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
    color: var(--text-primary) !important;
    line-height: 44px !important;
}
.select2-dropdown {
    background: var(--bg-elevated) !important;
    border-color: var(--border-color) !important;
    border-radius: var(--radius-sm) !important;
    box-shadow: var(--shadow-lg) !important;
}
.select2-results__option {
    color: var(--text-secondary) !important;
}
.select2-results__option--highlighted {
    background: var(--primary) !important;
    color: #fff !important;
}

/* --- Alerts --- */
.ok {
    background: rgba(0, 200, 83, 0.12) !important;
    border: 1px solid rgba(0, 200, 83, 0.3) !important;
    color: #69f0ae !important;
    border-radius: var(--radius-md) !important;
    padding: 12px 16px !important;
}

.err {
    background: rgba(239, 83, 80, 0.12) !important;
    border: 1px solid rgba(239, 83, 80, 0.3) !important;
    color: #ef9a9a !important;
    border-radius: var(--radius-md) !important;
    padding: 12px 16px !important;
}

/* --- Pagination --- */
.pagination,
.page-numbers {
    display: flex;
    justify-content: center;
    gap: 6px;
    margin: 20px 0;
    flex-wrap: wrap;
}

.pagination a,
.pagination span,
a.page-numbers,
span.page-numbers {
    background: var(--bg-elevated) !important;
    border: 1px solid var(--border-color) !important;
    color: var(--text-secondary) !important;
    border-radius: var(--radius-sm) !important;
    padding: 8px 14px !important;
    font-weight: 500 !important;
    font-size: 0.9em !important;
    text-decoration: none !important;
    transition: all var(--transition) !important;
}

.pagination a:hover,
a.page-numbers:hover {
    border-color: var(--primary) !important;
    color: var(--primary) !important;
    background: var(--primary-glow) !important;
}

.pagination .current,
span.page-numbers.current {
    background: var(--primary) !important;
    border-color: var(--primary) !important;
    color: #fff !important;
}

/* --- Cabinet / Personal Page --- */
.cabinet-menu h4 {
    color: var(--text-primary) !important;
    font-size: 1.1em !important;
    margin-bottom: 12px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--border-color);
}

.userlist {
    list-style: none !important;
    padding: 0 !important;
}

.userlist li {
    padding: 10px 14px !important;
    border-radius: var(--radius-sm) !important;
    transition: background var(--transition) !important;
    margin-bottom: 2px !important;
}

.userlist li:hover {
    background: var(--bg-elevated) !important;
}

.userlist li a {
    color: var(--text-secondary) !important;
    text-decoration: none !important;
    font-weight: 500 !important;
}

.userlist li:hover a {
    color: var(--primary) !important;
}

.userlist li .icon {
    color: var(--primary) !important;
    margin-right: 8px;
}

/* --- Footer --- */
.footer {
    background: var(--bg-surface) !important;
    border-top: 1px solid var(--border-color) !important;
}

.footer h4 {
    color: var(--primary) !important;
}

.footer a {
    color: var(--text-muted) !important;
    transition: color var(--transition) !important;
}
.footer a:hover {
    color: var(--primary) !important;
}

.underfooter {
    background: var(--bg-body) !important;
    border-top: 1px solid var(--border-color) !important;
    color: var(--text-muted) !important;
}

/* --- 18+ Modal --- */
/* Age gate / disclaimer */
.tosdisclaimer-overlay {
    background: rgba(0, 0, 0, 0.85) !important;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}
.tosdisclaimer-wrapper {
    z-index: 999999 !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
}
.age-gate {
    background: var(--bg-surface, #1a1a2e) !important;
    border: 1px solid var(--border-color, #2d2d3d) !important;
    border-radius: 12px !important;
    color: var(--text-primary, #eee) !important;
    box-shadow: 0 20px 60px rgba(0,0,0,0.5) !important;
    max-width: 560px;
    width: 92%;
    padding: 32px 28px !important;
    text-align: center;
    margin: 20px;
}
.ag-icon {
    font-size: 48px;
    font-weight: 900;
    color: var(--primary, #e91e63);
    margin-bottom: 8px;
    letter-spacing: -2px;
}
.age-gate h4 {
    color: #fff !important;
    font-size: 20px !important;
    font-weight: 700;
    margin: 0 0 12px;
}
.ag-divider {
    width: 60px;
    height: 3px;
    background: var(--primary, #e91e63);
    margin: 0 auto 16px;
    border-radius: 2px;
}
.ag-lead {
    color: var(--text-secondary, #bbb) !important;
    font-size: 14px;
    line-height: 1.6;
    margin-bottom: 16px;
}
.ag-legal {
    text-align: left;
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--border-color, #2d2d3d);
    border-radius: 8px;
    padding: 14px 16px;
    margin-bottom: 16px;
}
.ag-legal p {
    color: var(--text-secondary, #aaa) !important;
    font-size: 13px;
    line-height: 1.6;
    margin: 0 0 8px;
}
.ag-legal ul {
    list-style: none;
    padding: 0;
    margin: 0 0 10px;
}
.ag-legal li {
    padding: 4px 0 4px 20px;
    position: relative;
    font-size: 13px;
    color: var(--text-secondary, #bbb);
    line-height: 1.5;
}
.ag-legal li::before {
    content: "\2713";
    position: absolute;
    left: 0;
    color: var(--primary, #e91e63);
    font-weight: 700;
}
.ag-legal li a {
    color: var(--primary, #e91e63);
    text-decoration: underline;
}
.ag-law {
    font-size: 11px !important;
    color: #777 !important;
    margin-top: 10px !important;
    margin-bottom: 0 !important;
    line-height: 1.5 !important;
}
.ag-confirm {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-bottom: 16px;
    cursor: pointer;
    font-size: 14px;
    font-weight: 600;
    user-select: none;
}
.ag-confirm input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: var(--primary, #e91e63);
    cursor: pointer;
    flex-shrink: 0;
}
.ag-buttons {
    display: flex;
    flex-direction: column;
    gap: 10px;
    align-items: center;
}
.ag-enter {
    width: 100%;
    max-width: 340px;
    padding: 12px 24px !important;
    font-size: 15px !important;
    font-weight: 700;
    cursor: pointer;
    transition: opacity 0.2s;
}
.ag-enter:disabled {
    opacity: 0.35;
    cursor: not-allowed;
}
.ag-exit {
    background: none;
    border: 1px solid var(--border-color, #555);
    color: var(--text-secondary, #999);
    padding: 10px 24px;
    border-radius: 5px;
    font-size: 13px;
    cursor: pointer;
    width: 100%;
    max-width: 340px;
    transition: border-color 0.2s, color 0.2s;
}
.ag-exit:hover {
    border-color: #999;
    color: #ddd;
}
.ag-footer {
    font-size: 11px;
    color: #666 !important;
    margin-top: 14px !important;
    margin-bottom: 0 !important;
}

/* --- Search page --- */
.search-filters {
    background: var(--bg-card) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: var(--radius-md) !important;
}

/* --- Locked section --- */
.lockedsection {
    background: var(--bg-elevated) !important;
    color: var(--text-secondary) !important;
    border-radius: var(--radius-md) !important;
    border: 1px solid var(--border-color) !important;
}

/* --- Scrollbar (webkit) --- */
::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}
::-webkit-scrollbar-track {
    background: var(--bg-body);
}
::-webkit-scrollbar-thumb {
    background: var(--border-light);
    border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
    background: var(--text-muted);
}

/* --- Smooth animations --- */
.girl,
.thumb,
.pinkbutton,
.redbutton,
.bodybox,
input,
textarea,
select {
    transition: all var(--transition) !important;
}

/* --- Card grid improvements --- */
.profiles-loop,
.loop-profiles-wrapper .profiles-loop {
    display: flex !important;
    flex-wrap: wrap !important;
}

/* Remove float-based separators */
.show-separator {
    display: none !important;
}

/* --- Loading state for images --- */
.thumbwrapper img {
    background: var(--bg-elevated);
}

/* --- Legal pages content --- */
.bodybox h1 {
    color: var(--text-primary) !important;
    font-size: 1.8em !important;
    margin-bottom: 0.3em;
}

/* .bodybox h3 {
    margin-top: 1.5em;
} */

.bodybox h4 {
    color: var(--text-secondary) !important;
}

.bodybox p {
    color: var(--text-secondary) !important;
    line-height: 1.8;
}

.bodybox ul, .bodybox ol {
    color: var(--text-secondary) !important;
    line-height: 1.8;
}

.bodybox table th {
    background: var(--bg-elevated) !important;
    color: var(--text-secondary) !important;
    border-color: var(--border-color) !important;
}

.bodybox table td {
    border-color: var(--border-color) !important;
    color: var(--text-secondary) !important;
}

/* --- Profile gallery --- */
.profile-img-thumb-wrapper {
    border-radius: var(--radius-md) !important;
    overflow: hidden;
    border: 2px solid transparent;
    transition: border-color var(--transition);
}
.profile-img-thumb-wrapper:hover {
    border-color: var(--primary);
}

/* --- Photo management page --- */
.photo-item {
    background: var(--bg-card) !important;
    border-color: var(--border-color) !important;
    border-radius: var(--radius-md) !important;
}

.upload-section {
    background: var(--bg-card) !important;
    border: 2px dashed var(--border-light) !important;
    border-radius: var(--radius-md) !important;
}

/* --- Premium page specific --- */
.star-rating-input label {
    transition: color var(--transition) !important;
}


/* --- Fix for text areas that still show dark on light --- */
.bodybox strong,
.bodybox b {
    color: var(--text-primary) !important;
}

.bodybox small {
    color: var(--text-muted) !important;
}

.bodybox label {
    color: var(--text-secondary) !important;
}

/* --- Sidebar overrides --- */
.sidebar-left,
.sidebar-right {
    background: var(--bg-surface) !important;
}

/* =============================================
   REVIEW SECTION — Complete redesign
   ============================================= */

/* Section wrapper */
.review-section {
    background: var(--bg-card) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: var(--radius-lg) !important;
    padding: 28px !important;
    margin-top: 16px !important;
}

/* Header with title + average */
.review-section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 24px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--border-color);
}

.review-section-header h4 {
    margin: 0 !important;
    font-size: 1.2em !important;
}

.review-avg {
    display: flex;
    align-items: center;
    gap: 8px;
}

.review-avg-stars {
    color: #ff9800;
    font-size: 1.3em;
    letter-spacing: 2px;
}

.review-avg-num {
    font-size: 1.4em;
    font-weight: 700;
    color: #ff9800;
}

.review-avg-label {
    color: var(--text-muted);
    font-size: 0.9em;
}

/* Individual review item */
.review-item {
    padding: 16px;
    margin-bottom: 24px;
    background: var(--bg-elevated);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    transition: border-color var(--transition);
}

.review-item:hover {
    border-color: var(--border-light);
}

/* .review-item:last-of-type {
    margin-bottom: 0;
} */

.review-item-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}

.review-item-author {
    display: flex;
    align-items: center;
    gap: 10px;
}

.review-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--primary), var(--primary-dark));
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 0.85em;
    flex-shrink: 0;
}

.review-name {
    display: block;
    font-size: 0.9em;
    color: var(--text-primary);
}

.review-date {
    display: block;
    font-size: 0.75em;
    color: var(--text-muted);
    margin-top: 1px;
}

.review-item-stars {
    color: #ff9800;
    font-size: 1.1em;
    letter-spacing: 1px;
}

.review-item-text {
    color: var(--text-secondary);
    font-size: 0.92em;
    line-height: 1.7;
}

/* Empty state */
.review-empty {
    text-align: center;
    padding: 30px 20px;
    color: var(--text-muted);
}

.review-empty-icon {
    font-size: 3em;
    margin-bottom: 8px;
    opacity: 0.3;
}

.review-empty p {
    margin: 0;
    font-size: 0.95em;
}

/* ---- Review form ---- */
.review-form-wrapper {
    /* margin-top: 24px; */
    padding-top: 24px;
    border-top: 1px solid var(--border-color);
}

.review-form-title {
    /* margin: 0 0 20px 0 !important; */
    font-size: 1.1em !important;
}

.review-form {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.review-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.review-fields-row {
    display: flex;
    gap: 16px;
}

.review-field-half {
    flex: 1;
    min-width: 0;
}

.review-label {
    font-size: 0.85em;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.review-label-hint {
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0;
    color: var(--text-muted);
    font-size: 0.9em;
}

.review-input {
    width: 100%;
    height: 48px;
    padding: 0 16px;
    background: var(--bg-input);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    color: var(--text-primary);
    font-family: var(--font-sans);
    font-size: 0.95em;
    transition: border-color var(--transition), box-shadow var(--transition);
    outline: none;
}

.review-input:focus {
    border-color: var(--primary);
    box-shadow: 0 0 0 3px var(--primary-glow);
}

.review-input::placeholder {
    color: var(--text-muted);
}

.review-textarea {
    width: 100%;
    padding: 14px 16px;
    background: var(--bg-input);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    color: var(--text-primary);
    font-family: var(--font-sans);
    font-size: 0.95em;
    line-height: 1.6;
    resize: vertical;
    min-height: 120px;
    transition: border-color var(--transition), box-shadow var(--transition);
    outline: none;
}

.review-textarea:focus {
    border-color: var(--primary);
    box-shadow: 0 0 0 3px var(--primary-glow);
}

.review-textarea::placeholder {
    color: var(--text-muted);
}

.review-field-hint {
    font-size: 0.75em;
    color: var(--text-muted);
}

/* Star rating input */
.review-form .star-rating-input {
    display: inline-flex;
    flex-direction: row-reverse;
    justify-content: flex-end;
    gap: 4px;
    padding: 8px 0;
}

.review-form .star-rating-input input {
    display: none;
}

.review-form .star-rating-input label {
    font-size: 2em;
    color: var(--border-light);
    cursor: pointer;
    transition: color 0.15s ease, transform 0.15s ease;
    line-height: 1;
}

.review-form .star-rating-input label:hover {
    transform: scale(1.2);
}

.review-form .star-rating-input label:hover,
.review-form .star-rating-input label:hover ~ label,
.review-form .star-rating-input input:checked ~ label {
    color: #ff9800 !important;
}

/* Submit button */
.review-submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 32px;
    background: linear-gradient(135deg, var(--primary), var(--primary-dark));
    color: #fff;
    border: none;
    border-radius: var(--radius-full);
    font-family: var(--font-sans);
    font-size: 0.95em;
    font-weight: 600;
    letter-spacing: 0.02em;
    cursor: pointer;
    transition: all var(--transition);
    box-shadow: 0 4px 16px rgba(233, 30, 99, 0.3);
    align-self: flex-start;
}

.review-submit:hover {
    box-shadow: 0 6px 24px rgba(233, 30, 99, 0.45);
    transform: translateY(-2px);
}

.review-submit:active {
    transform: translateY(0);
}

/* Responsive */
@media (max-width: 576px) {
    .review-section {
        padding: 20px !important;
    }

    .review-section-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }

    .review-fields-row {
        flex-direction: column;
        gap: 16px;
    }

    .review-form .star-rating-input label {
        font-size: 1.6em;
    }

    .review-submit {
        width: 100%;
    }
}

/* --- Tooltip style link hovers --- */
a:not(.pinkbutton):not(.redbutton):not(.greenbutton):not(.bluebutton):hover {
    text-decoration: none !important;
}

/* --- Inline style overrides for dark theme pages --- */

/* Premium/admin pages — status boxes, plan cards, info boxes */
.bodybox > div[style*="background: #f9f9f9"],
.bodybox > div[style*="background:#f9f9f9"],
.bodybox div[style*="background: #f9f9f9"],
.bodybox div[style*="background: #f5f5f5"] {
    background: var(--bg-card) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: var(--radius-md) !important;
}

.bodybox div[style*="background: #FFF8E1"],
.bodybox div[style*="background: #fff3e0"] {
    background: rgba(255, 152, 0, 0.08) !important;
    border: 1px solid rgba(255, 152, 0, 0.2) !important;
    color: #ffcc80 !important;
    border-radius: var(--radius-md) !important;
}

.bodybox div[style*="background: #fff;"],
.bodybox div[style*="background:#fff;"] {
    background: var(--bg-card) !important;
}

/* Plan cards */
.bodybox div[style*="border: 2px solid #ddd"] {
    border-color: var(--border-color) !important;
    background: var(--bg-card) !important;
}

.bodybox div[style*="border: 2px solid #e91e63"] {
    background: var(--bg-card) !important;
    box-shadow: 0 0 20px rgba(233, 30, 99, 0.15) !important;
}

/* Table headers and cells */
.bodybox tr[style*="background: #f5f5f5"] {
    background: var(--bg-elevated) !important;
}

.bodybox th[style*="border: 1px solid #ddd"],
.bodybox td[style*="border: 1px solid #ddd"] {
    border-color: var(--border-color) !important;
}

/* Fix inline color overrides */
.bodybox div[style*="color: #666"],
.bodybox div[style*="color: #555"],
.bodybox div[style*="color: #795548"],
.bodybox span[style*="color: #999"],
.bodybox div[style*="color: #999"],
.bodybox li[style*="color: #999"] {
    color: var(--text-secondary) !important;
}

.bodybox div[style*="color: #333"],
.bodybox div[style*="font-weight: bold; color: #333"] {
    color: var(--text-primary) !important;
}

/* Admin section orange border */
.bodybox div[style*="border: 2px solid #ff9800"],
.bodybox div[style*="border: 1px solid #ff9800"] {
    background: rgba(255, 152, 0, 0.06) !important;
    border-color: rgba(255, 152, 0, 0.3) !important;
}

/* Admin bar in profiles */
.bodybox > div[style*="background: #fff3e0"] {
    background: rgba(255, 152, 0, 0.08) !important;
    border-color: rgba(255, 152, 0, 0.3) !important;
}

/* Cron command display */
.bodybox div[style*="background: #333"] {
    background: var(--bg-body) !important;
    border: 1px solid var(--border-color) !important;
}

/* Reviews section inline overrides */
.onereviewtext div[style*="border-bottom: 1px solid #eee"] {
    border-bottom-color: var(--border-color) !important;
}

/* Profile page inline info sections */
div[style*="background: #f0f8ff"],
div[style*="background: #f5f5f5"] {
    background: var(--bg-card) !important;
}

/* Photo management */
.photo-item[style*="border: 1px solid #ddd"],
.photo-item[style*="border: 3px solid #e91e63"] {
    background: var(--bg-card) !important;
}
.photo-item[style*="border: 1px solid #ddd"] {
    border-color: var(--border-color) !important;
}

/* Upload section dashed border */
div[style*="border: 2px dashed #ccc"] {
    border-color: var(--border-light) !important;
    background: var(--bg-card) !important;
}

/* --- Registration & Auth Pages --- */
.registerpage {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.registerpage h3.pagetitle {
    color: var(--text-primary) !important;
    width: 100%;
}

.registerpage .usertype {
    background: var(--bg-surface) !important;
    border: 1px solid var(--border-color) !important;
    color: var(--text-primary) !important;
    width: 100% !important;
    max-width: 600px !important;
    margin: 0 auto !important;
    float: none !important;
    border-radius: var(--radius-lg) !important;
    overflow: hidden;
}

.registerpage .usertype .userlist {
    color: var(--text-secondary) !important;
}

.registerpage .usertype .userlist .icon {
    color: var(--primary) !important;
}

.registerpage .usertype .usertype-bottom {
    border-top-color: var(--border-color) !important;
}

.usertype {
    background: var(--bg-surface) !important;
    border: 1px solid var(--border-color) !important;
}

.usertype-title {
    background: linear-gradient(135deg, var(--primary), var(--primary-dark)) !important;
}

.usertype-title h4 {
    color: #fff !important;
}

.usertype-content {
    background: var(--bg-surface) !important;
    padding: 20px !important;
}

.registerform .mandatory {
    color: var(--text-muted) !important;
}

.registerform .mandatory i {
    color: var(--primary) !important;
}

/* Form layout helpers */
.form-input {
    color: var(--text-secondary) !important;
}

.form-styling .form-input .input,
.form-styling .form-input .textarea,
.form-styling .form-input select {
    background-color: var(--bg-input) !important;
    border-color: var(--border-color) !important;
    color: var(--text-primary) !important;
}

.form-styling .form-input select option:disabled {
    color: var(--text-muted) !important;
    background: var(--bg-elevated) !important;
}

.form-styling .form-label small {
    color: var(--text-muted) !important;
}

.form-styling .form-label label i {
    color: var(--primary) !important;
}

.formseparator {
    border-bottom-color: var(--border-color) !important;
}

.form-input label {
    color: var(--text-secondary) !important;
}

.col40, .col50, .col60 {
    color: var(--text-secondary) !important;
}

/* --- Search Page --- */
.sf-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}
.sf-header h3.sf-title {
    color: var(--text-primary) !important;
    margin: 0 !important;
    font-size: 1.15em;
}
.sf-toggle-btn {
    font-size: 0.8em !important;
    padding: 6px 16px !important;
}

/* Form container */
.sf-form {
    background: var(--bg-surface);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: 20px;
}

/* Sections */
.sf-section {
    margin-bottom: 18px;
}
.sf-section:last-of-type {
    margin-bottom: 0;
}
.sf-section-title {
    color: var(--primary);
    font-size: 0.8em;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 10px;
    padding-bottom: 6px;
    border-bottom: 1px solid var(--border-color);
}

/* Grid layouts */
.sf-grid {
    display: grid;
    gap: 12px;
}
.sf-grid-2 { grid-template-columns: repeat(2, 1fr); }
.sf-grid-3 { grid-template-columns: repeat(3, 1fr); }
.sf-grid-4 { grid-template-columns: repeat(4, 1fr); }

/* Field */
.sf-field {
    display: flex;
    flex-direction: column;
}
.sf-field label {
    color: var(--text-secondary);
    font-size: 0.78em;
    font-weight: 600;
    margin-bottom: 4px;
}
.sf-field input,
.sf-field select {
    width: 100%;
    padding: 8px 10px;
    background: var(--bg-input, var(--bg-elevated));
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    color: var(--text-primary);
    font-size: 0.85em;
    font-family: inherit;
    box-sizing: border-box;
    transition: border-color var(--transition);
}
.sf-field input:focus,
.sf-field select:focus {
    outline: none;
    border-color: var(--primary);
}
.sf-field input::placeholder {
    color: var(--text-muted);
}
.sf-field select:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* Checkbox / radio inline */
.sf-checks-inline {
    display: flex;
    flex-wrap: wrap;
    gap: 6px 14px;
    padding-top: 4px;
}
.sf-check {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    color: var(--text-secondary);
    font-size: 0.82em;
    cursor: pointer;
    white-space: nowrap;
}
.sf-check input[type="checkbox"],
.sf-check input[type="radio"] {
    accent-color: var(--primary);
    width: 15px;
    height: 15px;
    margin: 0;
}

/* Services grid */
.sf-checks-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 4px 14px;
}

/* Actions */
.sf-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 20px;
    padding-top: 16px;
    border-top: 1px solid var(--border-color);
}
.sf-submit-btn {
    padding: 10px 32px !important;
    font-size: 0.9em !important;
}
.sf-reset-btn {
    background: none;
    border: none;
    color: var(--text-muted);
    font-size: 0.82em;
    cursor: pointer;
    padding: 8px 12px;
    transition: color var(--transition);
}
.sf-reset-btn:hover {
    color: var(--text-secondary);
}

/* Results */
.sf-results {
    margin-top: 20px;
}
.sf-results-info {
    color: var(--text-secondary);
    font-size: 0.85em;
    margin-bottom: 14px;
    padding: 8px 12px;
    background: var(--bg-surface);
    border-radius: var(--radius-sm);
    border: 1px solid var(--border-color);
}
.sf-no-results {
    text-align: center;
    padding: 40px 20px;
    color: var(--text-muted);
}
.sf-no-results p {
    margin: 0;
}

/* Pagination */
.sf-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    margin-top: 20px;
    padding-top: 16px;
}
.sf-page-btn {
    font-size: 0.82em !important;
    padding: 8px 18px !important;
}
.sf-page-info {
    color: var(--text-muted);
    font-size: 0.82em;
}

/* Profile edit rates table */
.pe-rates-tbl {
    width: 100%;
    border-collapse: collapse;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    overflow: hidden;
}
.pe-rates-tbl thead th {
    background: var(--bg-elevated);
    font-weight: 600;
    font-size: 0.8em;
    color: var(--text-secondary);
    padding: 8px 6px;
    text-align: center;
    border-bottom: 1px solid var(--border-color);
}
.pe-rates-tbl thead th.pe-tbl-label {
    text-align: left;
    width: 90px;
}
.pe-rates-tbl td {
    border-bottom: 1px solid var(--border-color);
    padding: 3px 4px;
}
.pe-rates-tbl tr:last-child td { border-bottom: none; }
.pe-tbl-label {
    font-size: 0.8em;
    color: var(--text-secondary);
    padding-left: 10px !important;
    white-space: nowrap;
    width: 90px;
}
.pe-tbl-col {
    text-align: center;
}
.pe-tbl-col input {
    width: 100%;
    padding: 5px 8px;
    background: var(--bg-input, var(--bg-elevated));
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    color: var(--text-primary);
    font-size: 0.82em;
    text-align: center;
    box-sizing: border-box;
}
.pe-tbl-col input:focus {
    outline: none;
    border-color: var(--primary);
}

/* Responsive */
@media (max-width: 768px) {
    .sf-grid-3, .sf-grid-4 { grid-template-columns: repeat(2, 1fr); }
    .sf-checks-grid { grid-template-columns: repeat(2, 1fr); }
    .sf-form { padding: 14px; }
    .pe-tbl-label { width: 70px; font-size: 0.72em; }
}
@media (max-width: 480px) {
    .sf-grid-2, .sf-grid-3, .sf-grid-4 { grid-template-columns: 1fr; }
    .sf-checks-grid { grid-template-columns: repeat(2, 1fr); }
    .sf-header { flex-direction: column; align-items: flex-start; gap: 10px; }
    .sf-actions { flex-direction: column; }
    .sf-submit-btn { width: 100%; }
    .pe-tbl-label { width: 60px; font-size: 0.7em; padding-left: 4px !important; }
}

/* --- Profile Page Details --- */
.girlsingle {
    color: var(--text-primary) !important;
}

.girlsingle .girlinfo .girlinfo-section {
    background: var(--bg-card) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: var(--radius-md) !important;
    margin-bottom: 16px !important;
    padding: 24px !important;
}

.girlsingle .girlinfo {
    padding: 0 8px !important;
}

.girlsingle .girlinfo.l {
    padding-left: 0 !important;
    padding-right: 8px !important;
}

.girlsingle .girlinfo.r {
    padding-right: 0 !important;
    padding-left: 8px !important;
}

.girlsingle .aboutme {
    background: var(--bg-card) !important;
    color: var(--text-secondary) !important;
    border-radius: var(--radius-md) !important;
    border: 1px solid var(--border-color) !important;
    margin-bottom: 16px !important;
    padding: 24px !important;
}

.girlsingle .aboutme a {
    color: var(--primary) !important;
}

.girlsingle .aboutme a:hover {
    color: var(--primary-dark) !important;
}

.aboutme h4 {
    color: var(--text-primary) !important;
}

.aboutme b {
    color: var(--text-primary) !important;
}

.girlinfo-section {
    border-bottom-color: var(--border-color) !important;
}

.girlinfo-section h4 {
    color: var(--text-primary) !important;
}

.girlsingle .profile-title {
    color: var(--primary) !important;
}

.girlsingle .profile-header .phone-box .label {
    color: var(--text-muted) !important;
}

.girlsingle .profile-header .phone-box a {
    color: var(--primary) !important;
}

.girlsingle .escortcontact {
    background: var(--bg-card) !important;
}

.girlsingle .contact span a {
    color: var(--primary) !important;
}

/* Locked section (login required) */
.girlsingle .lockedsection {
    background: var(--bg-elevated) !important;
    color: var(--text-secondary) !important;
    border: 1px solid var(--border-color) !important;
}

.girlsingle .lockedsection a {
    color: var(--primary) !important;
}

/* Rates table theme override */
.girlsingle .rates-table th {
    background: var(--bg-elevated) !important;
    color: var(--text-secondary) !important;
}

/* Profile badges */
.orangebutton {
    background: linear-gradient(135deg, #FFD700, #FF8C00) !important;
    color: #000 !important;
    font-weight: 700 !important;
    border: none !important;
}

.pinkdegrade {
    background: linear-gradient(135deg, var(--primary), #ff6090) !important;
    color: #fff !important;
    font-weight: 700 !important;
}

.greendegrade {
    background: linear-gradient(135deg, #00c853, #00e676) !important;
    color: #000 !important;
    font-weight: 700 !important;
}

.girlsinglelabels span {
    padding: 3px 10px !important;
    border-radius: var(--radius-sm) !important;
    font-size: 0.75em !important;
    letter-spacing: 0.05em;
    display: inline-block;
    margin-right: 4px;
}

/* Profile header */
.girlsingle .profile-header {
    margin-bottom: 16px !important;
}

.girlsingle .thumbs {
    display: grid !important;
    grid-template-columns: repeat(5, 1fr);
    gap: 6px;
    margin-bottom: 16px !important;
}
.girlsingle .thumbs .profile-img-thumb-wrapper {
    width: 100% !important;
    float: none !important;
    padding: 0 !important;
    aspect-ratio: 3 / 4;
    overflow: hidden;
}
.girlsingle .thumbs .profile-img-thumb-wrapper .profile-img-thumb {
    width: 100%;
    height: 100%;
}
.girlsingle .thumbs .profile-img-thumb-wrapper .profile-img-thumb a {
    display: block;
    width: 100%;
    height: 100%;
}
.girlsingle .thumbs .profile-img-thumb-wrapper img.mobile-ready-img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
    object-position: center 20%;
    border-radius: var(--radius-md) !important;
}
.girlsingle .thumbs .gallery-video-link {
    display: block;
    width: 100%;
    height: 100%;
    position: relative;
}
.girlsingle .thumbs .gallery-video-no-poster {
    width: 100%;
    height: 100%;
    background: #1a1a2e;
}
.girlsingle .thumbs .gallery-play-icon {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 36px;
    color: #fff;
    text-shadow: 0 2px 8px rgba(0,0,0,0.6);
    pointer-events: none;
}
@media (max-width: 768px) {
    .girlsingle .thumbs {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}
@media (max-width: 480px) {
    .girlsingle .thumbs {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 4px;
    }
}

/* Profile header info */
.profile-header-name-info {
    background: var(--bg-elevated) !important;
    border: 1px solid var(--border-color) !important;
    color: var(--text-primary) !important;
    border-radius: var(--radius-md) !important;
}

.section-box {
    border-bottom-color: var(--border-color) !important;
}

.section-box b {
    color: var(--text-muted) !important;
}

.section-box .valuecolumn {
    color: var(--text-primary) !important;
}

/* Contact section */
.contact {
    color: var(--text-secondary) !important;
}

.contact .b-label {
    color: var(--text-muted) !important;
}

.contact .valuecolumn {
    color: var(--text-primary) !important;
}

.contact .valuecolumn a {
    color: var(--primary) !important;
}

/* Call box / phone — match profile-header-name-info */
.girlsingle .profile-header .call-box {
    background: var(--bg-elevated) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: var(--radius-md) !important;
    padding: 10px 0 !important;
    display: flex;
    flex-direction: row;
    gap: 0;
    align-items: center;
}

/* Gap between call-box and profile-header-name-info */
.girlsingle .profile-header .profile-header-info {
    gap: 8px !important;
}

.girlsingle .profile-header .phone-box {
    display: flex !important;
    align-items: center !important;
    gap: 10px;
    margin-bottom: 0 !important;
    padding: 8px 14px;
    text-align: left !important;
    min-height: 50px;
}

.girlsingle .profile-header .phone-box:not(:last-child) {
    border-right: 1px solid var(--border-color);
    border-bottom: none;
}

.girlsingle .profile-header .phone-box img.phone,
.girlsingle .profile-header .phone-box img.whatsapp {
    width: 26px !important;
    height: 26px;
    flex-shrink: 0;
    filter: brightness(1.3);
}

.girlsingle .profile-header .phone-box a {
    color: var(--text-primary) !important;
    font-size: 1.05em !important;
    font-weight: 600 !important;
    letter-spacing: 0.04em;
    transition: color var(--transition) !important;
    text-decoration: none !important;
}

.girlsingle .profile-header .phone-box a:hover {
    color: var(--primary) !important;
}

/* Similar escorts row */
.similar-escorts-section {
    margin-top: 32px;
    padding: 24px 0;
}
.similar-escorts-title {
    color: var(--text-primary) !important;
    font-size: 1.15em;
    font-weight: 600;
    margin-bottom: 16px;
}
.similar-escorts-row {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    overflow-y: hidden;
    padding-bottom: 8px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
}
.similar-escorts-row > .girl {
    flex: 0 0 190px;
    max-width: 190px;
    scroll-snap-align: start;
    float: none !important;
    width: auto !important;
    margin: 0 !important;
}
.similar-escorts-row > .show-separator {
    display: none !important;
}
.similar-escorts-row::-webkit-scrollbar {
    height: 4px;
}
.similar-escorts-row::-webkit-scrollbar-track {
    background: var(--bg-elevated);
    border-radius: 2px;
}
.similar-escorts-row::-webkit-scrollbar-thumb {
    background: var(--border-color);
    border-radius: 2px;
}
@media (max-width: 768px) {
    .similar-escorts-row > .girl {
        flex: 0 0 160px;
        max-width: 160px;
    }
}

/* Report profile */
.report-profile-trigger {
    text-align: center;
    margin: 24px 0 8px;
}
.report-btn {
    background: none;
    border: 1px solid var(--border-color);
    color: var(--text-muted);
    font-size: 0.8em;
    padding: 8px 20px;
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--transition);
}
.report-btn:hover {
    border-color: #e53935;
    color: #e53935;
}

/* Report modal */
.report-modal-overlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(0,0,0,0.7);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px;
}
.report-modal {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    max-width: 500px;
    width: 100%;
    max-height: 85vh;
    overflow-y: auto;
    padding: 24px;
}
.report-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
}
.report-modal-header h4 {
    margin: 0;
    color: var(--text-primary);
    font-size: 1.1em;
}
.report-modal-close {
    background: none;
    border: none;
    color: var(--text-muted);
    font-size: 1.6em;
    cursor: pointer;
    line-height: 1;
    padding: 0 4px;
}
.report-modal-close:hover { color: var(--text-primary); }
.report-field {
    margin-bottom: 14px;
}
.report-label {
    display: block;
    color: var(--text-secondary);
    font-size: 0.85em;
    font-weight: 500;
    margin-bottom: 8px;
}
.report-hint {
    color: var(--text-muted);
    font-weight: 400;
    font-size: 0.9em;
}
.report-reasons {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.report-reason {
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--text-primary);
    font-size: 0.9em;
    cursor: pointer;
    padding: 8px 12px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--border-color);
    transition: all var(--transition);
}
.report-reason:hover {
    border-color: var(--primary);
    background: rgba(233,30,99,0.05);
}
.report-reason input[type="radio"] {
    accent-color: var(--primary);
}
.report-form textarea,
.report-form input[type="email"] {
    width: 100%;
    padding: 10px 12px;
    background: var(--bg-elevated);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    color: var(--text-primary);
    font-size: 0.9em;
    font-family: inherit;
    resize: vertical;
    box-sizing: border-box;
}
.report-form textarea:focus,
.report-form input[type="email"]:focus {
    outline: none;
    border-color: var(--primary);
}
.report-submit {
    width: 100%;
    padding: 12px;
    background: linear-gradient(135deg, var(--primary), var(--primary-dark)) !important;
    color: #fff;
    border: none;
    border-radius: var(--radius-full);
    font-size: 0.95em;
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition);
    box-shadow: 0 2px 12px rgba(233, 30, 99, 0.25);
}
.report-submit:hover {
    box-shadow: 0 4px 20px rgba(233, 30, 99, 0.45);
    transform: translateY(-2px);
}
.report-submit:disabled { opacity: 0.5; cursor: not-allowed; }

/* Contact page */
.contact-page { max-width: 700px; margin: 0 auto; }
.contact-info-block {
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.contact-info-item {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 16px;
    background: var(--bg-elevated);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
}
.contact-info-icon {
    font-size: 1.4em;
    flex-shrink: 0;
    width: 32px;
    text-align: center;
}
.contact-info-item b {
    display: block;
    color: var(--text-primary);
    margin-bottom: 2px;
    font-size: 0.9em;
}
.contact-info-item a,
.contact-info-item span {
    color: var(--text-secondary);
    font-size: 0.85em;
}
.contact-info-item a:hover { color: var(--primary); }
.contact-form-wrapper {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: 24px;
}
.contact-form-wrapper h4 {
    color: var(--text-primary);
    font-size: 1.05em;
    margin: 0;
}
.contact-form { margin-top: 16px; }
.contact-fields-row {
    display: flex;
    gap: 14px;
}
.contact-field {
    margin-bottom: 14px;
}
.contact-field-half {
    flex: 1;
}
.contact-field label {
    display: block;
    color: var(--text-secondary);
    font-size: 0.85em;
    font-weight: 500;
    margin-bottom: 6px;
}
.contact-field input,
.contact-field textarea {
    width: 100%;
    padding: 10px 12px;
    background: var(--bg-elevated);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    color: var(--text-primary);
    font-size: 0.9em;
    font-family: inherit;
    box-sizing: border-box;
    resize: vertical;
}
.contact-field input:focus,
.contact-field textarea:focus {
    outline: none;
    border-color: var(--primary);
}
.contact-field-hint {
    color: var(--text-muted);
    font-size: 0.75em;
    margin-top: 4px;
}
.contact-submit {
    width: 100%;
    padding: 12px;
    background: linear-gradient(135deg, var(--primary), var(--primary-dark)) !important;
    color: #fff;
    border: none;
    border-radius: var(--radius-full);
    font-size: 0.95em;
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition);
    box-shadow: 0 2px 12px rgba(233, 30, 99, 0.25);
}
.contact-submit:hover {
    box-shadow: 0 4px 20px rgba(233, 30, 99, 0.45);
    transform: translateY(-2px);
}
@media (max-width: 576px) {
    .contact-fields-row { flex-direction: column; gap: 0; }
}

/* View count on cards */
.card-views {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: 0.75em;
    color: rgba(255,255,255,0.7);
    margin-left: 6px;
}
.card-views-icon {
    font-size: 0.9em;
}
/* View count on profile */
.profile-views-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: var(--bg-elevated);
    border: 1px solid var(--border-color);
    border-radius: 20px;
    padding: 3px 10px;
    font-size: 0.7em;
    color: var(--text-muted);
    font-weight: 500;
    vertical-align: middle;
    margin-left: 6px;
}
.profile-views-icon {
    font-size: 1.1em;
}
/* Views analytics page */
.views-stats-cards {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
}
.views-stat-card {
    background: var(--bg-elevated);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: 20px 16px;
    text-align: center;
}
.views-stat-num {
    font-size: 1.8em;
    font-weight: 700;
    color: var(--text-primary);
}
.views-stat-label {
    font-size: 0.8em;
    color: var(--text-muted);
    margin-top: 4px;
}
.views-countries {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.views-country-row {
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--bg-elevated);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    padding: 6px 12px;
    font-size: 0.85em;
}
.views-country-flag {
    font-weight: 700;
    font-size: 0.75em;
    background: var(--bg-card);
    border-radius: 3px;
    padding: 2px 5px;
    color: var(--text-muted);
}
.views-country-name {
    color: var(--text-primary);
}
.views-country-cnt {
    color: var(--text-muted);
    font-size: 0.85em;
}
.views-table-wrap {
    overflow-x: auto;
}
.views-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.85em;
}
.views-table th {
    text-align: left;
    padding: 10px 12px;
    color: var(--text-muted);
    font-weight: 600;
    font-size: 0.8em;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-bottom: 1px solid var(--border-color);
}
.views-table td {
    padding: 8px 12px;
    color: var(--text-primary);
    border-bottom: 1px solid var(--border-subtle, rgba(255,255,255,0.04));
}
.views-row-bot td {
    color: var(--text-muted);
    opacity: 0.6;
}
.views-type-bot {
    background: rgba(255,152,0,0.15);
    color: #ffb74d;
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 0.85em;
}
.views-type-human {
    background: rgba(76,175,80,0.15);
    color: #81c784;
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 0.85em;
}
.views-pagination {
    display: flex;
    gap: 10px;
    margin-top: 16px;
    justify-content: center;
}
/* Click type badges */
.views-type-phone {
    background: rgba(33,150,243,0.15);
    color: #64b5f6;
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 0.85em;
}
.views-type-wa {
    background: rgba(76,175,80,0.15);
    color: #81c784;
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 0.85em;
}
/* Stat card accents */
.views-stat-phone { border-color: rgba(33,150,243,0.3); }
.views-stat-wa { border-color: rgba(76,175,80,0.3); }
.views-stats-cards-secondary .views-stat-num { font-size: 1.3em; }
/* Tabs */
.views-tabs {
    display: flex;
    gap: 4px;
    border-bottom: 1px solid var(--border-color);
}
.views-tab {
    padding: 10px 20px;
    color: var(--text-muted);
    font-size: 0.9em;
    font-weight: 500;
    text-decoration: none;
    border-bottom: 2px solid transparent;
    transition: all var(--transition);
}
.views-tab:hover { color: var(--text-primary); }
.views-tab.active {
    color: var(--primary);
    border-bottom-color: var(--primary);
}
@media (max-width: 768px) {
    .views-stats-cards {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Bookmark button on cards */
.thumb {
    position: relative;
}
.bookmark-btn {
    position: absolute;
    top: 8px;
    right: 8px;
    z-index: 10;
    background: rgba(0,0,0,0.5);
    backdrop-filter: blur(4px);
    border: none;
    color: #fff;
    font-size: 1.2em;
    width: 34px;
    height: 34px;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: all 0.2s;
    line-height: 1;
    padding: 0;
}
.girl:hover .bookmark-btn,
.bookmark-btn.bookmarked {
    opacity: 1;
}
.bookmark-btn.bookmarked {
    color: var(--primary);
    background: rgba(0,0,0,0.6);
}
.bookmark-btn:hover {
    transform: scale(1.15);
    opacity: 1;
}
/* Profile page bookmark */
.profile-title-row {
    display: flex;
    align-items: center;
    gap: 12px;
}
.bookmark-btn-profile {
    position: static;
    opacity: 1;
    background: var(--bg-elevated);
    border: 1px solid var(--border-color);
    color: var(--text-muted);
    font-size: 1.3em;
    width: 40px;
    height: 40px;
    flex-shrink: 0;
}
.bookmark-btn-profile.bookmarked {
    color: var(--primary);
    border-color: var(--primary);
    background: rgba(233,30,99,0.1);
}
/* Header bookmark icon */
.bookmarks-btn a {
    display: flex;
    align-items: center;
    gap: 4px;
    position: relative;
}
.bookmark-header-icon {
    font-size: 1.3em;
    line-height: 1;
}
.bookmark-header-count {
    /* background: var(--primary); */
    color: #fff;
    font-size: 0.65em;
    font-weight: 700;
    min-width: 16px;
    height: 16px;
    line-height: 16px;
    text-align: center;
    border-radius: 8px;
    padding: 0 4px;
}
.bookmark-mobile-count {
    font-size: 0.85em;
    opacity: 0.7;
}
/* Saved profiles page */
.saved-loading {
    text-align: center;
    color: var(--text-muted);
    padding: 40px 0;
}
.saved-empty {
    text-align: center;
    padding: 40px 0;
    color: var(--text-muted);
}
.saved-empty-icon {
    font-size: 3em;
    margin-bottom: 12px;
    opacity: 0.3;
}
.saved-actions {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 16px;
}
.saved-clear-btn {
    background: none;
    border: 1px solid var(--border-color);
    color: var(--text-muted);
    padding: 6px 14px;
    border-radius: var(--radius-sm);
    font-size: 0.8em;
    cursor: pointer;
    transition: all var(--transition);
}
.saved-clear-btn:hover {
    border-color: #e53935;
    color: #e53935;
}

/* Services */
.services div {
    color: var(--text-secondary) !important;
}

.services .icon-ok {
    color: var(--success) !important;
}

.services .icon-cancel {
    color: var(--text-muted) !important;
}

/* Rates table */
.rates-table {
    border-collapse: collapse !important;
}

.rates-table th {
    background: var(--bg-elevated) !important;
    color: var(--text-muted) !important;
    border-color: var(--border-color) !important;
    text-transform: uppercase;
    font-size: 0.8em;
    letter-spacing: 0.05em;
}

.rates-table td {
    border-color: var(--border-color) !important;
    color: var(--text-primary) !important;
    padding: 8px 10px !important;
}

.rates-table td b {
    color: var(--text-secondary) !important;
}

/* Online status */
.online-status {
    color: var(--success) !important;
}

.online-label {
    background: rgba(0, 200, 83, 0.15) !important;
    color: var(--success) !important;
    border-radius: var(--radius-full) !important;
    padding: 4px 12px !important;
}

/* Star rating display */
.starrating {
    filter: brightness(1.1);
}

.profilestarrating-wrapper .label {
    color: var(--text-muted) !important;
}

.profilestarrating-wrapper i {
    color: var(--text-muted) !important;
}

/* --- Photo Management --- */
.photo-item {
    transition: all var(--transition) !important;
}

.photo-item img {
    border-radius: var(--radius-sm) !important;
}

/* Small action buttons in photo grid */
.photo-item button[style*="background:#4CAF50"],
.photo-item button[style*="background: #4CAF50"] {
    background: var(--success) !important;
    border-radius: var(--radius-sm) !important;
}

.photo-item button[style*="background:#f44336"],
.photo-item button[style*="background: #f44336"] {
    background: var(--danger) !important;
    border-radius: var(--radius-sm) !important;
}

.photo-item button[style*="background:#2196F3"],
.photo-item button[style*="background: #2196F3"] {
    background: linear-gradient(135deg, #2196F3, #1565C0) !important;
    border-radius: var(--radius-sm) !important;
}

.photo-item span[style*="color: #e91e63"] {
    color: var(--primary) !important;
}

/* --- All inline table overrides (comprehensive) --- */
table[style*="border-collapse"] {
    color: var(--text-primary) !important;
}

table[style*="border-collapse"] th[style*="border: 1px solid #ddd"],
table[style*="border-collapse"] th[style*="border:1px solid #ddd"] {
    background: var(--bg-elevated) !important;
    border-color: var(--border-color) !important;
    color: var(--text-secondary) !important;
}

table[style*="border-collapse"] td[style*="border: 1px solid #ddd"],
table[style*="border-collapse"] td[style*="border:1px solid #ddd"] {
    border-color: var(--border-color) !important;
    color: var(--text-secondary) !important;
}

table[style*="border-collapse"] tr[style*="background: #f5f5f5"],
table[style*="border-collapse"] tr[style*="background:#f5f5f5"] {
    background: var(--bg-elevated) !important;
}

/* --- Comprehensive inline color overrides --- */

/* Background overrides */
*[style*="background: #fff;"],
*[style*="background:#fff;"],
*[style*="background: white"],
*[style*="background: #ffffff"] {
    background: var(--bg-card) !important;
}

*[style*="background: #f9f9f9"],
*[style*="background:#f9f9f9"] {
    background: var(--bg-card) !important;
}

*[style*="background: #f5f5f5"],
*[style*="background:#f5f5f5"] {
    background: var(--bg-elevated) !important;
}

*[style*="background: #f0f8ff"] {
    background: var(--bg-card) !important;
}

*[style*="background: #FFF8E1"],
*[style*="background: #fff8e1"] {
    background: rgba(255, 152, 0, 0.08) !important;
}

*[style*="background: #fff3e0"],
*[style*="background:#fff3e0"] {
    background: rgba(255, 152, 0, 0.08) !important;
}

/* Text color overrides */
*[style*="color: #333"],
*[style*="color:#333"] {
    color: var(--text-primary) !important;
}

*[style*="color: #555"],
*[style*="color:#555"] {
    color: var(--text-secondary) !important;
}

*[style*="color: #666"],
*[style*="color:#666"] {
    color: var(--text-secondary) !important;
}

*[style*="color: #795548"],
*[style*="color:#795548"] {
    color: #ffcc80 !important;
}

*[style*="color: #999"],
*[style*="color:#999"] {
    color: var(--text-muted) !important;
}

/* Border overrides */
*[style*="border: 1px solid #ddd"],
*[style*="border:1px solid #ddd"] {
    border-color: var(--border-color) !important;
}

*[style*="border: 2px solid #ddd"],
*[style*="border:2px solid #ddd"] {
    border-color: var(--border-color) !important;
}

*[style*="border-bottom: 1px solid #eee"],
*[style*="border-bottom:1px solid #eee"] {
    border-bottom-color: var(--border-color) !important;
}

*[style*="border: 2px solid #ff9800"],
*[style*="border: 1px solid #ff9800"] {
    border-color: rgba(255, 152, 0, 0.3) !important;
}

*[style*="border: 2px solid #e91e63"] {
    border-color: var(--primary) !important;
}

*[style*="border: 2px dashed #ccc"] {
    border-color: var(--border-light) !important;
}

/* Premium plan card backgrounds in dark mode */
.bodybox div[style*="background: #fff"][style*="border: 2px solid"] {
    background: var(--bg-card) !important;
}

/* Status labels — keep the colored ones visible */
span[style*="background: #4CAF50"][style*="color: #fff"] {
    background: rgba(0, 200, 83, 0.85) !important;
}

span[style*="background: #999"][style*="color: #fff"] {
    background: var(--bg-elevated) !important;
    border: 1px solid var(--border-light) !important;
}

/* Order status colors in tables */
span[style*="color:#4CAF50"],
span[style*="color: #4CAF50"] {
    color: var(--success) !important;
}

span[style*="color:#f44336"],
span[style*="color: #f44336"] {
    color: var(--danger) !important;
}

span[style*="color:#ff9800"],
span[style*="color: #ff9800"] {
    color: var(--warning) !important;
}

/* Cron/code display */
div[style*="background: #333"][style*="color: #0f0"] {
    background: var(--bg-body) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: var(--radius-sm) !important;
    color: var(--success) !important;
}

/* --- Input submit buttons --- */
input[type="submit"].pinkbutton {
    cursor: pointer !important;
    font-family: var(--font-sans) !important;
}

input[type="submit"].input,
input[type="submit"] {
    cursor: pointer;
}

/* --- Links and navigation --- */
/* .bodybox > a {
    color: var(--primary) !important;
} */

/* Pagination in admin */
b[style*="padding: 4px 8px"] {
    color: var(--primary) !important;
}

/* --- General table styling --- */
table {
    border-collapse: collapse;
}

.bodybox table {
    width: 100%;
}

.bodybox table th {
    font-weight: 600;
    text-align: left;
}

/* --- Fancybox dark override --- */
.fancybox-skin {
    background: var(--bg-surface) !important;
    border-radius: var(--radius-md) !important;
}

.fancybox-outer {
    background: var(--bg-body) !important;
}

.fancybox-title {
    color: var(--text-secondary) !important;
}

/* --- Video player lightbox --- */
.video-player-lightbox {
    background: var(--bg-body) !important;
}

/* --- See more button --- */
.see-more-button {
    margin: 16px auto !important;
    display: block !important;
    text-align: center !important;
    max-width: 200px !important;
    text-decoration: none !important;
    padding: 10px 24px !important;
    cursor: pointer !important;
    color: #fff !important;
    background: linear-gradient(135deg, var(--primary), var(--primary-dark)) !important;
    border-radius: var(--radius-full) !important;
    font-weight: 600 !important;
    font-size: 0.9em !important;
    box-shadow: 0 2px 12px rgba(233, 30, 99, 0.25) !important;
    transition: all var(--transition) !important;
}
.see-more-button:hover {
    box-shadow: 0 4px 20px rgba(233, 30, 99, 0.45) !important;
    transform: translateY(-2px);
    color: #fff !important;
}

/* --- Home region chips --- */
.home-regions {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    padding: 16px 12px !important;
    justify-content: center !important;
}
.home-region-chip {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    background: var(--bg-elevated) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: var(--radius-full) !important;
    padding: 6px 14px !important;
    text-decoration: none !important;
    color: var(--text-secondary) !important;
    font-size: 0.85em !important;
    transition: border-color var(--transition), color var(--transition), background var(--transition) !important;
    white-space: nowrap !important;
}
.home-region-chip:hover {
    border-color: var(--primary) !important;
    color: var(--primary) !important;
    background: var(--primary-glow) !important;
}
.home-region-name {
    font-weight: 500 !important;
}
.home-region-count {
    background: rgba(255,255,255,0.1) !important;
    color: var(--text-muted) !important;
    font-size: 0.8em !important;
    font-weight: 600 !important;
    padding: 1px 7px !important;
    border-radius: 10px !important;
    min-width: 20px !important;
    text-align: center !important;
}
.home-region-chip:hover .home-region-count {
    background: rgba(233, 30, 99, 0.15) !important;
    color: var(--primary) !important;
}

/* --- Social icons filter for dark bg --- */
.social-icons-contact-info {
    filter: brightness(0.85) invert(0.1);
}

/* --- Profile sticker --- */
.wpp-sticker {
    border-radius: var(--radius-sm) !important;
}

/* --- Checkbox/radio styling --- */
input[type="checkbox"],
input[type="radio"] {
    accent-color: var(--primary);
}

/* --- Fix small text items --- */
small {
    color: var(--text-muted) !important;
}

small[style*="color:#999"],
small[style*="color: #999"] {
    color: var(--text-muted) !important;
}

/* Red required asterisk */
i[style*="color:red"],
i[style*="color: red"] {
    color: var(--primary) !important;
}

/* Warning/info banner (settings page email change) */
*[style*="background: #fff3cd"],
*[style*="background:#fff3cd"] {
    background: rgba(255, 193, 7, 0.1) !important;
    border-color: rgba(255, 193, 7, 0.3) !important;
    color: #ffd54f !important;
    border-radius: var(--radius-md) !important;
}

*[style*="border: 1px solid #ffc107"] {
    border-color: rgba(255, 193, 7, 0.3) !important;
}

/* Admin section orange header */
*[style*="color: #e65100"],
*[style*="color:#e65100"] {
    color: #ffab40 !important;
}

/* Error/validation text */
span[style*="color:#c33"],
span[style*="color: #c33"] {
    color: var(--danger) !important;
}

/* --- Photo grid drag state --- */
.photo-item[style*="opacity: 0.4"] {
    opacity: 0.4 !important;
}

.photo-item[style*="border-color: #2196F3"] {
    border-color: var(--primary) !important;
}

/* --- Loading and empty states --- */
.bodybox p:only-child {
    color: var(--text-muted);
}

/* --- Premium balance display --- */
div[style*="font-size: 32px"][style*="font-weight: bold"] {
    text-shadow: 0 0 20px rgba(233, 30, 99, 0.15);
}

/* --- Smooth page transitions --- */
.maincontainer {
    animation: fadeInUp 0.3s ease-out;
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* --- Card hover premium glow animation --- */
@keyframes premiumGlow {
    0%, 100% { box-shadow: 0 0 15px rgba(255, 111, 0, 0.15); }
    50% { box-shadow: 0 0 25px rgba(255, 111, 0, 0.25); }
}

.thumb.girlpremium {
    animation: premiumGlow 3s ease-in-out infinite;
}

.thumb.girlpremium:hover {
    animation: none;
}

/* --- Profile header responsive --- */
@media (max-width: 768px) {
    .profile-header-name-info .section-box {
        font-size: 0.85em !important;
    }

    .girlsinglelabels span {
        font-size: 0.65em !important;
        padding: 2px 6px !important;
    }

    .girlsingle .profile-header .call-box {
        flex-direction: column !important;
    }
    .girlsingle .profile-header .phone-box:not(:last-child) {
        border-right: none !important;
        border-bottom: 1px solid var(--border-color) !important;
    }

    .photo-item[style*="width: 150px"] {
        width: 110px !important;
    }

    .photo-item img[style*="width: 140px"] {
        width: 100px !important;
    }
}

@media (max-width: 576px) {
    .photos-grid[style*="gap: 15px"] {
        gap: 8px !important;
    }

    .photo-item[style*="width: 150px"] {
        width: 90px !important;
    }

    .photo-item img[style*="width: 140px"] {
        width: 80px !important;
    }
}


/* --- Responsive adjustments --- */
@media (max-width: 768px) {
    :root {
        --header-h: 60px;
    }

    .bodybox {
        padding: 16px !important;
        border-radius: var(--radius-md) !important;
    }

    .bodybox.profile-page {
        padding: 12px 8px !important;
        border-radius: var(--radius-sm) !important;
    }

    .girl {
        padding: 4px !important;
    }

    h3 {
        font-size: 1.2em !important;
    }

    .pinkbutton,
    .redbutton {
        padding: 8px 18px !important;
        font-size: 0.85em !important;
    }

    .girlsingle .girlinfo,
    .girlsingle .girlinfo.l,
    .girlsingle .girlinfo.r {
        width: 100% !important;
        float: none !important;
        padding: 0 !important;
    }

    .girlsingle .girlinfo .girlinfo-section {
        padding: 16px 12px !important;
        margin-bottom: 10px !important;
    }

    .girlsingle .aboutme {
        padding: 16px 12px !important;
        margin-bottom: 10px !important;
    }

    #addreviewsection,
    .review-section {
        padding: 16px 12px !important;
    }
}

@media (max-width: 576px) {
    .maincontainer {
        padding: 0 4px !important;
    }

    .bodybox {
        padding: 10px 6px !important;
    }

    .bodybox.profile-page {
        padding: 8px 4px !important;
        border-radius: 0 !important;
        border-left: none !important;
        border-right: none !important;
    }

    .girlsingle .girlinfo .girlinfo-section {
        padding: 14px 10px !important;
        border-radius: var(--radius-sm) !important;
    }

    .girlsingle .aboutme {
        padding: 14px 10px !important;
        border-radius: var(--radius-sm) !important;
    }

    #addreviewsection,
    .review-section {
        padding: 14px 10px !important;
        border-radius: var(--radius-sm) !important;
    }

    .girl-name {
        font-size: 0.85em !important;
    }
}

/* ===== Geo location (profile edit) ===== */
.geo-notice {
    background: #1a2a1a !important;
    border: 1px solid #2a4a2a !important;
    border-radius: 8px !important;
    padding: 12px 16px !important;
    font-size: 0.9em !important;
    color: #b0d0b0 !important;
    line-height: 1.5 !important;
}
.geo-controls {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    flex-wrap: wrap !important;
}
.geo-coords {
    font-size: 0.85em !important;
    color: #999 !important;
    font-family: monospace !important;
}
.greybutton {
    background: #555 !important;
    color: #fff !important;
    border: none !important;
    cursor: pointer !important;
    display: inline-block !important;
}
.greybutton:hover {
    background: #666 !important;
}

/* ===== Nearby page ===== */
.nearby-request-block {
    text-align: center !important;
    padding: 40px 20px !important;
    background: #1a1a2e !important;
    border-radius: 12px !important;
    border: 1px solid #333 !important;
}
.nearby-request-block p {
    margin: 0 0 8px !important;
    color: #ccc !important;
    font-size: 0.95em !important;
}
.nearby-loading {
    text-align: center !important;
    padding: 40px 20px !important;
}
.nearby-loading p {
    color: #aaa !important;
}
.nearby-error {
    text-align: center !important;
    padding: 30px 20px !important;
    background: #2a1a1a !important;
    border-radius: 12px !important;
    border: 1px solid #442222 !important;
}
.nearby-error p {
    color: #e88 !important;
    margin: 0 0 15px !important;
}
.nearby-empty {
    text-align: center !important;
    padding: 40px 20px !important;
    color: #888 !important;
}
.nearby-distance-badge {
    position: absolute !important;
    top: 8px !important;
    left: 8px !important;
    background: rgba(0, 0, 0, 0.75) !important;
    color: #4fc3f7 !important;
    font-size: 0.75em !important;
    font-weight: 600 !important;
    padding: 3px 8px !important;
    border-radius: 4px !important;
    z-index: 5 !important;
    pointer-events: none !important;
}

/* ===== Verification page ===== */
.verify-status {
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
    padding: 20px !important;
    border-radius: 10px !important;
    border: 1px solid #333 !important;
}
.verify-status-approved {
    background: #1a2a1a !important;
    border-color: #2a4a2a !important;
}
.verify-status-pending {
    background: #2a2a1a !important;
    border-color: #4a4a2a !important;
}
.verify-status-rejected {
    background: #2a1a1a !important;
    border-color: #4a2a2a !important;
}
.verify-status-icon {
    font-size: 2.5em !important;
    line-height: 1 !important;
}
.verify-status-text strong {
    font-size: 1.1em !important;
    display: block !important;
    margin-bottom: 4px !important;
}
.verify-status-text p {
    margin: 4px 0 0 !important;
    color: #aaa !important;
    font-size: 0.9em !important;
}
.verify-instructions {
    background: #1a1a2a !important;
    border: 1px solid #333 !important;
    border-radius: 10px !important;
    padding: 20px !important;
}
.verify-steps {
    display: flex !important;
    flex-direction: column !important;
    gap: 14px !important;
}
.verify-step {
    display: flex !important;
    align-items: flex-start !important;
    gap: 14px !important;
}
.verify-step-num {
    min-width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    background: #e91e63 !important;
    color: #fff !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-weight: 700 !important;
    font-size: 0.9em !important;
}
.verify-step-text {
    padding-top: 4px !important;
    line-height: 1.5 !important;
}
.verify-gesture {
    font-size: 1.4em !important;
    vertical-align: middle !important;
}
.verify-requirements {
    margin-top: 16px !important;
    padding-top: 16px !important;
    border-top: 1px solid #333 !important;
}
.verify-requirements ul {
    margin: 8px 0 0 20px !important;
    padding: 0 !important;
    color: #bbb !important;
    font-size: 0.9em !important;
}
.verify-requirements li {
    margin-bottom: 4px !important;
}
.verify-upload-area {
    border: 2px dashed #444 !important;
    border-radius: 12px !important;
    padding: 40px 20px !important;
    text-align: center !important;
    cursor: pointer !important;
    transition: border-color 0.2s, background 0.2s !important;
    min-height: 200px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}
.verify-upload-area:hover,
.verify-upload-area.dragover {
    border-color: #e91e63 !important;
    background: rgba(233, 30, 99, 0.05) !important;
}
.verify-upload-prompt {
    color: #888 !important;
}
.verify-gesture-big {
    font-size: 4em !important;
    margin-bottom: 12px !important;
}
.verify-upload-hint {
    font-size: 0.8em !important;
    color: #666 !important;
    margin-top: 8px !important;
}
.verify-upload-preview img,
.verify-upload-preview video {
    max-width: 100% !important;
    max-height: 400px !important;
    border-radius: 8px !important;
}
.verify-message {
    text-align: center !important;
    padding: 12px !important;
    margin-top: 16px !important;
    border-radius: 8px !important;
    font-size: 0.95em !important;
}
.verify-msg-ok {
    background: #1a2a1a !important;
    color: #6f6 !important;
    border: 1px solid #2a4a2a !important;
}
.verify-msg-error {
    background: #2a1a1a !important;
    color: #f66 !important;
    border: 1px solid #4a2a2a !important;
}

/* ===== Gallery video play icon ===== */
.gallery-video-link {
    position: relative !important;
    display: block !important;
}
.gallery-play-icon {
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
    width: 56px !important;
    height: 56px !important;
    background: rgba(0, 0, 0, 0.6) !important;
    border: 2px solid rgba(255, 255, 255, 0.8) !important;
    border-radius: 50% !important;
    color: #fff !important;
    font-size: 22px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding-left: 4px !important;
    pointer-events: none !important;
    transition: background 0.2s, transform 0.2s !important;
}
.gallery-video-link:hover .gallery-play-icon {
    background: rgba(233, 30, 99, 0.8) !important;
    transform: translate(-50%, -50%) scale(1.1) !important;
}
.gallery-video-no-poster {
    width: 100% !important;
    padding-bottom: 150% !important;
    background: #1a1a2a !important;
    border-radius: 5px !important;
}
.profile-gallery-video {
    position: relative !important;
    cursor: pointer;
}

/* Video thumbnail preview */
.video-thumb-preview {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
    object-position: center 20%;
    border-radius: var(--radius-md) !important;
    pointer-events: none;
}
.video-thumb-cell:hover .gallery-play-icon {
    background: rgba(233, 30, 99, 0.8) !important;
    transform: translate(-50%, -50%) scale(1.1) !important;
}

/* Video lightbox modal */
.video-modal-overlay {
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    z-index: 999999;
    background: rgba(0,0,0,0.9);
    display: flex;
    align-items: center;
    justify-content: center;
}
.video-modal-content {
    position: relative;
    width: 90%;
    max-width: 800px;
    max-height: 90vh;
}
.video-modal-content video {
    width: 100%;
    max-height: 85vh;
    border-radius: 8px;
    background: #000;
}
.video-modal-close {
    position: absolute;
    top: -40px;
    right: 0;
    background: none;
    border: none;
    color: #fff;
    font-size: 32px;
    cursor: pointer;
    line-height: 1;
    opacity: 0.7;
    transition: opacity 0.2s;
}
.video-modal-close:hover {
    opacity: 1;
}

/* Video badge in admin photo grid */
.media-thumb-video-badge {
    position: absolute !important;
    top: 8px !important;
    left: 8px !important;
    background: rgba(233, 30, 99, 0.85) !important;
    color: #fff !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    padding: 2px 6px !important;
    border-radius: 3px !important;
    z-index: 2 !important;
    letter-spacing: 0.5px !important;
}

/* ============================================
   PROFILE STATUS BOX (personal cabinet)
   ============================================ */
.profile-status-box {
    background: var(--card-bg, #1e1e2a);
    border: 1px solid var(--border, #2d2d3d);
    padding: 16px 20px;
}
.psb-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 10px;
}
.psb-status {
    font-size: 15px;
    color: var(--text-secondary, #aaa);
}
.psb-badge {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 3px;
    font-size: 13px;
    font-weight: 700;
}
.psb-active {
    background: #28a745;
    color: #fff;
}
.psb-inactive {
    background: #6c757d;
    color: #fff;
}
.psb-toggle button {
    font-size: 13px;
    padding: 6px 16px;
    cursor: pointer;
}
.psb-checklist {
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid var(--border, #2d2d3d);
}
.psb-checklist p {
    margin: 0 0 8px;
    font-size: 14px;
    color: var(--text-secondary, #aaa);
}
.psb-checklist ul {
    list-style: none;
    padding: 0;
    margin: 0;
}
.psb-checklist li {
    padding: 4px 0;
    font-size: 14px;
}
.psb-checklist .check-ok {
    color: #28a745;
}
.psb-checklist .check-missing {
    color: #dc3545;
}
.psb-checklist .check-missing a {
    color: var(--primary, #e91e63);
    text-decoration: underline;
}

/* ============================================
   COLLAPSIBLE SECTIONS (profile page)
   ============================================ */
.collapsible-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    cursor: pointer;
    user-select: none;
}
.collapsible-header-right {
    display: flex;
    align-items: center;
    gap: 10px;
}
.collapsible-arrow {
    display: inline-block;
    font-size: 12px;
    transition: transform 0.2s;
    transform: rotate(-90deg);
    color: var(--text-secondary, #aaa);
}
.collapsible-arrow.open {
    transform: rotate(0deg);
}
.review-form-toggle {
    padding: 12px 0;
    border-top: 1px solid var(--border, #2d2d3d);
}
.review-form-toggle h4 {
    margin: 0;
}

/* ============================================
   404 PAGE
   ============================================ */
.page-404-box {
    text-align: center;
}
.e404-hero {
    padding: 40px 20px 30px;
}
.e404-code {
    font-size: 100px;
    font-weight: 800;
    line-height: 1;
    background: linear-gradient(135deg, var(--primary, #e91e63), #ff6090);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin-bottom: 10px;
}
.e404-title {
    font-size: 22px;
    margin-bottom: 10px;
}
.e404-text {
    color: var(--text-secondary, #aaa);
    font-size: 15px;
    max-width: 500px;
    margin: 0 auto;
}
.e404-suggestions {
    padding: 20px 0;
    text-align: left;
}
.e404-suggestions-title {
    text-align: center;
    margin-bottom: 16px;
    font-size: 17px;
}
.e404-cards {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}
.e404-actions {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
    padding-bottom: 20px;
}
.e404-actions a {
    padding: 10px 24px;
    font-size: 14px;
}
@media (max-width: 480px) {
    .e404-code { font-size: 70px; }
    .e404-title { font-size: 18px; }
}

/* ============================================
   ADMIN BAR (profile page)
   ============================================ */
.admin-bar {
    padding: 10px 15px;
    margin-bottom: 15px;
    /* background: #fff3e0; */
    border: 2px solid #ff9800;
    border-radius: 11px;
    font-size: 13px;
    /* color: #333; */
}
.admin-bar a { color: #e65100; text-decoration: underline; }
.ab-row { margin-bottom: 6px; }
.ab-row:last-child { margin-bottom: 0; }
.ab-controls {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
}
.ab-controls label {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-weight: 600;
    color: #555;
}
.ab-select {
    padding: 2px 6px;
    border: 1px solid #ccc;
    border-radius: 3px;
    font-size: 12px;
    background: #fff;
    color: #333;
    cursor: pointer;
}
.ab-toggle {
    cursor: pointer;
    user-select: none;
}
.ab-toggle input[type="checkbox"] {
    width: 16px;
    height: 16px;
    cursor: pointer;
    accent-color: #ff9800;
}
.ab-status {
    font-size: 12px;
    font-weight: 700;
    margin-left: 4px;
}
.ab-ok { color: #2e7d32; }
.ab-err { color: #c62828; }

/* ============================================
   ADMIN PHONES PAGE
   ============================================ */
.ap-stats {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}
.ap-stat {
    flex: 1;
    min-width: 100px;
    background: var(--card-bg, #1e1e2a);
    border: 1px solid var(--border, #2d2d3d);
    border-radius: 5px;
    padding: 12px;
    text-align: center;
}
.ap-stat-num {
    font-size: 28px;
    font-weight: 700;
}
.ap-stat-warn .ap-stat-num {
    color: #ff9800;
}
.ap-stat-label {
    font-size: 12px;
    color: var(--text-secondary, #aaa);
    margin-top: 2px;
}
.ap-section-title {
    font-size: 16px;
    margin-bottom: 10px;
    padding-bottom: 6px;
    border-bottom: 1px solid var(--border, #2d2d3d);
}
.ap-section-title.ap-multi {
    color: #ff9800;
}
.ap-table-wrap {
    overflow-x: auto;
}
.ap-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}
.ap-table th {
    text-align: left;
    padding: 8px 10px;
    background: var(--bg-elevated, #252535);
    color: var(--text-secondary, #aaa);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.ap-table td {
    padding: 8px 10px;
    border-bottom: 1px solid var(--border, #2d2d3d);
    vertical-align: top;
}
.ap-row-multi {
    background: rgba(255, 152, 0, 0.07);
}
.ap-phone {
    white-space: nowrap;
    font-family: monospace;
    font-size: 14px;
}
.ap-phone a {
    color: var(--text-primary, #eee);
    text-decoration: none;
}
.ap-phone a:hover {
    color: var(--primary, #e91e63);
}
.ap-badge-multi {
    display: inline-block;
    background: #ff9800;
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    padding: 1px 6px;
    border-radius: 10px;
    margin-left: 6px;
}
.ap-profile-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin-right: 14px;
    margin-bottom: 4px;
    white-space: nowrap;
}
.ap-profile-link a {
    color: var(--primary, #e91e63);
    text-decoration: none;
    font-weight: 500;
}
.ap-profile-link a:hover {
    text-decoration: underline;
}
.ap-pid {
    font-size: 11px;
    color: var(--text-secondary, #888);
}
.ap-status-pub {
    font-size: 11px;
    color: #28a745;
}
.ap-status-draft {
    font-size: 11px;
    color: #888;
}

/* ============================================
   SEO TEXT BLOCKS
   ============================================ */
.seo-text-block {
    padding: 24px 20px !important;
    margin-top: 10px;
    line-height: 1.7;
}
.seo-text-block h2 {
    font-size: 18px;
    color: var(--text-primary, #eee);
    margin-bottom: 12px;
}
.seo-text-block h3 {
    font-size: 15px;
    color: var(--text-primary, #ddd);
    margin: 16px 0 8px;
}
.seo-text-block p {
    font-size: 14px;
    color: var(--text-secondary, #999);
    margin-bottom: 10px;
}
.seo-text-block ul {
    list-style: none;
    padding: 0;
    margin: 0 0 12px;
}
.seo-text-block li {
    font-size: 14px;
    color: var(--text-secondary, #999);
    padding: 4px 0 4px 18px;
    position: relative;
}
.seo-text-block li::before {
    content: "\2713";
    position: absolute;
    left: 0;
    color: var(--primary, #e91e63);
    font-weight: 700;
}
.seo-text-block a {
    color: var(--primary, #e91e63);
    text-decoration: none;
}
.seo-text-block a:hover {
    text-decoration: underline;
}

/* H1 — inherit same styles as h3 in bodybox */
.bodybox h1 {
    color: var(--text-primary) !important;
    font-size: 1.3em !important;
    padding-bottom: 12px !important;
    position: relative;
}
.bodybox h1::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 40px;
    height: 3px;
    background: var(--primary) !important;
    border-radius: 2px;
}
.bodybox h1.l::after {
    left: 0;
}
/* H1 on profile page — keep same size as before */
h1.profile-title {
    font-size: 1.5em !important;
    padding-bottom: 0 !important;
    margin: 0;
}
h1.profile-title::after {
    display: none;
}

/* Report number button (warning icon next to phone) */
.report-number-btn {
    display: inline-block;
    margin-left: 6px;
    cursor: pointer;
    font-size: 14px;
    color: #666;
    opacity: 0.5;
    transition: opacity 0.2s, color 0.2s;
    vertical-align: middle;
}
.report-number-btn:hover {
    opacity: 1;
    color: #ff9800;
}