@media (max-width: 768px) {
    *, *::before, *::after { box-sizing: border-box; }
    html, body { width: 100%; max-width: 100%; overflow-x: hidden; }
    body { padding-bottom: 64px; -webkit-text-size-adjust: 100%; }
    img, iframe, video, table { max-width: 100%; }

    nav[role="navigation"] {
        display: grid !important;
        grid-template-columns: 46px minmax(0, 1fr) 46px;
        align-items: center;
        gap: 8px;
        width: 100%;
        min-height: 62px;
        padding: 8px 10px !important;
        background: #181818;
    }
    nav .logo { display: flex; align-items: center; justify-content: center; min-width: 0; }
    nav .logo img { width: 42px; height: auto; }
    nav form.search {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) 46px;
        width: 100% !important;
        min-width: 0 !important;
        max-width: none !important;
        margin: 0 !important;
        float: none !important;
    }
    nav form.search input[type="search"] {
        width: 100% !important;
        min-width: 0 !important;
        height: 46px;
        font-size: 16px;
    }
    nav .btn-square { width: 46px; height: 46px; min-width: 46px; padding: 0; }
    nav .collapse.mobile-open,
    nav .collapse.open {
        position: fixed !important;
        top: 62px !important;
        left: 0 !important;
        right: 0 !important;
        max-height: calc(100vh - 126px) !important;
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch;
    }
    nav .menu.right,
    nav .menu.left { width: 100% !important; }

    #content, .container, .index-container, #bigcontainer, #thumbnail-container,
    .local-comments, .thumbnail-load-actions {
        width: min(100% - 20px, 1120px) !important;
        max-width: calc(100vw - 20px) !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }
    .content-unit, .content-unit-device { max-width: 100%; overflow: hidden; }

    .index-container {
        padding: 14px 0 !important;
        text-align: center;
    }
    .index-container h1,
    .index-container h2,
    .index-container h3 {
        font-size: 24px !important;
        line-height: 1.2 !important;
        margin: 14px 0 !important;
    }
    .gallery {
        display: inline-block !important;
        width: calc(50% - 10px) !important;
        max-width: 190px;
        margin: 5px !important;
        vertical-align: top;
    }
    .gallery .cover,
    a.cover {
        display: block;
        width: 100% !important;
        min-width: 0 !important;
        overflow: hidden;
        border-radius: 6px;
    }
    .gallery .caption,
    .cover .caption {
        font-size: 13px !important;
        line-height: 1.18 !important;
        padding: 7px 6px !important;
        max-height: 48px;
        overflow: hidden;
    }

    #bigcontainer {
        display: block !important;
        padding: 16px 10px !important;
        text-align: left !important;
    }
    #cover, #info-block, #info {
        display: block !important;
        float: none !important;
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 auto !important;
        text-align: left !important;
    }
    #cover { text-align: center !important; margin-bottom: 18px !important; }
    #cover img {
        width: auto !important;
        max-width: min(100%, 360px) !important;
        height: auto !important;
        margin: 0 auto;
        border-radius: 6px;
    }
    #info h1 {
        font-size: 22px !important;
        line-height: 1.22 !important;
        margin: 8px 0 10px !important;
        word-break: break-word;
    }
    #info h2 {
        font-size: 16px !important;
        line-height: 1.35 !important;
        margin: 0 0 12px !important;
        word-break: break-word;
    }
    #gallery_id { text-align: center; font-size: 18px !important; }
    #tags .tag-container {
        display: block !important;
        margin: 9px 0 !important;
        line-height: 1.7;
    }
    #tags .tags {
        display: flex !important;
        flex-wrap: wrap;
        gap: 6px;
        margin-top: 4px;
    }
    #tags .tag {
        margin: 0 !important;
        max-width: 100%;
        white-space: normal !important;
        overflow-wrap: anywhere;
    }
    .reading-actions,
    #favorite-actions,
    .buttons {
        display: flex !important;
        flex-wrap: wrap;
        align-items: center;
        gap: 10px;
        width: 100%;
        margin-top: 14px !important;
    }
    .reading-actions .btn,
    #favorite-actions .btn,
    .buttons .btn {
        flex: 1 1 150px;
        min-height: 46px;
        margin: 0 !important;
        text-align: center;
        white-space: normal;
    }
    .reaction-actions { flex: 0 0 auto; }

    #thumbnail-container {
        display: grid !important;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 8px;
        padding: 0 !important;
    }
    .thumb-container {
        display: block !important;
        width: 100% !important;
        margin: 0 !important;
    }
    .gallerythumb,
    .gallerythumb img {
        display: block;
        width: 100% !important;
        height: auto !important;
        border-radius: 5px;
    }
    .thumbnail-load-actions {
        display: grid !important;
        grid-template-columns: 1fr 1fr;
        gap: 10px;
    }
    .thumbnail-load-actions .btn { margin: 0 !important; }

    #page-container {
        width: 100% !important;
        max-width: 100vw !important;
        padding: 8px 8px 72px !important;
    }
    .reader-tools {
        justify-content: flex-start !important;
        gap: 8px !important;
        overflow-x: auto;
        padding: 9px 8px !important;
        margin: 0 -8px 10px !important;
    }
    .reader-tools > .btn,
    .reader-mode-switch,
    .reader-fit-switch,
    .reader-jump,
    .reader-progress {
        flex: 0 0 auto;
    }
    .reader-fit-switch .btn,
    .reader-mode-switch .btn,
    .reader-jump .btn {
        min-height: 42px;
        padding: 9px 11px !important;
        white-space: nowrap;
    }
    .reader-jump input {
        width: 72px !important;
        height: 42px;
        font-size: 16px;
    }
    .reader-pagination-controls {
        display: flex !important;
        justify-content: center !important;
        align-items: center;
        gap: 12px !important;
        flex-wrap: nowrap;
        width: 100% !important;
        margin: 10px auto !important;
        padding: 0 !important;
    }
    .reader-pagination-controls a,
    .reader-pagination-controls button {
        min-width: 42px;
        min-height: 42px;
        margin: 0 !important;
    }
    #image-container img,
    #reader-current-image {
        width: 100% !important;
        max-width: 100% !important;
        height: auto !important;
    }
    .reader-fit-height #reader-current-image {
        width: auto !important;
        max-width: 100% !important;
        max-height: calc(100vh - 190px);
    }
    .reader-fit-actual #reader-current-image {
        max-width: 100% !important;
        width: auto !important;
    }
    .vertical-page-wrap { padding: 0 2px; }

    .local-comments {
        padding: 14px !important;
        margin-top: 22px !important;
    }
    .local-comment { gap: 9px; }
    .local-comment.reply { margin-left: 18px !important; }
    .comment-form textarea,
    .reply-form textarea {
        font-size: 16px;
    }

    .seo-link-hub { padding: 18px 10px; }
    .seo-link-grid { grid-template-columns: 1fr 1fr !important; }
    footer { padding-bottom: 74px !important; }
    .footer-container { width: min(100% - 20px, 1120px) !important; }
    .footer-left, .footer-right {
        display: flex !important;
        flex-wrap: wrap;
        justify-content: center;
        gap: 8px 12px;
    }
    .footer-left li, .footer-right li { margin: 0 !important; }

    .card, .table-card, .dashboard-card, .profile-card {
        width: min(100% - 20px, 1120px) !important;
        max-width: calc(100vw - 20px) !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }
    table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }
}

@media (max-width: 430px) {
    .gallery { width: calc(50% - 8px) !important; margin: 4px !important; }
    #thumbnail-container { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .seo-link-grid { grid-template-columns: 1fr !important; }
    .mobile-bottom-nav a { font-size: 11px !important; padding-left: 2px !important; padding-right: 2px !important; }
    .mobile-bottom-nav i { font-size: 15px; }
    #info h1 { font-size: 20px !important; }
}

@media (max-width: 768px) {
    nav .logo {
        margin-left: 0 !important;
        padding: 0 !important;
        height: 46px !important;
    }
    nav .logo img {
        max-width: 42px !important;
        max-height: 34px !important;
        object-fit: contain;
    }

    .languageflag {
        display: grid !important;
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: 8px;
        width: calc(100vw - 20px) !important;
        max-width: calc(100vw - 20px) !important;
        margin: 10px auto !important;
        padding: 0 !important;
    }
    .languageflag li {
        width: auto !important;
        margin: 0 !important;
        min-width: 0 !important;
    }
    .languageflag a {
        display: grid !important;
        justify-items: center;
        gap: 4px;
        min-width: 0 !important;
        padding: 6px 3px !important;
    }
    .languageflag img {
        width: 36px !important;
        height: 36px !important;
    }
    .languageflag span {
        max-width: 100%;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        font-size: 11px !important;
    }

    .index-container {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px !important;
        align-items: start;
        width: calc(100vw - 16px) !important;
        max-width: calc(100vw - 16px) !important;
        padding: 10px 8px !important;
        margin: 10px auto !important;
        text-align: left !important;
    }
    .index-container > h1,
    .index-container > h2,
    .index-container > h3,
    .index-container > .notice,
    .index-container > .pagination {
        grid-column: 1 / -1;
        text-align: left !important;
    }
    .index-container h1,
    .index-container h2,
    .index-container h3 {
        font-size: 20px !important;
        line-height: 1.25 !important;
        margin: 4px 0 2px !important;
    }
    .index-container .gallery,
    .gallery {
        display: block !important;
        width: 100% !important;
        max-width: none !important;
        min-width: 0 !important;
        margin: 0 !important;
        position: relative !important;
    }
    .index-container .gallery .cover,
    .gallery .cover,
    a.cover {
        position: relative !important;
        display: block !important;
        width: 100% !important;
        min-width: 0 !important;
        overflow: hidden !important;
        background: #111 !important;
    }
    .index-container .gallery .cover img,
    .gallery .cover img,
    a.cover > img {
        position: absolute !important;
        inset: 0 !important;
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
        margin: 0 !important;
    }
    .index-container .gallery .caption,
    .gallery .caption,
    .cover .caption {
        position: absolute !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        top: auto !important;
        max-height: 58px !important;
        min-height: 36px;
        padding: 6px 5px !important;
        color: #fff !important;
        background: linear-gradient(transparent, rgba(0,0,0,.88)) !important;
        text-shadow: 0 1px 2px #000;
        font-size: 12px !important;
        line-height: 1.15 !important;
    }

    #bigcontainer {
        width: calc(100vw - 16px) !important;
        max-width: calc(100vw - 16px) !important;
        padding: 12px 10px !important;
    }
    #cover img {
        width: 100% !important;
        max-width: 320px !important;
    }
    #info h1 {
        font-size: 17px !important;
        line-height: 1.28 !important;
    }
    #info h2 {
        font-size: 13px !important;
    }
    #gallery_id {
        font-size: 15px !important;
        text-align: left !important;
    }
    #tags .tag-container {
        font-size: 12px !important;
    }
    #tags .tag .name,
    #tags .tag .count {
        font-size: 11px !important;
    }

    #thumbnail-container {
        width: calc(100vw - 16px) !important;
        max-width: calc(100vw - 16px) !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 8px !important;
        padding: 8px !important;
    }
    .thumb-container,
    .thumb-container a,
    .gallerythumb {
        min-width: 0 !important;
        max-width: none !important;
    }
    .gallerythumb img {
        width: 100% !important;
        height: auto !important;
        object-fit: contain !important;
    }

    .seo-link-hub {
        width: calc(100vw - 16px) !important;
        max-width: calc(100vw - 16px) !important;
        margin: 12px auto !important;
        padding: 14px 10px !important;
        text-align: left !important;
    }
    .seo-link-hub h2 {
        font-size: 20px !important;
        line-height: 1.25 !important;
    }

    .pagination {
        display: flex !important;
        flex-wrap: wrap;
        justify-content: center;
        gap: 4px;
        width: calc(100vw - 16px) !important;
        margin: 16px auto !important;
        font-size: 13px !important;
    }
    .pagination a,
    .pagination span {
        min-width: 28px !important;
        padding: 5px 6px !important;
    }
}

@media (max-width: 360px) {
    .index-container { gap: 8px !important; }
    .index-container .gallery .caption,
    .gallery .caption,
    .cover .caption {
        font-size: 11px !important;
        max-height: 50px !important;
    }
    .reader-pagination-controls { gap: 8px !important; }
    .reader-pagination-controls a,
    .reader-pagination-controls button {
        min-width: 36px;
    }
}

@media (max-width: 768px), (pointer: coarse) {
    html,
    body {
        height: auto !important;
        min-height: 100% !important;
        overflow-y: auto !important;
        overscroll-behavior-y: auto !important;
    }

    #page-container,
    #image-container,
    #reader-next-link,
    #vertical-reader-container,
    #vertical-reader-pages,
    .vertical-page-wrap {
        overflow: visible !important;
        touch-action: pan-y pinch-zoom !important;
        -webkit-overflow-scrolling: touch;
    }

    #reader-next-link {
        display: block !important;
    }

    #reader-current-image,
    .vertical-page {
        touch-action: pan-y pinch-zoom !important;
        -webkit-user-drag: none;
        user-select: none;
    }

    .reader-tap,
    .reader-left,
    .reader-right {
        display: none !important;
        pointer-events: none !important;
    }
}

@media (max-width: 768px) {
    nav[role="navigation"] {
        grid-template-columns: 48px minmax(0, 1fr) 52px !important;
        min-height: 58px !important;
        padding: 7px 10px !important;
        gap: 8px !important;
        border-bottom: 1px solid #282828;
    }

    nav #hamburger {
        display: inline-flex !important;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 4px;
        width: 52px !important;
        height: 46px !important;
        min-width: 52px !important;
        margin: 0 !important;
        border-radius: 5px !important;
    }
    nav #hamburger .line {
        width: 32px !important;
        height: 3px !important;
        margin: 0 !important;
    }

    nav .collapse,
    nav .collapse.mobile-open,
    nav .collapse.open {
        position: fixed !important;
        top: 58px !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 56px !important;
        width: 100vw !important;
        max-height: none !important;
        min-height: 0 !important;
        overflow-y: auto !important;
        overscroll-behavior: contain;
        background: #151515 !important;
        border-top: 1px solid #2a2a2a !important;
        box-shadow: 0 18px 35px rgba(0,0,0,.5) !important;
        padding: 6px 0 !important;
        z-index: 9999 !important;
    }
    nav .collapse:not(.open):not(.mobile-open) {
        display: none !important;
        max-height: 0 !important;
        bottom: auto !important;
        padding: 0 !important;
    }

    nav .collapse .menu,
    nav .collapse.mobile-open .menu,
    nav .collapse.open .menu,
    nav .menu.left,
    nav .menu.right {
        display: block !important;
        float: none !important;
        width: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
        list-style: none !important;
    }

    nav .collapse .menu li,
    nav .collapse.mobile-open .menu li,
    nav .collapse.open .menu li {
        display: block !important;
        width: 100% !important;
        margin: 0 !important;
        border: 0 !important;
    }

    nav .collapse .menu li a,
    nav .collapse.mobile-open .menu li a,
    nav .collapse.open .menu li a {
        display: flex !important;
        align-items: center;
        justify-content: flex-start;
        width: 100% !important;
        height: auto !important;
        min-height: 44px !important;
        line-height: 1.25 !important;
        padding: 12px 22px !important;
        color: #eee !important;
        font-size: 16px !important;
        text-align: left !important;
        border-bottom: 1px solid #282828 !important;
        background: transparent !important;
    }
    nav .collapse .menu li.active > a {
        background: #ed2553 !important;
        color: #fff !important;
    }

    nav .collapse .menu.left + .menu.right {
        margin-top: 6px !important;
        border-top: 1px solid #303030 !important;
    }

    nav .collapse .dropdown,
    nav .collapse.mobile-open .dropdown,
    nav .collapse.open .dropdown,
    nav .collapse .dropdown-menu,
    nav .collapse.mobile-open .dropdown-menu,
    nav .collapse.open .dropdown-menu,
    nav #dropdown {
        display: none !important;
        visibility: hidden !important;
        height: 0 !important;
        min-height: 0 !important;
        max-height: 0 !important;
        padding: 0 !important;
        margin: 0 !important;
        overflow: hidden !important;
    }
}
