body {
    margin: 0;
    font: 14px/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    overflow-x: hidden;
    background-color: #fafafa;
    -webkit-font-smoothing: antialiased;
    color: #262626;
}
strong {
    font-weight: 700;
}
code, kbd, pre, samp {
    font-family: Menlo,Monaco,Consolas,"Courier New",monospace;
}
code {
    padding: 2px 4px;
    font-size: 90%;
    color: #c7254e;
    background-color: #f9f2f4;
    border-radius: 4px;
}
pre {
    display: block;
    margin: 0;
    line-height: 1.42857143;
    word-break: break-all;
    word-wrap: break-word;
    color: #333;
    background-color: #f5f5f5;
    border-radius: 8px;
    overflow: auto;
    padding: 8px;
    border: 1px solid #eee;
    max-height: none;
    font-size: inherit;
}
.clearfix:after {
    content: " ";
    visibility: hidden;
    display: block;
    height: 0;
    clear: both;
}
.pull_left {
    float: left;
}
.pull_right {
    float: right;
}
.page_wrap {
    background-color: transparent;
    color: #262626;
}
.page_wrap a {
    color: #0095f6;
    text-decoration: none;
}
.page_wrap a:hover {
    text-decoration: none;
    color: #00376b;
}
.page_header {
    position: fixed;
    z-index: 10;
    background-color: #ffffff;
    width: 100%;
    border-bottom: 1px solid #dbdbdb;
}
.page_header .content {
    max-width: 480px;
    width: 100%;
    box-sizing: border-box;
    margin: 0 auto;
    border-radius: 0 !important;
}
.page_header a.content {
    background-repeat: no-repeat;
    background-position: 24px 21px;
    background-size: 24px 24px;
}
.bold {
    color: #262626;
    font-weight: 600;
}
.details {
    color: #8e8e8e;
}
.page_header .content .text {
    padding: 18px 16px;
    font-size: 16px;
    font-weight: 600;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    text-align: center;
    font-style: italic;
    letter-spacing: -0.5px;
}
.page_header a.content .text {
    padding: 18px 16px 18px 52px;
    text-align: left;
}
.page_body {
    padding-top: 80px;
    max-width: 480px;
    width: 100%;
    box-sizing: border-box;
    margin: 0 auto;
}
.page_about {
    padding: 24px 24px;
}
.with_divider {
    border-top: 1px solid #e3e6e8;
}
.userpic_link {
    display: block;
    text-decoration: none;
}
.userpic_link:hover {
    text-decoration: none;
}
.userpic {
    display: block;
    border-radius: 50%;
    overflow: hidden;
}
.story {
    display: block;
    border-radius: 4px;
    overflow: hidden;
}
.userpic .initials {
    display: block;
    color: #fff;
    text-align: center;
    text-transform: uppercase;
    user-select: none;
}
.color_red,
.userpic1,
.media_call .fill,
.media_file .fill,
.media_live_location .fill {
    background-color: #ff5555;
}
.color_green,
.userpic2,
.media_call.success .fill,
.media_photo .fill {
    background-color: #64bf47;
}
.color_yellow,
.userpic3,
.media_venue .fill {
    background-color: #ffab00;
}
.color_blue,
.userpic4,
.media_audio_file .fill,
.media_voice_message .fill {
    background-color: #4f9cd9;
}
.color_purple,
.userpic5,
.media_game .fill {
    background-color: #9884e8;
}
.color_pink,
.userpic6,
.media_invoice .fill {
    background-color: #e671a5;
}
.color_sea,
.userpic7,
.media_location .fill,
.media_video .fill {
    background-color: #47bcd1;
}
.color_orange,
.userpic8,
.media_contact .fill {
    background-color: #ff8c44;
}
.personal_info {
    padding: 24px;
}
.personal_info .userpic .initials {
    font-size: 30px;
}
.personal_info .rows {
    float: left;
    padding-right: 24px;
}
.personal_info .names {
    width: 164px;
}
.personal_info .info {
    width: 124px;
}
.personal_info .bio {
    width: 400px;
}
.personal_info .row {
    padding-bottom: 16px;
}
a.block_link {
    display: block;
    text-decoration: none !important;
    border-radius: 4px;
}
a.block_link:hover {
    text-decoration: none !important;
    background-color: #f5f7f8;
}
a.expanded {
    padding: 2px 8px;
    margin: -2px -8px;
}
.sections {
    padding: 11px 0;
}
.section {
    height: 48px;
    background-position: 24px 12px;
    background-repeat: no-repeat;
    background-size: 24px 24px;
}
.section .counter {
    float: right;
    padding: 14px 24px 0;
    font-size: 15px;
}
.section .label {
    padding: 15px 0 0 82px;
    font-size: 15px;
}
.list_page .page_about {
    padding: 16px 24px 0;
    font-size: 11px;
}
.list_page .entry_list {
    padding: 16px 0;
}
.list_page .entry {
    padding: 10px 16px;
}
.list_page .entry .userpic .initials {
    font-size: 18px;
}
.list_page .entry .body {
    margin-left: 66px;
}
.list_page .entry .name {
    padding: 4px 0 2px;
    font-size: 14px;
}
.list_page .entry .subname {
    padding-top: 4px;
}
.list_page .entry .details_entry {
    padding-top: 4px;
}
.list_page .entry .info {
    font-size: 11px;
    padding-top: 5px;
}
.history {
    padding: 0;
}
.message {
    margin: 0 0 8px 0;
    transition: background-color 0.3s ease;
}
div.selected {
    background-color: #fafafa;
    transition: background-color 0.3s ease;
}
.service {
    padding: 10px 24px;
}
.service .body {
    text-align: center;
}
.service .userpic_wrap {
    padding-top: 10px;
}
.service .userpic {
    margin: 0 auto;
}
.service .userpic .initials {
    font-size: 24px;
}
.message .userpic .initials {
    font-size: 16px;
}
.default {
    padding: 0;
    background-color: #ffffff;
    border-radius: 0;
    box-shadow: none;
    border: none;
    border-bottom: 1px solid #efefef;
}
.default.joined {
    margin-top: 0;
}
/* IG-style post header row */
.default .from_name {
    color: #262626;
    font-weight: 600;
    font-size: 14px;
    display: flex;
    align-items: center;
    padding: 12px 16px;
}
.default .from_name::after {
    content: '';
    display: inline-block;
    width: 16px;
    height: 16px;
    margin-left: 5px;
    background-color: #0095f6;
    border-radius: 50%;
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="white"><path d="M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z"/></svg>');
    background-size: 11px;
    background-repeat: no-repeat;
    background-position: center;
    flex-shrink: 0;
}
.default .from_name .details {
    font-weight: 400;
    color: #8e8e8e;
    margin-left: 4px;
    font-size: 12px;
}
.default .body {
    margin-left: 0;
    padding: 0;
}
.default .text {
    word-wrap: break-word;
    line-height: 1.6;
    unicode-bidi: plaintext;
    text-align: start;
    padding: 8px 16px 12px 16px;
    font-size: 14px;
    color: #262626;
}
.default .reply_to,
.default .media_wrap {
    padding-bottom: 0;
}
.default .media {
    margin: 0;
    padding: 0;
}
.default .media .fill,
.default .media .thumb {
    width: 44px;
    height: 44px;
    border-radius: 50%;
}
.default .media .fill {
    background-repeat: no-repeat;
    background-position: 12px 12px;
    background-size: 22px 22px;
}
.default .media .title,
.default .media_poll .question {
    padding-top: 4px;
    font-size: 14px;
    font-weight: 600;
}
.default .media .description {
    color: #262626;
    padding-top: 2px;
    font-size: 13px;
}
.default .media .status {
    padding-top: 4px;
    font-size: 12px;
    color: #8e8e8e;
}
.default .video_file_wrap,
.default .animated_wrap {
    position: relative;
    width: 100%;
}
.default .video_file,
.default .animated,
.default .photo,
.default .sticker {
    display: block;
    width: 100%;
    max-width: 100%;
    height: auto !important;
    border-radius: 0;
    box-shadow: none;
}
.photo_wrap,
.video_file_wrap,
.animated_wrap {
    max-width: 100%;
}
.video_duration {
    background: rgba(0, 0, 0, .4);
    padding: 0px 5px;
    position: absolute;
    z-index: 2;
    border-radius: 2px;
    right: 3px;
    bottom: 3px;
    color: #ffffff;
    font-size: 11px;
}
.video_play_bg {
    background: rgba(0, 0, 0, .4);
    width: 40px;
    height: 40px;
    line-height: 0;
    position: absolute;
    z-index: 2;
    border-radius: 50%;
    overflow: hidden;
    margin: -20px auto 0 -20px;
    top: 50%;
    left: 50%;
    pointer-events: none;
}
.video_play {
    position: absolute;
    display: inline-block;
    top: 50%;
    left: 50%;
    margin-left: -5px;
    margin-top: -9px;
    z-index: 1;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 9px 0 9px 14px;
    border-color: transparent transparent transparent #fff;
}
.gif_play {
    font-weight: 700;
    color: #FFF;
    display: block;
    line-height: 40px;
    font-size: 13px;
    text-align: center;
}
.pagination {
    text-align: center;
    padding: 20px;
    font-size: 16px;
}

.toast_container {
    position: fixed;
    left: 50%;
    top: 50%;
    opacity: 0;
    transition: opacity 3.0s ease;
}
.toast_body {
    margin: 0 -50%;
    float: left;
    border-radius: 15px;
    padding: 10px 20px;
    background: rgba(0, 0, 0, 0.7);
    color: #ffffff;
}
div.toast_shown {
    opacity: 1;
    transition: opacity 0.4s ease;
}

.section.calls {
    background-image: url(../images/section_calls.png);
}
.section.chats {
    background-image: url(../images/section_chats.png);
}
.section.contacts {
    background-image: url(../images/section_contacts.png);
}
.section.frequent {
    background-image: url(../images/section_frequent.png);
}
.section.photos {
    background-image: url(../images/section_photos.png);
}
.section.sessions {
    background-image: url(../images/section_sessions.png);
}
.section.stories {
    background-image: url(../images/section_stories.png);
}
.section.music {
    background-image: url(../images/section_music.png);
}
.section.web {
    background-image: url(../images/section_web.png);
}
.section.other {
    background-image: url(../images/section_other.png)
}
.page_header a.content {
    background-image: url(../images/back.png);
}
.media_call .fill {
    background-image: url(../images/media_call.png)
}
.media_contact .fill {
    background-image: url(../images/media_contact.png)
}
.media_file .fill {
    background-image: url(../images/media_file.png)
}
.media_game .fill {
    background-image: url(../images/media_game.png)
}
.media_live_location .fill,
.media_location .fill,
.media_venue .fill {
    background-image: url(../images/media_location.png)
}
.media_audio_file .fill {
    background-image: url(../images/media_music.png)
}
.media_invoice .fill {
    background-image: url(../images/media_shop.png)
}
.media_voice_message .fill {
    background-image: url(../images/media_voice.png)
}
.media_photo .fill {
    background-image: url(../images/media_photo.png)
}
.media_video .fill {
    background-image: url(../images/media_video.png)
}
.audio_icon {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background-color: #4f9cd9;
    background-image: url(../images/media_music.png);
    background-repeat: no-repeat;
    background-position: 12px 12px;
    background-size: 24px 24px;
}

@media only screen and (min--moz-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2/1), only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min-device-pixel-ratio: 2) {
.section.calls {
    background-image: url(../images/section_calls@2x.png);
}
.section.chats {
    background-image: url(../images/section_chats@2x.png);
}
.section.contacts {
    background-image: url(../images/section_contacts@2x.png);
}
.section.frequent {
    background-image: url(../images/section_frequent@2x.png);
}
.section.photos {
    background-image: url(../images/section_photos@2x.png);
}
.section.sessions {
    background-image: url(../images/section_sessions@2x.png);
}
.section.stories {
    background-image: url(../images/section_stories@2x.png);
}
.section.music {
    background-image: url(../images/section_music@2x.png);
}
.section.web {
    background-image: url(../images/section_web@2x.png);
}
.section.other {
    background-image: url(../images/section_other@2x.png);
}
.page_header a.content {
    background-image: url(../images/back@2x.png);
}
.media_call .fill {
    background-image: url(../images/media_call@2x.png)
}
.media_contact .fill {
    background-image: url(../images/media_contact@2x.png)
}
.media_file .fill {
    background-image: url(../images/media_file@2x.png)
}
.media_game .fill {
    background-image: url(../images/media_game@2x.png)
}
.media_live_location .fill,
.media_location .fill,
.media_venue .fill {
    background-image: url(../images/media_location@2x.png)
}
.media_audio_file .fill {
    background-image: url(../images/media_music@2x.png)
}
.media_invoice .fill {
    background-image: url(../images/media_shop@2x.png)
}
.media_voice_message .fill {
    background-image: url(../images/media_voice@2x.png)
}
.media_photo .fill {
    background-image: url(../images/media_photo@2x.png)
}
.media_video .fill {
    background-image: url(../images/media_video@2x.png)
}
.audio_icon {
    background-image: url(../images/media_music@2x.png);
}
}

.spoiler {
    background: #e8e8e8;
}
.spoiler.hidden {
    background: #a9a9a9;
    cursor: pointer;
    border-radius: 3px;
}
.spoiler.hidden span {
    opacity: 0;
    user-select: none;
}

.bot_buttons_table {
    border-spacing: 0px 2px;
    width: 100%;
}
.bot_button {
    border-radius: 8px;
    text-align: center;
    vertical-align: middle;
    background-color: #168acd40;
}
.bot_button_row {
    display: table;
    table-layout: fixed;
    padding: 0px;
    width:100%;
}
.bot_button_row div {
    display: table-cell;
}
.bot_button_column_separator {
    width: 2px
}

.reactions {
    margin: 0;
    padding: 4px 16px 12px 16px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

.reactions .reaction {
    display: inline-flex;
    height: 32px;
    border-radius: 9999px;
    background-color: transparent;
    color: #262626;
    font-weight: 600;
    margin-bottom: 0;
    padding: 0 12px 0 8px;
    align-items: center;
    border: 1px solid #dbdbdb;
    transition: background-color 0.15s ease;
    cursor: pointer;
    font-size: 13px;
}

.reactions .reaction:hover {
    background-color: #fafafa;
    transform: none;
}

.reactions .reaction.active {
    background-color: #fef3f3;
    color: #ed4956;
    border-color: #ed4956;
}

.reactions .reaction.paid {
    background-color: transparent;
    color: #8e8e8e;
    border-color: #dbdbdb;
}

.reactions .reaction.active.paid {
    background-color: #fff3cd;
    color: #8a6914;
    border-color: #ffc107;
}

.reactions .reaction .emoji {
    line-height: 32px;
    margin: 0 4px 0 0;
    font-size: 16px;
}

.reactions .reaction .userpic:not(:first-child) {
    margin-left: -8px;
}

.reactions .reaction .userpic {
    display: inline-block;
}

.reactions .reaction .userpic .initials {
    font-size: 8px;
}

.reactions .reaction .count {
    margin-right: 0;
    line-height: 32px;
    font-size: 12px;
    font-weight: 600;
}

@media (prefers-color-scheme: dark) {
html, body {
    background-color: #000000;
    margin: 0;
    padding: 0;
}
.page_wrap {
    background-color: transparent;
    color: #f5f5f5;
    min-height: 100vh;
}
.page_wrap a {
    color: #0095f6;
}
.page_header {
    background-color: #000000;
    border-bottom: 1px solid #262626;
}
.bold {
    color: #f5f5f5;
    font-weight: 600;
}
.details {
    color: #a8a8a8;
}
.page_body {
    background-color: transparent;
}
code {
    color: #ff7b72;
    background-color: #21262d;
}
pre {
    color: #c9d1d9;
    background-color: #161b22;
    border: 1px solid #30363d;
}
.with_divider {
    border-top: 1px solid #30363d;
}
a.block_link:hover {
    background-color: #21262d;
}
.list_page .entry {
    color: #c9d1d9;
}
.message {
    color: #c9d1d9;
}
div.selected {
    background-color: #1a1a1a;
}
.default {
    background-color: #000000;
    box-shadow: none;
    border-bottom: 1px solid #262626;
    border-top: none;
    border-left: none;
    border-right: none;
}
.default .from_name {
    color: #f5f5f5;
}
.default .text {
    color: #f5f5f5;
}
.default .media .description {
    color: #c9d1d9;
}
msgInBg,
.historyComposeAreaBg {
    background-color: #161b22;
}
msgOutBg {
    background-color: #21262d;
}
msgInBgSelected {
    background-color: #30363d;
}
msgOutBgSelected {
    background-color: #30363d;
}
.spoiler {
    background: #30363d;
}
.spoiler.hidden {
    background: #58a6ff;
}
.bot_button {
    background-color: rgba(88, 166, 255, 0.2);
}
.reactions .reaction {
    background-color: transparent;
    color: #f5f5f5;
    border-color: #363636;
}
.reactions .reaction:hover {
    background-color: #1a1a1a;
}
.reactions .reaction.active {
    background-color: transparent;
    color: #ed4956;
    border-color: #ed4956;
}
.reactions .reaction.paid {
    background-color: #3e2e1e;
    color: #e3b341;
    border-color: rgba(227, 179, 65, 0.2);
}
.reactions .reaction.active.paid {
    background-color: #e3b341;
    color: #221e16;
}
}

/* Lightbox Styles */
#lightbox_overlay {
    display: none;
    position: fixed;
    z-index: 9999;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.9);
    align-items: center;
    justify-content: center;
}

#lightbox_overlay.active {
    display: flex;
}

#lightbox_content_container {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

#lightbox_content {
    max-width: 95%;
    max-height: 95%;
    object-fit: contain;
    border-radius: 8px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.5);
}

#lightbox_close {
    position: absolute;
    top: 20px;
    left: 20px;
    color: white;
    font-size: 35px;
    font-weight: bold;
    cursor: pointer;
    user-select: none;
    background: rgba(255, 255, 255, 0.2);
    width: 50px;
    height: 50px;
    border-radius: 50%;
    text-align: center;
    line-height: 45px;
    z-index: 10000;
    backdrop-filter: blur(5px);
}
#lightbox_close:hover {
    background: rgba(255, 255, 255, 0.4);
}

/* Custom Profile Picture for Diana Rider */
.userpic5 {
    background-image: url('../photos/photo_244@05-04-2026_19-17-39_thumb.jpg') !important;
    background-size: cover !important;
    background-position: center !important;
    background-color: transparent !important;
}
.userpic5 .initials {
    display: none !important;
}

/* Hide date and time */
.pull_right.date.details,
div[id^="message-"] {
    display: none !important;
}

/* Exclusive Content Button (Instagram Follow-style) */
.exclusive-btn-wrap {
    clear: both;
    margin-top: 0;
    margin-bottom: 0;
    display: flex;
    justify-content: center;
    padding: 12px 16px;
    border-top: 1px solid #efefef;
}
.exclusive-btn {
    display: block;
    width: 100%;
    text-align: center;
    background-color: #0095f6;
    color: #ffffff !important;
    text-decoration: none !important;
    padding: 7px 16px;
    border-radius: 8px;
    font-weight: 600;
    font-size: 14px;
    letter-spacing: 0;
    box-shadow: none;
    transition: background-color 0.2s ease;
}
.exclusive-btn:hover {
    transform: none;
    background-color: #1877f2;
    box-shadow: none;
}

/* Photo sizing – make images behave like videos */
.photo_wrap img {
    width: 100% !important;
    height: auto !important;
    display: block;
    border-radius: 0 !important;
    box-shadow: none !important;
}

.exclusive-btn-wrap {
    clear: both;
    margin-top: 0;
    margin-bottom: 0;
    display: flex;
    justify-content: center;
    padding: 12px 16px;
    border-top: 1px solid #efefef;
}
.exclusive-btn {
    display: block;
    width: 100%;
    text-align: center;
    background-color: #0095f6;
    color: #ffffff !important;
    text-decoration: none !important;
    padding: 7px 16px;
    border-radius: 8px;
    font-weight: 600;
    font-size: 14px;
    letter-spacing: 0;
    box-shadow: none;
    transition: background-color 0.2s ease;
}
.exclusive-btn:hover {
    transform: none;
    background-color: #1877f2;
    box-shadow: none;
}

@media (prefers-color-scheme: dark) {
    .exclusive-btn-wrap {
        border-top-color: #262626;
    }
    .exclusive-btn {
        background-color: #0095f6;
    }
    .exclusive-btn:hover {
        background-color: #1877f2;
    }
}
/* Responsive adjustments */
@media (max-width: 600px) {
    /* Mobile view */
    .page_wrap {
        max-width: 100%;
        padding: 0 8px;
    }
    .page_header .content .text {
        font-size: 15px;
    }
    .default .from_name {
        font-size: 13px;
    }
    .default .text {
        font-size: 13px;
    }
    .exclusive-btn {
        font-size: 13px;
        padding: 6px 12px;
    }
}
/* Desktop view */
@media (min-width: 601px) {
    .page_wrap {
        max-width: 480px;
        margin: 0 auto;
    }
    .page_header .content .text { font-size: 16px; }
    .default .from_name { font-size: 14px; }
    .default .text      { font-size: 14px; }
    .exclusive-btn {
        font-size: 14px;
        padding: 7px 16px;
    }
}
