/* ============================================
   MODERN MODAL WINDOW STYLES
   Clean, flat, minimal design for error/success messages
   ============================================ */

/* Modal Overlay */
#modal-overlay {
    background: rgba(0, 0, 0, 0.5) !important;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}

/* Modal Window Container */
#modal-window {
    position: fixed !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
    z-index: 10000 !important;
    max-width: 600px;
    width: 90%;
    min-width: 400px;
    animation: modalFadeIn 0.3s ease;
    margin: 0 !important;
    bottom: auto !important;
    right: auto !important;
}

/* Override any inline styles that might interfere */
#modal-window[style*="position: absolute"] {
    position: fixed !important;
}

#modal-window[style*="top"] {
    top: 50% !important;
}

#modal-window[style*="left"] {
    left: 50% !important;
}

/* Override old styles from all.css that use position: absolute and top: 10% */
.pop-box#modal-window,
#modal-window.pop-box {
    position: fixed !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
    margin: 0 !important;
}

@keyframes modalFadeIn {
    from {
        opacity: 0;
        transform: translate(-50%, -48%) scale(0.95);
    }
    to {
        opacity: 1;
        transform: translate(-50%, -50%) scale(1);
    }
}

/* Pop Box - Modern Design */
.pop-box {
    background: #ffffff !important;
    border-radius: 16px !important;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2) !important;
    overflow: hidden !important;
    position: relative !important;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
}

.pop-box .i1 {
    overflow: hidden !important;
    border-radius: 16px 16px 0 0 !important;
}

.pop-box .i2 {
    overflow: hidden !important;
    border-radius: 16px 16px 0 0 !important;
}

/* Ensure first child (h2) has rounded top corners */
.pop-box > h2:first-child,
.pop-box > .i1:first-child > .i2:first-child > h2:first-child {
    border-radius: 16px 16px 0 0 !important;
}

/* Override old styles from all.css */
#modal-window.pop-box,
.pop-box#modal-window {
    position: fixed !important;
    left: 50% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) !important;
    margin: 0 !important;
}

/* Remove old background images and borders */
.pop-box .i1,
.pop-box .i2 {
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    border-radius: 16px 16px 0 0 !important;
}

.pop-box .pop-b {
    display: none !important;
}

/* Header */
.pop-box h2 {
    background: #ffffff !important;
    border-bottom: 1px solid #e8e8e8 !important;
    padding: 20px 24px !important;
    margin: 0 !important;
    height: auto !important;
    min-height: 24px !important;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    border-radius: 16px 16px 0 0 !important;
}

.pop-box h2.no-title {
    border-bottom: none !important;
    padding: 16px 20px 0 !important;
    overflow: visible !important;
    border-radius: 16px 16px 0 0 !important;
}

.pop-box h2 {
    overflow: visible !important;
    position: relative !important;
    border-radius: 16px 16px 0 0 !important;
}

.pop-box h2 span {
    background: none !important;
    color: #1a1a1a !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    line-height: 1.4 !important;
    text-shadow: none !important;
    padding: 0 !important;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif !important;
    flex: 1;
}

.pop-box h2.no-title span {
    display: none !important;
}

/* Close Button - Modern */
.pop-box .close {
    position: absolute !important;
    top: 16px !important;
    right: 16px !important;
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    background: #f5f5f5 !important;
    border: none !important;
    cursor: pointer !important;
    display: block !important;
    text-indent: -9999px !important;
    font-size: 0 !important;
    color: transparent !important;
    line-height: 1 !important;
    transition: background 0.2s ease !important;
    z-index: 100 !important;
    text-decoration: none !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    box-sizing: border-box !important;
}

.pop-box h2.no-title .close {
    top: 12px !important;
    right: 12px !important;
}

.pop-box .close::before {
    content: '×';
    font-size: 24px;
    font-weight: 300;
    line-height: 1;
    display: block;
    text-indent: 0;
    color: #666;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: auto;
    height: auto;
    margin: 0;
    padding: 0;
    transition: color 0.2s ease, transform 0.2s ease;
}

.pop-box .close:hover {
    background: #e8e8e8 !important;
    background-position: inherit !important;
}

.pop-box .close:hover::before {
    color: #1a1a1a !important;
    transform: translate(-50%, -50%) rotate(90deg);
}

/* Remove any ::after pseudo-element that might create unwanted shapes */
.pop-box .close::after {
    display: none !important;
    content: none !important;
}

/* Content Area */
.pop-mid {
    padding: 30px 40px !important;
    margin: 0 !important;
    text-align: center;
}

.pop-box h2.no-title + .i1 .pop-mid {
    padding-top: 30px !important;
}

.pop-mid h3 {
    margin: 0 !important;
    padding: 0 !important;
    font-size: 16px !important;
    font-weight: 500 !important;
    line-height: 1.5 !important;
    color: #4a4a4a !important;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 12px;
}

/* Error Icon - Modern */
.pop-box i.pop-error {
    width: 24px !important;
    height: 24px !important;
    background: none !important;
    position: static !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 50% !important;
    background: #fee !important;
    flex-shrink: 0;
}

.pop-box i.pop-error::before {
    content: '⚠';
    font-size: 16px;
    color: #e91e63;
    line-height: 1;
}

/* Success Icon */
.pop-box i.pop-ok {
    width: 24px !important;
    height: 24px !important;
    background: none !important;
    position: static !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 50% !important;
    background: #efe !important;
    flex-shrink: 0;
}

.pop-box i.pop-ok::before {
    content: '✓';
    font-size: 16px;
    color: #4caf50;
    line-height: 1;
    font-weight: bold;
}

/* Warning Icon */
.pop-box i.pop-warn {
    width: 24px !important;
    height: 24px !important;
    background: none !important;
    position: static !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 50% !important;
    background: #fff3cd !important;
    flex-shrink: 0;
}

.pop-box i.pop-warn::before {
    content: '⚠';
    font-size: 16px;
    color: #ff9800;
    line-height: 1;
}

/* Question Icon */
.pop-box i.pop-quest {
    width: 24px !important;
    height: 24px !important;
    background: none !important;
    position: static !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 50% !important;
    background: #e3f2fd !important;
    flex-shrink: 0;
}

.pop-box i.pop-quest::before {
    content: '?';
    font-size: 16px;
    color: #2196f3;
    line-height: 1;
    font-weight: bold;
}

/* Bottom Section */
.pop-bot {
    background: #f8f8f8 !important;
    border-top: 1px solid #e8e8e8 !important;
    padding: 20px 24px !important;
    margin: 0 !important;
    text-align: center;
}

.pop-c {
    display: flex !important;
    justify-content: center !important;
    gap: 12px;
    margin: 0 !important;
}

/* Modern Button */
.pop-c .m_button {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 12px 24px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    color: #ffffff !important;
    background: #e91e63 !important;
    border: none !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    text-decoration: none !important;
    transition: all 0.2s ease !important;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif !important;
    min-width: 100px;
    margin: 0 !important;
}

.pop-c .m_button:hover {
    background: #c2185b !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(233, 30, 99, 0.3);
    text-decoration: none !important;
    color: #ffffff !important;
}

.pop-c .m_button:active {
    transform: translateY(0);
    box-shadow: 0 2px 6px rgba(233, 30, 99, 0.2);
}

.pop-c .m_button span {
    display: inline !important;
    background: none !important;
    padding: 0 !important;
    margin: 0 !important;
    font: inherit !important;
    color: inherit !important;
}

/* Error Text Styling */
.pop-error-txt {
    color: #e91e63 !important;
    font-weight: 500 !important;
}

/* Modal Login Form Styles */
.modal-login-form {
    display: flex;
    flex-direction: column;
    gap: 24px;
    padding: 30px 40px;
    min-width: 400px;
}

/* Error message in login form */
.modal-login-error {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    background: #fff5f5;
    border: 2px solid #e91e63;
    border-radius: 8px;
    color: #c2185b;
    font-size: 14px;
    font-weight: 500;
    margin-bottom: 8px;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
}

.modal-login-error i.pop-error {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background-color: #e91e63;
    color: #ffffff;
    font-style: normal;
    font-weight: bold;
    font-size: 12px;
    flex-shrink: 0;
}

.modal-login-error i.pop-error::before {
    content: '⚠';
    font-size: 14px;
    line-height: 1;
}

/* Login Form Error (for main page form) */
.login-form-error {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    background: #fff5f5;
    border: 2px solid #e91e63;
    border-radius: 8px;
    color: #c2185b;
    font-size: 14px;
    font-weight: 500;
    margin-bottom: 12px;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
}

.login-form-error i.pop-error {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background-color: #e91e63;
    color: #ffffff;
    font-style: normal;
    font-weight: bold;
    font-size: 12px;
    flex-shrink: 0;
}

.login-form-error i.pop-error::before {
    content: '⚠';
    font-size: 14px;
    line-height: 1;
}

.modal-login-field {
    width: 100%;
    position: relative;
}

.modal-login-field-password {
    position: relative;
}

.modal-password-toggle {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    cursor: pointer;
    padding: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #666;
    transition: color 0.2s ease;
    z-index: 10;
}

.modal-password-toggle:hover {
    color: #333;
}

.modal-password-toggle svg {
    width: 20px;
    height: 20px;
    stroke: currentColor;
}

.modal-login-form input {
    width: 100%;
    padding: 16px 20px;
    font-size: 16px;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    box-sizing: border-box;
    transition: border-color 0.2s ease;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
}

.modal-login-field-password input {
    padding-right: 50px;
}

.modal-login-form input:focus {
    outline: none;
    border-color: #e91e63;
    box-shadow: 0 0 0 3px rgba(233, 30, 99, 0.1);
}

.modal-login-actions {
    width: 100%;
}

.modal-login-submit {
    width: 100%;
    background: #e91e63;
    color: #ffffff;
    padding: 16px 24px;
    font-size: 17px;
    font-weight: 600;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
}

.modal-login-submit:hover {
    background: #c2185b;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(233, 30, 99, 0.3);
}

.modal-login-submit:active {
    transform: translateY(0);
    box-shadow: 0 2px 6px rgba(233, 30, 99, 0.2);
}

.modal-login-submit:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
}

.modal-login-forgot {
    text-align: center;
    margin-top: 8px;
}

.modal-login-forgot a {
    color: #5a6c7d;
    text-decoration: none;
    font-size: 14px;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
}

.modal-login-forgot a:hover {
    color: #e91e63;
    text-decoration: underline;
}

/* Message Modal (mod-messenger) Styles */
/* Using high specificity selectors with ID to override old styles without !important */
#modal-window.mod-messenger {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 10000;
    margin: 0;
    background: #ffffff;
    border-radius: 16px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
    overflow: hidden;
    max-width: 600px;
    width: 522px;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    box-sizing: border-box;
}

#modal-window.mod-messenger .mes-head {
    background: #ffffff;
    border-bottom: 1px solid #e8e8e8;
    padding: 20px 24px;
    margin: 0;
    position: relative;
    border-radius: 16px 16px 0 0;
    display: flex;
    align-items: center;
    min-height: 60px;
    box-sizing: border-box;
    width: 100% !important;
    max-width: 100% !important;
}

#modal-window.mod-messenger .mes-head h2 {
    margin: 0;
    padding: 0 48px 0 0;
    background: none;
    border: none;
    height: auto;
    overflow: visible;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    font-size: 18px;
    font-weight: 600;
    line-height: 1.4;
    color: #1a1a1a;
    position: relative;
    width: 100%;
    box-sizing: border-box;
}

#modal-window.mod-messenger .mes-head h2 span {
    color: #1a1a1a;
    font-size: 18px;
    font-weight: 600;
    text-shadow: none;
    float: none;
    display: inline;
    flex-shrink: 0;
    padding-left: 4px;
}

#modal-window.mod-messenger .mes-head h2 em {
    color: #666;
    font-size: 15px;
    font-weight: 400;
    font-style: normal;
    text-shadow: none;
    float: none;
    display: inline;
    margin-left: 8px;
    flex-shrink: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

#modal-window.mod-messenger .mes-head .close {
    position: absolute;
    top: 50%;
    right: 16px;
    transform: translateY(-50%);
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: #f5f5f5;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    transition: background 0.2s ease;
    z-index: 100;
    margin: 0;
    padding: 0;
    text-indent: -9999px;
    font-size: 0;
    color: transparent;
    line-height: 1;
    overflow: visible;
    background-image: none;
    background-position: 0 0;
    box-sizing: border-box;
    flex-shrink: 0;
}

#modal-window.mod-messenger .mes-head .close::before {
    content: '×';
    font-size: 24px;
    font-weight: 300;
    line-height: 1;
    display: block;
    text-indent: 0;
    color: #666;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: auto;
    height: auto;
    margin: 0;
    padding: 0;
    transition: color 0.2s ease, transform 0.2s ease;
    pointer-events: none;
    text-align: center;
}

#modal-window.mod-messenger .mes-head .close::after {
    display: none;
    content: none;
}

#modal-window.mod-messenger .mes-head .close:hover {
    background: #e8e8e8;
    background-image: none;
    background-position: inherit;
}

#modal-window.mod-messenger .mes-head .close:hover::before {
    color: #1a1a1a;
    transform: translate(-50%, -50%) rotate(90deg);
}

#modal-window.mod-messenger .i1,
#modal-window.modal-content .mod-messenger .i1 {
    background: #ffffff;
    padding: 0 !important;
    border: none !important;
    outline: none;
    box-shadow: none;
    width: 100% !important;
    margin: 0 !important;
    box-sizing: border-box;
}

#modal-window.mod-messenger .i2 {
    background: #ffffff;
    border: none !important;
    padding: 20px 24px;
    box-sizing: border-box;
    width: 100% !important;
    max-width: 100% !important;
    overflow: hidden;
    margin: 0 !important;
}

#modal-window.mod-messenger .mes-head {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box;
    margin: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

#modal-window.mod-messenger .mes-first {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 24px;
    padding: 20px 0;
    padding-bottom: 24px;
    border-bottom: 1px solid #e8e8e8;
    background: transparent;
    border-radius: 0;
    background-image: none;
    overflow: hidden;
    width: 100%;
    box-sizing: border-box;
}

#modal-window.mod-messenger .mes-first .ava {
    float: none;
    width: auto;
    padding: 0;
    position: relative;
    flex-shrink: 0;
}

#modal-window.mod-messenger .mes-first .ava a {
    display: block;
    position: relative;
    text-decoration: none;
}

#modal-window.mod-messenger .mes-first .ava img {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    border: 3px solid #ffffff;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    object-fit: cover;
    display: block;
}

#modal-window.mod-messenger .mes-first .ava .vip-dash {
    position: absolute;
    bottom: -2px;
    right: -2px;
    background: linear-gradient(135deg, #ffd700, #ffed4e);
    color: #000;
    font-size: 10px;
    font-weight: 700;
    padding: 2px 6px;
    border-radius: 8px;
    border: 2px solid #ffffff;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

#modal-window.mod-messenger .mes-first-txt {
    float: none;
    width: auto;
    padding: 0;
    overflow: visible;
    flex: 1;
    min-width: 0;
}

#modal-window.mod-messenger .mes-first-txt .hd {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    border: none;
    padding: 0;
    margin: 0 0 12px 0;
    width: 100%;
    overflow: visible;
    min-height: 24px;
}

#modal-window.mod-messenger .mes-first-txt .hd a {
    float: none;
    margin: 0;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    text-decoration: none;
    color: #1a1a1a;
    font-size: 16px;
    font-weight: 600;
    transition: color 0.2s ease;
}

#modal-window.mod-messenger .mes-first-txt .hd a:hover {
    color: #e91e63;
}

#modal-window.mod-messenger .mes-first-txt .hd a i {
    font-size: 14px;
    color: #666;
}

#modal-window.mod-messenger .mes-first-txt .hd i.mes-online {
    float: none;
    width: 8px;
    height: 8px;
    margin: 0;
    background: #4caf50;
    border-radius: 50%;
    display: inline-block;
    box-shadow: 0 0 0 2px rgba(76, 175, 80, 0.2);
    background-image: none;
    flex-shrink: 0;
}

#modal-window.mod-messenger .mes-first-txt .hd span {
    float: none;
    color: #999;
    font-size: 13px;
    margin-left: auto;
    white-space: nowrap;
}

#modal-window.mod-messenger .mes-first-txt > *:not(.hd) {
    color: #4a4a4a;
    font-size: 14px;
    line-height: 1.6;
    margin: 0;
}

#modal-window.mod-messenger .mes-first-txt p {
    margin: 0 0 8px 0;
    word-wrap: break-word;
    overflow-wrap: break-word;
}

#modal-window.mod-messenger .mes-first-txt p:last-child {
    margin-bottom: 0;
}

#modal-window.mod-messenger .mes-first-txt img {
    max-width: 100%;
    height: auto;
    border-radius: 8px;
    margin: 8px 0;
    display: block;
}

#modal-window.mod-messenger .mes-first-txt a {
    color: #e91e63;
    text-decoration: none;
    transition: color 0.2s ease;
}

#modal-window.mod-messenger .mes-first-txt a:hover {
    color: #c2185b;
    text-decoration: underline;
}

#modal-window.mod-messenger #myMessage {
    margin-top: 16px;
    padding: 12px;
    background: #f0f7ff;
    border-left: 3px solid #e91e63;
    border-radius: 6px;
}

#modal-window.mod-messenger #myMessage b {
    display: block;
    margin-bottom: 8px;
    color: #1a1a1a;
    font-weight: 600;
    font-size: 13px;
}

#modal-window.mod-messenger #myMessage p {
    margin: 0;
    color: #4a4a4a;
    line-height: 1.6;
}

#modal-window.mod-messenger .mes-tools {
    padding: 0;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    overflow: hidden;
    height: auto;
    background: transparent;
}

/* General textarea styles - for textareas not in wrapper */
#modal-window.mod-messenger .mes-tools > textarea {
    width: 100%;
    max-width: 100%;
    padding: 12px 16px;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    font-size: 14px;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    resize: vertical;
    transition: border-color 0.2s ease;
    background: #ffffff;
    box-sizing: border-box;
    margin: 0 0 16px 0;
    display: block;
    height: auto;
    overflow: auto;
}

#modal-window.mod-messenger .mes-tools textarea:focus {
    outline: none;
    border-color: #e91e63;
    box-shadow: 0 0 0 3px rgba(233, 30, 99, 0.1);
}

#modal-window.mod-messenger .mes-tools textarea.disabled {
    background: #f5f5f5;
    border-color: #d0d0d0;
    color: #999;
}

#modal-window.mod-messenger .mes-tools .wrapper,
#modal-window.modal-content .mes-tools .wrapper {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    width: 100%;
    overflow: visible;
    margin: 0 0 20px 0;
    box-sizing: border-box;
}

/* Remove margin between send-gift-info and next wrapper */
#modal-window.mod-messenger .mes-tools .wrapper.send-gift-info,
#modal-window.modal-content .mes-tools .wrapper.send-gift-info {
    margin-bottom: 0;
}

/* Wrapper with textarea - add more bottom margin */
#modal-window.mod-messenger .mes-tools .wrapper:has(textarea),
#modal-window.mod-messenger .mes-tools .wrapper:has(#messageArea),
#modal-window.modal-content .mes-tools .wrapper:has(textarea),
#modal-window.modal-content .mes-tools .wrapper:has(#messageArea) {
    margin-bottom: 16px;
}

#modal-window.mod-messenger .mes-tools .wrapper:after,
#modal-window.modal-content .mes-tools .wrapper:after {
    display: none;
}

/* Image in wrapper - rounded corners, fixed size */
#modal-window.mod-messenger .mes-tools .wrapper .image,
#modal-window.modal-content .mes-tools .wrapper .image,
#modal-window.mod-messenger .mes-tools .wrapper img.image,
#modal-window.modal-content .mes-tools .wrapper img.image {
    width: 68px !important;
    height: 68px !important;
    border-radius: 12px;
    object-fit: cover;
    display: block;
    flex-shrink: 0;
    border: 2px solid #e0e0e0;
    box-sizing: border-box;
    float: none;
    margin: 0;
    padding: 0;
}

#modal-window.mod-messenger .mes-tools .wrapper a,
#modal-window.modal-content .mes-tools .wrapper a {
    display: block;
    flex-shrink: 0;
    float: none;
    text-decoration: none;
    border-radius: 12px;
    overflow: hidden;
}

/* Textarea in wrapper - same height as image, flex to fill space */
#modal-window.mod-messenger .mes-tools .wrapper textarea,
#modal-window.modal-content .mes-tools .wrapper textarea,
#modal-window.mod-messenger .mes-tools .wrapper #messageArea,
#modal-window.modal-content .mes-tools .wrapper #messageArea {
    flex: 1;
    min-width: 0;
    width: auto !important;
    height: 68px !important;
    min-height: 68px;
    max-height: 68px;
    padding: 12px 16px;
    border: 2px solid #e0e0e0;
    border-radius: 12px;
    font-size: 14px;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    resize: none;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    background: #ffffff;
    box-sizing: border-box;
    margin: 0;
    display: block;
    line-height: 1.5;
    color: #1a1a1a;
    float: none;
}

#modal-window.mod-messenger .mes-tools .wrapper textarea:focus,
#modal-window.modal-content .mes-tools .wrapper textarea:focus,
#modal-window.mod-messenger .mes-tools .wrapper #messageArea:focus,
#modal-window.modal-content .mes-tools .wrapper #messageArea:focus {
    outline: none;
    border-color: #e91e63;
    box-shadow: 0 0 0 3px rgba(233, 30, 99, 0.1);
}

#modal-window.mod-messenger .mes-tools .wrapper textarea:disabled,
#modal-window.modal-content .mes-tools .wrapper textarea:disabled,
#modal-window.mod-messenger .mes-tools .wrapper #messageArea:disabled,
#modal-window.modal-content .mes-tools .wrapper #messageArea:disabled {
    background: #f5f5f5;
    border-color: #d0d0d0;
    color: #999;
    cursor: not-allowed;
}

/* Second wrapper with buttons - Flexbox layout */
/* Target wrapper that contains .mes-buts (not the one with textarea) */
#modal-window.mod-messenger .mes-tools .wrapper:not(:has(textarea)):has(.mes-buts),
#modal-window.modal-content .mes-tools .wrapper:not(:has(textarea)):has(.mes-buts),
#modal-window.mod-messenger .mes-tools .wrapper:not(:has(#messageArea)):has(.mes-buts),
#modal-window.modal-content .mes-tools .wrapper:not(:has(#messageArea)):has(.mes-buts) {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
    flex-wrap: nowrap;
    width: 100%;
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

/* Fallback for browsers without :has() support - target by position */
#modal-window.mod-messenger .mes-tools .wrapper + .wrapper,
#modal-window.modal-content .mes-tools .wrapper + .wrapper {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
    flex-wrap: nowrap;
    width: 100%;
    box-sizing: border-box;
    margin: 0 0 0 0;
    padding: 0;
}

/* Alternative selector for browsers that don't support :has() */
#modal-window.mod-messenger .mes-tools .wrapper .anothergift,
#modal-window.modal-content .mes-tools .wrapper .anothergift {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    text-decoration: none;
    color: #2f7ab3;
    font-size: 14px;
    font-weight: 500;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    flex-shrink: 0;
    float: none;
    margin: 0;
    padding: 0;
    line-height: 1.5;
}

#modal-window.mod-messenger .mes-tools .wrapper .anothergift:hover,
#modal-window.modal-content .mes-tools .wrapper .anothergift:hover {
    color: #1a1a1a;
    text-decoration: underline;
}

#modal-window.mod-messenger .mes-tools .wrapper .anothergift i,
#modal-window.modal-content .mes-tools .wrapper .anothergift i,
#modal-window.mod-messenger .mes-tools .wrapper .anothergift .ico,
#modal-window.modal-content .mes-tools .wrapper .anothergift .ico {
    flex-shrink: 0;
    display: inline-block;
    width: 14px;
    height: 14px;
    margin: 0;
    padding: 0;
    vertical-align: middle;
    position: static;
    float: none;
}

/* Mes-buts container - flexbox, pushed to right */
#modal-window.mod-messenger .mes-tools .wrapper .mes-buts,
#modal-window.modal-content .mes-tools .wrapper .mes-buts {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
    float: none;
    margin: 0 0 0 auto;
    margin-left: auto;
    vertical-align: middle;
}

/* Lettercount - right aligned */
#modal-window.mod-messenger .mes-tools .wrapper .lettercount,
#modal-window.modal-content .mes-tools .wrapper .lettercount {
    display: inline-flex;
    align-items: center;
    flex-shrink: 0;
    float: none;
    margin: 0;
    padding: 0;
}

#modal-window.mod-messenger .mes-tools .wrapper .lettercount.right,
#modal-window.modal-content .mes-tools .wrapper .lettercount.right {
    margin-left: auto;
}

#modal-window.mod-messenger .mes-tools .lettercount {
    float: left;
    color: #999;
    padding: 4px 0 3px;
    line-height: 18px;
    display: inline-flex;
    align-items: center;
    vertical-align: middle;
}

#modal-window.mod-messenger .mes-tools .lettercount input {
    float: left;
    border: 1px solid #d9d9d9;
    font: 11px Tahoma, Arial, Helvetica, sans-serif;
    height: 14px;
    padding: 1px;
    width: 27px;
    text-align: center;
    color: #999;
    margin-right: 4px;
    vertical-align: middle;
}

#modal-window.mod-messenger .mes-tools .wrapper .lettercount.right input,
#modal-window.modal-content .mes-tools .wrapper .lettercount.right input {
    width: 50px !important;
    min-width: 50px;
    padding: 2px 4px;
    height: 18px;
    box-sizing: border-box;
    font-size: 12px;
    color: #666;
    background: #f7f7f7;
    border: 1px solid #d9d9d9;
    border-radius: 3px;
}

#modal-window.mod-messenger .mes-buts,
#modal-window.modal-content .mes-buts {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
    float: none;
    margin: 0;
    vertical-align: middle;
}

/* Shift mes-buts to the right in wrapper */
#modal-window.mod-messenger .mes-tools .wrapper:has(.mes-buts),
#modal-window.modal-content .mes-tools .wrapper:has(.mes-buts) {
    display: flex;
    justify-content: flex-end;
    align-items: center;
}

#modal-window.mod-messenger .mes-buts .smiles {
    float: left;
    width: 26px;
    height: 25px;
    margin-right: 4px;
    cursor: pointer;
    position: relative;
    z-index: 3;
    display: inline-block;
    vertical-align: middle;
}

#modal-window.mod-messenger .mes-buts .smiles span {
    float: left;
    width: 26px;
    height: 25px;
    background: url(../images/smile1.png) no-repeat 50% 50%;
    text-indent: -9999px;
    text-align: left;
    position: relative;
    z-index: 3;
    display: block;
}

#modal-window.mod-messenger .mes-buts .smiles span i {
    display: none;
    position: absolute;
    z-index: 2;
    left: 9px;
    top: -7px;
    width: 9px;
    height: 6px;
}

#modal-window.mod-messenger .mes-buts .m_button,
#modal-window.modal-content .mes-buts .m_button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #e91e63;
    color: #ffffff;
    padding: 12px 24px;
    border: none;
    border-radius: 8px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
    text-decoration: none;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    min-height: 42px;
    box-sizing: border-box;
    line-height: 1;
}

#modal-window.mod-messenger .mes-buts .m_button:hover,
#modal-window.modal-content .mes-buts .m_button:hover {
    background: #c2185b;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(233, 30, 99, 0.3);
    text-decoration: none;
    color: #ffffff;
}

#modal-window.mod-messenger .mes-buts .m_button:active,
#modal-window.modal-content .mes-buts .m_button:active {
    transform: translateY(0);
    box-shadow: 0 2px 6px rgba(233, 30, 99, 0.2);
}

#modal-window.mod-messenger .mes-buts .m_button span,
#modal-window.modal-content .mes-buts .m_button span {
    color: inherit;
    background: none;
    padding: 0;
    margin: 0;
    display: inline;
    font: inherit;
    line-height: 1;
}

/* Gift Modal Styles - Modern Design */
#modal-window.modal-content {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 10000;
    margin: 0;
    background: transparent;
    border-radius: 16px;
    overflow: visible;
}

#modal-window.modal-content .mod-gifts,
#modal-window.modal-content .mod-gifts-lite2 {
    background: #ffffff;
    border-radius: 16px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
    overflow: hidden;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    width: 100%;
    box-sizing: border-box;
}

#modal-window.modal-content .mod-gifts-lite2 {
    width: 611px;
    max-width: 95vw;
}

#modal-window.modal-content .mod-gifts .mes-head,
#modal-window.modal-content .mod-gifts-lite2 .mes-head {
    background: #ffffff;
    border-bottom: 1px solid #e8e8e8;
    padding: 20px 24px;
    margin: 0;
    position: relative;
    border-radius: 16px 16px 0 0;
    display: flex;
    align-items: center;
    min-height: 60px;
    box-sizing: border-box;
}

#modal-window.modal-content .mod-gifts .mes-head h2,
#modal-window.modal-content .mod-gifts-lite2 .mes-head h2 {
    margin: 0;
    padding: 0 48px 0 0;
    background: none;
    border: none;
    height: auto;
    overflow: visible;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    font-size: 18px;
    font-weight: 600;
    line-height: 1.4;
    color: #1a1a1a;
    position: relative;
    width: 100%;
    box-sizing: border-box;
}

#modal-window.modal-content .mod-gifts .mes-head h2 span,
#modal-window.modal-content .mod-gifts-lite2 .mes-head h2 span {
    color: #1a1a1a;
    font-size: 18px;
    font-weight: 600;
    text-shadow: none;
    float: none;
    display: inline;
}

#modal-window.modal-content .mod-gifts .mes-head .close,
#modal-window.modal-content .mod-gifts-lite2 .mes-head .close {
    position: absolute;
    top: 50%;
    right: 16px;
    transform: translateY(-50%);
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: #f5f5f5;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    transition: background 0.2s ease;
    z-index: 100;
    margin: 0;
    padding: 0;
    text-indent: -9999px;
    font-size: 0;
    color: transparent;
    line-height: 1;
    overflow: visible;
    background-image: none;
    background-position: 0 0;
    box-sizing: border-box;
    flex-shrink: 0;
}

#modal-window.modal-content .mod-gifts .mes-head .close::before,
#modal-window.modal-content .mod-gifts-lite2 .mes-head .close::before {
    content: '×';
    font-size: 24px;
    font-weight: 300;
    line-height: 1;
    display: block;
    text-indent: 0;
    color: #666;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: auto;
    height: auto;
    margin: 0;
    padding: 0;
    transition: color 0.2s ease, transform 0.2s ease;
    pointer-events: none;
    text-align: center;
}

#modal-window.modal-content .mod-gifts .mes-head .close::after,
#modal-window.modal-content .mod-gifts-lite2 .mes-head .close::after {
    display: none;
    content: none;
}

#modal-window.modal-content .mod-gifts .mes-head .close:hover,
#modal-window.modal-content .mod-gifts-lite2 .mes-head .close:hover {
    background: #e8e8e8;
    background-image: none;
    background-position: inherit;
}

#modal-window.modal-content .mod-gifts .mes-head .close:hover::before,
#modal-window.modal-content .mod-gifts-lite2 .mes-head .close:hover::before {
    color: #1a1a1a;
    transform: translate(-50%, -50%) rotate(90deg);
}

#modal-window.modal-content .mod-gifts .i1,
#modal-window.modal-content .mod-gifts-lite2 .i1 {
    background: #ffffff;
    padding: 0;
    border: none;
}

#modal-window.modal-content .mod-gifts .i2,
#modal-window.modal-content .mod-gifts-lite2 .i2 {
    background: #ffffff;
    border: none;
    padding: 20px 24px;
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    overflow: hidden;
}

#modal-window.modal-content .mod-gifts .i2.wrapper,
#modal-window.modal-content .mod-gifts-lite2 .i2.wrapper {
    overflow: visible;
}

#modal-window.modal-content #gift-window {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    background: none !important;
    background-image: none !important;
}

#modal-window.modal-content #gift-window .mes-main {
    box-sizing: border-box;
    overflow: visible;
    width: 100%;
    border-top: none;
    border: none;
    background: none;
    background-image: none;
}

#modal-window.modal-content #gift-window .favs.wrapper {
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    overflow: visible;
    padding: 0;
    margin: 0;
}

#modal-window.modal-content #gift-window .favs.wrapper:after {
    content: ".";
    display: block;
    width: 100%;
    overflow: hidden;
    height: 0;
    clear: both;
    visibility: hidden;
}

#modal-window.modal-content #gift-window .fav-photo.fav-gift {
    float: left;
    width: 108px;
    height: 108px;
    position: relative;
    margin: 12px 5px 0 0;
    box-sizing: border-box;
}

#modal-window.modal-content #gift-window .fav-photo.fav-gift:nth-child(5n) {
    margin-right: 0;
}

#modal-window.modal-content #gift-window .fav-photo.fav-gift > a {
    display: block;
    overflow: hidden;
    width: 100%;
    height: 104px;
}

#modal-window.modal-content #gift-window .fav-photo.fav-gift img {
    width: 100%;
    height: 104px;
    object-fit: cover;
    display: block;
    transition: none !important;
    transform: none !important;
    scale: 1 !important;
}

#modal-window.modal-content #gift-window .fav-photo.fav-gift:hover img {
    transform: none !important;
    scale: 1 !important;
    width: 100% !important;
    height: 104px !important;
}

#modal-window.modal-content #gift-window .fav-photo.fav-gift .overlay img,
#modal-window.modal-content #gift-window .fav-photo.fav-gift .overlay .double-pic img {
    transform: none !important;
    transition: none !important;
    scale: 1 !important;
    width: 152px !important;
    height: 108px !important;
    max-width: 152px !important;
    max-height: 108px !important;
    object-fit: contain !important;
}

#modal-window.modal-content #gift-window .fav-photo.fav-gift:hover .overlay img,
#modal-window.modal-content #gift-window .fav-photo.fav-gift:hover .overlay .double-pic img {
    transform: none !important;
    scale: 1 !important;
    width: 152px !important;
    height: 108px !important;
    max-width: 152px !important;
    max-height: 108px !important;
    object-fit: contain !important;
}

/* Add z-index and border for gift overlay in modal */
#modal-window.modal-content #gift-window .fav-photo.fav-gift:hover .overlay,
#modal-window.modal-content #gift-window .gift-name:hover .overlay {
    z-index: 100;
    border: 2px solid #cbd5e1;
    border-radius: 8px;
    background: #ffffff;
}

/* Gift Pagination and Credits Styles */
#modal-window.modal-content #gift-window .charge-btn {
    width: auto;
    min-width: 130px;
    margin: 0 0 0 40px;
    padding: 10px 20px;
    background: #e91e63;
    color: #ffffff;
    font-size: 14px;
    font-weight: 600;
    line-height: 1.4;
    text-align: center;
    cursor: pointer;
    float: right;
    border: none;
    border-radius: 8px;
    text-decoration: none;
    transition: all 0.2s ease;
    display: inline-block;
    box-sizing: border-box;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    text-shadow: none;
}

#modal-window.modal-content #gift-window .charge-btn:hover {
    background: #c2185b;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(233, 30, 99, 0.3);
    text-shadow: none;
    color: #ffffff;
}

#modal-window.modal-content #gift-window .charge-btn:active {
    transform: translateY(0);
    box-shadow: 0 2px 6px rgba(233, 30, 99, 0.2);
}


/* Gift Warning Styles */
#gift-window .mes-main-top {
    position: relative;
    width: 100%;
    box-sizing: border-box;
    overflow: hidden;
    padding: 12px 0;
    margin: 0;
    background: transparent;
    border-top: none;
    border: none;
}

#gift-window #giftWarning {
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    bottom: auto;
}

/* Hide giftWarning by default - show only on click when insufficient credits */
/* Use most specific selector to override .warning-error display: flex !important */
#modal-window.modal-content .warning-error#giftWarning,
#modal-window.modal-content #gift-window .warning-error#giftWarning,
#gift-window .warning-error#giftWarning,
.warning-error#giftWarning {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    height: 0 !important;
    overflow: hidden !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* Show giftWarning when it needs to be displayed (via JavaScript with inline style) */
/* Rounded error card with modern styling */
#modal-window.modal-content .warning-error#giftWarning[style*="flex"],
#modal-window.modal-content #gift-window .warning-error#giftWarning[style*="flex"],
#gift-window .warning-error#giftWarning[style*="flex"],
.warning-error#giftWarning[style*="flex"] {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    height: auto !important;
    overflow: visible !important;
    padding: 18px 24px 18px 24px !important;
    margin: 10px 0 16px 0 !important;
    border-radius: 12px !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1) !important;
    border: none !important;
    background: linear-gradient(135deg, #fff3e0, #ffe0b2) !important;
    border-left: 4px solid #ff9800 !important;
    color: #e65100 !important;
}
    width: 100%;
    max-width: 100%;
    margin: 0 0 12px 0;
    padding: 12px 16px;
    box-sizing: border-box;
    word-wrap: break-word;
    overflow-wrap: break-word;
    z-index: 10;
}

#gift-window #giftWarning a {
    white-space: nowrap;
}

/* Gift Setup Modal - Form Elements Styles */
/* Modern Input Fields - for textareas not in wrapper */
#modal-window.modal-content .mes-tools > textarea,
#modal-window.modal-content .mes-tools > #messageArea {
    width: 100% !important;
    max-width: 100%;
    padding: 12px 16px;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    font-size: 14px;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    resize: vertical;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    background: #ffffff;
    box-sizing: border-box;
    margin: 0 0 16px 0;
    display: block;
    height: auto;
    min-height: 100px;
    line-height: 1.5;
    color: #1a1a1a;
}

#modal-window.modal-content .mes-tools textarea:focus,
#modal-window.modal-content .mes-tools #messageArea:focus {
    outline: none;
    border-color: #e91e63;
    box-shadow: 0 0 0 3px rgba(233, 30, 99, 0.1);
}

#modal-window.modal-content .mes-tools textarea:disabled,
#modal-window.modal-content .mes-tools #messageArea:disabled {
    background: #f5f5f5;
    border-color: #d0d0d0;
    color: #999;
    cursor: not-allowed;
}

/* Modern Select/Dropdown Menu */
#modal-window.modal-content .mes-tools select {
    width: 100%;
    max-width: 100%;
    padding: 10px 40px 10px 16px;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    font-size: 14px;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    background: #ffffff;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 12px;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    cursor: pointer;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    box-sizing: border-box;
    color: #1a1a1a;
    line-height: 1.5;
    min-height: 42px;
}

/* Gift Type Select - Narrower width, inline */
#modal-window.modal-content .gift-type select,
#modal-window.modal-content #giftType,
#modal-window.mod-messenger .gift-type select,
#modal-window.mod-messenger #giftType {
    width: auto;
    min-width: 180px;
    max-width: 250px;
    padding: 10px 40px 10px 16px;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    font-size: 14px;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    background: #ffffff;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 12px;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    cursor: pointer;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    box-sizing: border-box;
    color: #1a1a1a;
    line-height: 1.5;
    min-height: 42px;
    flex-shrink: 0;
    float: none;
    display: inline-block;
}

#modal-window.modal-content .mes-tools select:focus {
    outline: none;
    border-color: #e91e63;
    box-shadow: 0 0 0 3px rgba(233, 30, 99, 0.1);
}

#modal-window.modal-content .mes-tools select:hover {
    border-color: #c0c0c0;
}

#modal-window.modal-content .gift-type select:focus,
#modal-window.modal-content #giftType:focus,
#modal-window.mod-messenger .gift-type select:focus,
#modal-window.mod-messenger #giftType:focus {
    outline: none;
    border-color: #e91e63;
    box-shadow: 0 0 0 3px rgba(233, 30, 99, 0.1);
}

#modal-window.modal-content .gift-type select:hover,
#modal-window.modal-content #giftType:hover,
#modal-window.mod-messenger .gift-type select:hover,
#modal-window.mod-messenger #giftType:hover {
    border-color: #c0c0c0;
}

#modal-window.modal-content .gift-type select option,
#modal-window.modal-content #giftType option,
#modal-window.modal-content .mes-tools select option,
#modal-window.mod-messenger .gift-type select option,
#modal-window.mod-messenger #giftType option {
    padding: 10px 16px;
    background: #ffffff;
    color: #1a1a1a;
    font-size: 14px;
}

/* Letter Count Input */
#modal-window.modal-content .mes-tools .lettercount input,
#modal-window.modal-content .lettercount input {
    width: 60px !important;
    padding: 8px 12px;
    border: 2px solid #e0e0e0;
    border-radius: 6px;
    font-size: 13px;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    background: #f5f5f5;
    color: #666;
    text-align: center;
    box-sizing: border-box;
    transition: border-color 0.2s ease;
}

#modal-window.modal-content .mes-tools .lettercount input:focus,
#modal-window.modal-content .lettercount input:focus {
    outline: none;
    border-color: #e91e63;
    background: #ffffff;
}

/* Send Gift Info Container - Flexbox layout */
#modal-window.modal-content .send-gift-info,
#modal-window.mod-messenger .send-gift-info {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: nowrap;
    width: 100%;
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    min-height: 42px;
}

/* Lettercount inside send-gift-info - positioned to the right */
#modal-window.modal-content .send-gift-info .lettercount,
#modal-window.mod-messenger .send-gift-info .lettercount {
    margin-left: auto;
    flex-shrink: 0;
}

/* Button wrapper - place right after send-gift-info with minimal spacing */
#modal-window.mod-messenger .mes-tools .wrapper.send-gift-info ~ .wrapper:has(.mes-buts),
#modal-window.modal-content .mes-tools .wrapper.send-gift-info ~ .wrapper:has(.mes-buts) {
    margin-top: 0;
    margin-bottom: 0;
}

/* Reduce spacing for textarea wrapper when it comes after button */
#modal-window.mod-messenger .mes-tools .wrapper:has(.mes-buts) ~ .wrapper:has(textarea),
#modal-window.mod-messenger .mes-tools .wrapper:has(.mes-buts) ~ .wrapper:has(#messageArea),
#modal-window.modal-content .mes-tools .wrapper:has(.mes-buts) ~ .wrapper:has(textarea),
#modal-window.modal-content .mes-tools .wrapper:has(.mes-buts) ~ .wrapper:has(#messageArea) {
    margin-top: 0;
}

/* Author Link */
#modal-window.modal-content .send-gift-info .author,
#modal-window.mod-messenger .send-gift-info .author {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    text-decoration: none;
    color: #2f7ab3;
    font-size: 14px;
    font-weight: 500;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    flex-shrink: 0;
    float: none;
    padding: 0;
    margin: 0;
    line-height: 1.5;
    height: auto;
    min-height: 42px;
    align-self: center;
    border-radius: 0;
}

#modal-window.modal-content .send-gift-info .author:hover,
#modal-window.mod-messenger .send-gift-info .author:hover {
    text-decoration: none;
}

#modal-window.modal-content .send-gift-info .author span,
#modal-window.mod-messenger .send-gift-info .author span {
    color: #2f7ab3;
    font-weight: 500;
    float: none;
    display: inline;
}

#modal-window.modal-content .send-gift-info .author:hover span,
#modal-window.mod-messenger .send-gift-info .author:hover span {
    color: #1a1a1a;
    text-decoration: underline;
}

#modal-window.modal-content .send-gift-info .author em,
#modal-window.mod-messenger .send-gift-info .author em {
    color: #ff9000;
    font-style: normal;
    font-size: 13px;
    float: none;
    display: inline;
}

#modal-window.modal-content .send-gift-info .author i,
#modal-window.mod-messenger .send-gift-info .author i {
    flex-shrink: 0;
    display: inline-block;
}

/* Gift Type Container - Inline with author, pushed to right */
#modal-window.modal-content .gift-type,
#modal-window.mod-messenger .gift-type {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
    width: auto;
    margin: 0 0 0 auto;
    float: none;
    box-sizing: border-box;
    margin-left: auto;
    height: auto;
    min-height: 42px;
    align-self: center;
}

/* Gift Type Label - Inline */
#modal-window.modal-content .gift-type label,
#modal-window.mod-messenger .gift-type label {
    display: inline-block;
    margin: 0;
    color: #4a4a4a;
    font-size: 14px;
    font-weight: 500;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    float: none;
    text-align: left;
    line-height: 1.5;
    white-space: nowrap;
    flex-shrink: 0;
}

/* Gift Type Help Icon (wtf) */
#modal-window.modal-content .gift-type .wtf,
#modal-window.mod-messenger .gift-type .wtf {
    display: inline-block;
    vertical-align: middle;
    margin-left: 4px;
    flex-shrink: 0;
    float: none;
    position: relative;
}

/* Ensure mod-messenger has rounded corners */
#modal-window.modal-content .mod-messenger {
    background: #ffffff;
    border-radius: 16px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
    overflow: hidden;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    width: 100% !important;
    box-sizing: border-box;
}

#modal-window.modal-content .mod-messenger .i1 {
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    box-sizing: border-box;
    background: transparent !important;
    border: none !important;
}

#modal-window.modal-content .mod-messenger .mes-head {
    background: #ffffff;
    border-bottom: 1px solid #e8e8e8;
    padding: 20px 24px;
    margin: 0;
    position: relative;
    border-radius: 16px 16px 0 0;
    display: flex;
    align-items: center;
    min-height: 60px;
    box-sizing: border-box;
    width: 100% !important;
    max-width: 100% !important;
}

#modal-window.modal-content .mod-messenger .mes-head h2 {
    margin: 0;
    padding: 0 48px 0 0;
    background: none;
    border: none;
    height: auto;
    overflow: visible;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    font-size: 18px;
    font-weight: 600;
    line-height: 1.4;
    color: #1a1a1a;
    position: relative;
    width: 100%;
    box-sizing: border-box;
}

#modal-window.modal-content .mod-messenger .mes-head h2 span {
    color: #1a1a1a;
    font-size: 18px;
    font-weight: 600;
    text-shadow: none;
    float: none;
    display: inline;
    padding-left: 4px;
}

#modal-window.modal-content .mod-messenger .mes-head .close {
    position: absolute;
    top: 50%;
    right: 16px;
    transform: translateY(-50%);
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: #f5f5f5;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    transition: background 0.2s ease;
    z-index: 100;
    margin: 0;
    padding: 0;
    text-indent: -9999px;
    font-size: 0;
    color: transparent;
    line-height: 1;
    overflow: visible;
    background-image: none;
    background-position: 0 0;
    box-sizing: border-box;
    flex-shrink: 0;
}

#modal-window.modal-content .mod-messenger .mes-head .close::before {
    content: '×';
    font-size: 24px;
    font-weight: 300;
    line-height: 1;
    display: block;
    text-indent: 0;
    color: #666;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: auto;
    height: auto;
    margin: 0;
    padding: 0;
    transition: color 0.2s ease, transform 0.2s ease;
    pointer-events: none;
    text-align: center;
}

#modal-window.modal-content .mod-messenger .mes-head .close::after {
    display: none;
    content: none;
}

#modal-window.modal-content .mod-messenger .mes-head .close:hover {
    background: #e8e8e8;
    background-image: none;
    background-position: inherit;
}

#modal-window.modal-content .mod-messenger .mes-head .close:hover::before {
    color: #1a1a1a;
    transform: translate(-50%, -50%) rotate(90deg);
}

#modal-window.modal-content .mod-messenger .i1 {
    background: #ffffff;
    padding: 0;
    border: none;
}

#modal-window.modal-content .mod-messenger .i2 {
    background: #ffffff;
    border: none !important;
    padding: 20px 24px;
    box-sizing: border-box;
    width: 100% !important;
    max-width: 100% !important;
    overflow: hidden;
    border-radius: 0 0 16px 16px;
    margin: 0 !important;
}

/* Send Money Block - Modern Styling */
#modal-window.mod-messenger .sendmoney,
#modal-window.modal-content .sendmoney {
    padding: 24px 0;
    text-align: left;
    background: #f8f9fa;
    border-radius: 12px;
    margin: 0 0 20px 0;
    padding: 24px;
    box-sizing: border-box;
}

#modal-window.mod-messenger .sendmoney p,
#modal-window.modal-content .sendmoney p {
    margin: 0 0 16px 0;
    font-size: 14px;
    line-height: 1.6;
    color: #4a4a4a;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
}

#modal-window.mod-messenger .sendmoney p:first-child,
#modal-window.modal-content .sendmoney p:first-child {
    margin-top: 0;
}

#modal-window.mod-messenger .sendmoney p:last-child,
#modal-window.modal-content .sendmoney p:last-child {
    margin-bottom: 0;
}

#modal-window.mod-messenger .sendmoney p strong.green,
#modal-window.modal-content .sendmoney p strong.green {
    color: #0e9600;
    font-weight: 700;
    font-size: 16px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

#modal-window.mod-messenger .sendmoney .ico,
#modal-window.modal-content .sendmoney .ico {
    display: inline-block;
    vertical-align: middle;
    margin: 0;
    width: 16px;
    height: 16px;
}

/* VIP icon larger size in sendmoney */
#modal-window.mod-messenger .sendmoney .ico.i-vip,
#modal-window.modal-content .sendmoney .ico.i-vip {
    width: 36px;
    height: 36px;
}

/* Credits Select - Modern Styling */
#modal-window.mod-messenger .sendmoney select,
#modal-window.modal-content .sendmoney select,
#modal-window.mod-messenger #selсredits,
#modal-window.modal-content #selсredits {
    width: 100%;
    max-width: 250px;
    padding: 12px 40px 12px 16px;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    font-size: 15px;
    font-weight: 600;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    background: #ffffff;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%230e9600' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 12px;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    cursor: pointer;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    box-sizing: border-box;
    color: #0e9600;
    line-height: 1.5;
    min-height: 48px;
    margin: 12px 8px 12px 0;
    vertical-align: middle;
    display: inline-block;
}

#modal-window.mod-messenger .sendmoney select:focus,
#modal-window.modal-content .sendmoney select:focus,
#modal-window.mod-messenger #selсredits:focus,
#modal-window.modal-content #selсredits:focus {
    outline: none;
    border-color: #0e9600;
    box-shadow: 0 0 0 3px rgba(14, 150, 0, 0.1);
}

#modal-window.mod-messenger .sendmoney select:hover,
#modal-window.modal-content .sendmoney select:hover,
#modal-window.mod-messenger #selсredits:hover,
#modal-window.modal-content #selсredits:hover {
    border-color: #0e9600;
}

#modal-window.mod-messenger .sendmoney select option,
#modal-window.modal-content .sendmoney select option,
#modal-window.mod-messenger #selсredits option,
#modal-window.modal-content #selсredits option {
    padding: 10px 16px;
    background: #ffffff;
    color: #1a1a1a;
    font-size: 15px;
    font-weight: 600;
}

/* Credits text after select */
#modal-window.mod-messenger .sendmoney select + *,
#modal-window.modal-content .sendmoney select + * {
    display: inline-block;
    font-size: 14px;
    color: #666;
    margin-left: 4px;
    vertical-align: middle;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
}

/* Mes-spr separator - Modern */
#modal-window.mod-messenger .mes-spr,
#modal-window.modal-content .mes-spr {
    border-bottom: 1px solid #e8e8e8;
    height: 1px;
    overflow: hidden;
    background: transparent;
    margin: 20px 0;
    border-radius: 0;
}

/* Gift Title - Bold and prominent */
#modal-window.modal-content .mes-gift .gift-title,
#modal-window.mod-messenger .mes-gift .gift-title {
    text-align: center;
    font-weight: 700;
    font-size: 18px;
    line-height: 1.4;
    color: #1a1a1a;
    padding: 12px 0 16px 0;
    margin: 0;
    background: none !important;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    letter-spacing: -0.3px;
    text-transform: none;
}

/* Responsive */
@media (max-width: 568px) {
    #modal-window {
        width: 95%;
        max-width: none;
    }
    
    #modal-window.mod-messenger {
        width: 95%;
        max-width: none;
    }
    
    .pop-box h2 {
        padding: 16px 20px;
    }
    
    #modal-window.mod-messenger .mes-head {
        padding: 16px 20px;
    }
    
    #modal-window.mod-messenger .i2 {
        padding: 16px 20px;
    }
    
    .pop-mid {
        padding: 20px;
    }
    
    .pop-bot {
        padding: 16px 20px;
    }
    
    .pop-c .m_button {
        padding: 10px 20px;
        font-size: 14px;
    }
    
    #gift-window #giftWarning {
        padding: 10px 12px;
        font-size: 13px;
    }
}

