@charset "windows-1251";

/**************************************************************
* Скелет кода by max, the murder!
* Переработка и стиль by Filippa Turner
* Девиз релиза: работает - и хуй с ним
**************************************************************/

/**************************************************************
* 01. Подключения и шрифты
* Импорты, Font Awesome, Google Fonts и ролевые красивости
**************************************************************/

@import url('style_cs.1778832125.css');

@import url('https://kit-pro.fontawesome.com/releases/v6.6.0/css/pro.min.css');

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;0,700;1,400;1,600;1,700&family=Forum&family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Lora:ital,wght@0,400;0,600;0,700;1,400;1,600;1,700&family=Marck+Script&family=Montserrat:ital,wght@0,100..900;1,100..900&family=Noto+Serif+Display:ital,wght@0,400;0,600;0,700;1,400;1,600;1,700&family=Nunito+Sans:ital,wght@0,200..900;1,200..900&family=Philosopher:wght@400;700&family=Rubik:wght@400;500;600;700&display=swap');

/* эти священные артефакты не должны исчезнуть */

@font-face {
    font-family: 'Yeseva One';
    src: url('https://forumstatic.ru/files/001a/cb/85/57134.otf') format('opentype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Garam Masala Header';
    src: url('https://forumstatic.ru/files/001b/b7/47/80138.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Roboto Local';
    src: url('https://forumstatic.ru/files/001b/0f/9f/47601.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Mostly Bright';
    src: url('https://forumstatic.ru/files/0019/e6/8a/51018.otf') format('opentype');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Agraham';
    src: url('https://forumstatic.ru/files/0019/e6/8a/39518.ttf') format('truetype');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

/**************************************************************
* 02. Наименование тем и базовый каркас
* Не спрашивайте, я сама запуталась
**************************************************************/

:root {
    --text-main: 69 55 45;
    --surface-soft: 255 250 244;
    --accent-tea: 198 118 95;
    --accent-gold: 198 118 95;
    --line-warm: 222 204 190;
    --muted-text: 139 116 103;
    --page-bg: 222 204 190;
    --panel-bg: 255 250 244;
    --category-bg: 255 247 241;
    --category-head-bg: 252 242 234;
    --stats-bg: 238 219 207;
    --post-bg: 255 247 241;
    --profile-bg: 247 235 226;
    --quote-bg: 247 235 226;
    --code-bg: 241 228 219;
    --spoiler-bg: 247 235 226;
    --hero-title: 198 118 95;
    --hero-subtitle: 108 75 36;
    --hero-note: 69 55 45;
    --hero-shadow: 255 250 244;
    --nav-link: 69 55 45;
    --quick-link: 198 118 95;
    --theme-toggle-bg: 255 250 244;
    --theme-toggle-shadow: 69 55 45;
    --forum-shadow: 69 55 45;
    --font-title: 'Yeseva One', georgia, times new roman, garamond, serif;
    --font-header: 'Garam Masala Header', 'Cormorant Garamond', georgia, times new roman, serif;
    --font-icons: 'Font Awesome 6 Pro';
    --page-pattern: url('https://forumstatic.ru/files/001b/b7/47/24237.jpg');
    --hero-image: url('https://forumstatic.ru/files/001b/b7/47/37459.jpg');
    --profile-width: calc(180px + calc(var(--16) * 2));
    --forum-width: 1080px;
    --hero-height: 360px;
    --64: calc(var(--16) * 4);
    --32: calc(var(--16) * 2);
    --24: calc(var(--16) * 1.5);
    --20: calc(var(--16) * 1.25);
    --16: 16px;
    --12: calc(var(--16) / 1.33);
    --8: calc(var(--16) / 2);
    --6: calc(var(--16) / 2.66);
    --4: calc(var(--16) / 4);
    --2: calc(var(--16) / 8);
    --radius-main: 8px;
    --radius-small: calc(var(--radius-main) / 2);
}

html[data-theme="dark"] {
    --text-main: 222 199 168;
    --surface-soft: 24 22 18;
    --accent-tea: 213 159 76;
    --accent-gold: 236 187 96;
    --line-warm: 108 73 45;
    --muted-text: 177 144 106;
    --page-bg: 12 11 9;
    --panel-bg: 21 19 16;
    --category-bg: 24 22 18;
    --category-head-bg: 31 27 22;
    --stats-bg: 10 10 9;
    --post-bg: 29 27 23;
    --profile-bg: 38 36 31;
    --quote-bg: 35 33 29;
    --code-bg: 25 24 21;
    --spoiler-bg: 35 33 29;
    --hero-title: 224 164 91;
    --hero-subtitle: 224 164 91;
    --hero-note: 232 209 176;
    --hero-shadow: 0 0 0;
    --nav-link: 225 196 151;
    --quick-link: 236 187 96;
    --theme-toggle-bg: 34 29 23;
    --theme-toggle-shadow: 0 0 0;
    --forum-shadow: 0 0 0;
    --page-pattern: url('https://forumstatic.ru/files/001b/b7/47/89821.jpg');
    --hero-image: url('https://forumstatic.ru/files/001b/b7/47/90490.jpg');
}

html[data-theme="gray"] {
    --text-main: 205 196 181;
    --surface-soft: 36 40 40;
    --accent-tea: 111 146 169;
    --accent-gold: 154 176 188;
    --line-warm: 104 105 99;
    --muted-text: 166 157 145;
    --page-bg: 28 34 35;
    --panel-bg: 39 43 43;
    --category-bg: 42 47 48;
    --category-head-bg: 48 52 52;
    --stats-bg: 35 34 34;
    --post-bg: 43 48 49;
    --profile-bg: 50 55 55;
    --quote-bg: 48 53 54;
    --code-bg: 35 39 40;
    --spoiler-bg: 48 53 54;
    --hero-title: 213 198 181;
    --hero-subtitle: 213 198 181;
    --hero-note: 210 202 191;
    --hero-shadow: 0 0 0;
    --nav-link: 205 196 181;
    --quick-link: 133 166 190;
    --theme-toggle-bg: 42 47 48;
    --theme-toggle-shadow: 0 0 0;
    --forum-shadow: 0 0 0;
    --page-pattern: url('https://forumstatic.ru/files/001b/b7/47/10360.jpg');
    --hero-image: url('https://forumstatic.ru/files/001b/b7/47/71641.jpg');
}

* {
    margin: 0;
    padding: 0;
    border: none;
    box-sizing: border-box;
    outline: none;
}

html {
    padding: var(--32) 0;
    font: normal 70%/140% 'Inter', verdana, arial, tahoma, trebuchet ms, sans-serif;
    background: var(--page-pattern) no-repeat center center / cover fixed, rgb(var(--page-bg));
    color: rgb(var(--text-main));
    -webkit-text-size-adjust: 100%;
}

#pun {
    max-width: var(--forum-width);
    width: calc(100% - 32px);
    margin: 0 auto;
}

.punbb {
    padding: 0 var(--32) var(--16);
    background: rgb(var(--surface-soft));
    position: relative;
    border: 1px solid rgb(var(--line-warm));
    border-radius: var(--radius-main);
}

.punbb .container {
    padding: 1.4em 0; /* он видел страшное */
}

.punbb .container::after,
#viewprofile-next::after,
.post-body::after,
.linkst::after {
    clear: both;
    content: '';
    display: block;
    visibility: hidden;
}

.fs-box {
    padding: var(--8) 0;
}

.hashelp {
    position: relative;
}

.punbb {
    box-shadow: 0 22px 70px rgb(var(--forum-shadow) / .16);
}

/**************************************************************
* 03. Служебные контейнеры, боевые окрошки, ссылки и заголовки
**************************************************************/

#pun-announcement .container {
    padding: 0;
}

#html-footer .container {
    padding: 0;
}

/* модный футер для модных девочек */
#gm-footer {
    display: grid;
    grid-template-columns: minmax(260px, 1fr) minmax(420px, 2fr) 200px;
    align-items: stretch;
    width: calc(100% + var(--64));
    margin: var(--16) calc(var(--32) * -1) calc(var(--16) * -1);
    border-top: 1px solid rgb(var(--line-warm) / .55);
    border-right: 0;
    border-bottom: 0;
    border-left: 0;
    border-radius: 0;
    background: rgb(var(--surface-soft) / .72);
    overflow: hidden;
    color: rgb(var(--text-main));
}

#gm-footer > div {
    min-width: 0;
}

.gm-footer-left,
.gm-footer-links,
.gm-footer-seal {
    min-height: 92px;
}

.gm-footer-left {
    display: grid;
    grid-template-columns: 86px minmax(0, 1fr);
    align-items: center;
    gap: var(--16);
    padding: var(--12) var(--20);
    border-right: 1px solid rgb(var(--line-warm) / .42);
}

.gm-footer-ornament {
    width: 62px;
    height: 62px;
    margin: 0 auto;
    opacity: .58;
    background:
        linear-gradient(135deg, transparent 42%, rgb(var(--line-warm)) 43% 46%, transparent 47%),
        linear-gradient(45deg, transparent 42%, rgb(var(--line-warm)) 43% 46%, transparent 47%);
    border-radius: 50%;
}

.gm-footer-brand {
    text-align: center;
}

.gm-footer-title {
    color: rgb(var(--text-main));
    font: 400 1.15rem/1 var(--font-title);
    text-transform: uppercase;
    letter-spacing: .22em;
}

.gm-footer-divider {
    margin: var(--4) 0;
    color: rgb(var(--accent-tea));
    font-size: .8rem;
}

.gm-footer-subtitle {
    color: rgb(var(--accent-tea));
    font: italic 700 .78rem/1.2 'Cormorant Garamond', georgia, serif;
    letter-spacing: .08em;
}

.gm-footer-links {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    border-right: 1px solid rgb(var(--line-warm) / .42);
}

.gm-footer-link {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--6);
    min-width: 0;
    padding: var(--12) var(--8);
    text-align: center;
    border-right: 1px solid rgb(var(--line-warm) / .34);
    color: rgb(var(--text-main));
    text-decoration: none;
    transition: color .2s ease, background .2s ease;
}

.gm-footer-link:last-child {
    border-right: 0;
}

.gm-footer-link:hover,
.gm-footer-link:focus {
    background: rgb(var(--stats-bg) / .38);
    color: rgb(var(--accent-tea));
}

.gm-footer-icon {
    color: rgb(var(--accent-tea));
    font-size: 1.15rem;
    line-height: 1;
}

.gm-footer-link b {
    display: block;
    max-width: 100%;
    font: 700 .72rem/1.2 'Inter', verdana, sans-serif;
    text-transform: uppercase;
    letter-spacing: .04em;
}

.gm-footer-seal {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--12);
}

.gm-footer-seal span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 62px;
    height: 62px;
    border: 1px solid rgb(var(--line-warm) / .72);
    border-radius: 50%;
    color: rgb(var(--accent-tea) / .72);
    font: 400 1rem/1 var(--font-title);
    letter-spacing: .08em;
    text-transform: uppercase;
    box-shadow: inset 0 0 0 6px rgb(var(--surface-soft) / .55);
}

#pun-about .container, #pun-crumbs2 .container {
    min-height: 14px;
    padding: 0 0 0;
    font-size: 0.81rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--8);
}

#pun-status .container {
    font-size: 0.9rem;
    padding-bottom: 0;
}

#pun-crumbs1 .container {
    font-size: 1.1rem;
    margin: 0 calc(var(--32) * -1); /* так надо */
    padding: var(--4) var(--32) var(--16);
}

#pun-crumbs1 .container a,
#pun-crumbs2 .container a {
    font-weight: 700;
}

h1,
h2 {
    position: relative;
    padding: var(--16) var(--32);
    border-bottom: 1px solid rgb(var(--line-warm) / .36);
    text-align: center !important; /* я сказала импортант, сука */
    margin: var(--16) calc(var(--32) * -1) var(--8);
}

h1 span,
h2 span {
    display: inline-block;
    padding: 0 var(--4) var(--2);
}

#pun-messages h2 {
    text-align: left;
}

.punbb legend span {
    font-size: 0.9rem;
    padding: 0 var(--4) var(--2);
}

/* css золушка */

#jGrowl h2 {
    border: none;
    margin: 0;
    text-align: left !important;
}

#jGrowl h2 span {
    background: none;
    font: inherit;
}

#jGrowl td {
    padding: var(--8) 0 0;
}

table {
    width: 100%;
    border-spacing: 0;
}

td,
th {
    padding: var(--12) var(--16);
}

.tipsy-inner #respect td {
    padding: 0;
}

th {
    font-size: 0.8rem;
    text-align: left;
    padding: var(--4) var(--16);
}

#pun-status .status-right {
    float: right;
    display: inline-block;
    margin: 0px 0px 0px 9px;
}

/**************************************************************
* 04. Скрытые элементы и системные правки
**************************************************************/

.punbb:not(.punbb-admin) #pun-title,
#pun-title .title-logo-tdl,
#pun-navlinks h2,
#pun-ulinks h2,
#pun-status h2,
#pun-index h1,
#pun-announcement h2,
.punbb:not(#pun-statistic) #pun-main h1,
#pun-crumbs1 .container strong,
#pun-crumbs2 .container strong,
#pun-index thead,
#pun-status .item4,
.acchide,
#pun-userlist h1,
#pun-userlist h2,
#pun-profile h2,
#pun-viewtopic h2,
#post fieldset legend > span,
.sharelink,
#formkey,
#formetc,
#pun-searchposts h1,
#pun-searchposts h2,
#pun-searchtopics h1,
#pun-searchtopics h2,
#pun-modviewforum h1,
#pun-modviewforum h2,
#pun-viewforum h1,
#pun-viewforum h2,
.punbb .submitfield label,
.pa-gifts,
.gid5 #navprofile,
.post-sig dt,
#pun-navlinks #navawards,
#pun-navlinks #navrules,
.modlist,
.tclcon:has(.modlist) > br:last-of-type,
#pun-ulinks #h-replies,
#pun-ulinks #h-unanswered,
.pl-email.email,
.catleft,
.catright,
#pun-premoderation .pa-title,
#pun-premoderation .pa-ua,
#pun-premoderation .pa-posts,
#pun-premoderation .pa-respect,
#pun-premoderation li[class^="pa-fld"],
#pun-premoderation h2,
#pun-viewtopic .linksb .postlink,
.inputfield:has(.social) {
    display: none;
}

#pun-viewforum tr td:first-child,
#pun-viewforum tr th:first-child,
#pun-modviewforum tr td:first-child,
#pun-modviewforum tr th:first-child,
#pun-searchtopics tr td:first-child,
#pun-searchtopics tr th:first-child,
#pun-userlist tr td:first-child,
#pun-userlist tr th:first-child,
#pun-statistic tr td:first-child,
#pun-statistic tr th:first-child,
#pun-respect tr td:first-child,
#pun-respect tr th:first-child,
#pun-positive tr td:first-child,
#pun-positive tr th:first-child,
#pun-messages #messages tr td:first-child,
#pun-messages #messages tr th:first-child,
.profile-awards-container tr td:first-child,
.profile-awards-container tr th:first-child {
    padding-left: 0;
}

#pun-viewforum tr td:last-child,
#pun-viewforum tr th:last-child,
#pun-modviewforum tr td:last-child,
#pun-modviewforum tr th:last-child,
#pun-searchtopics tr td:last-child,
#pun-searchtopics tr th:last-child,
#pun-userlist tr td:last-child,
#pun-userlist tr th:last-child,
#pun-statistic tr td:last-child,
#pun-statistic tr th:last-child,
#pun-respect tr td:last-child,
#pun-respect tr th:last-child,
#pun-positive tr td:last-child,
#pun-positive tr th:last-child,
#pun-messages #messages tr td:last-child,
#pun-messages #messages tr th:last-child,
.profile-awards-container tr td:last-child,
.profile-awards-container tr th:last-child {
    padding-right: 0;
}

/**************************************************************
* 05. Верхняя навигация и пользовательские ссылки
**************************************************************/
#pun-navlinks,
#pun-ulinks {
    margin: 0 calc(var(--32) * -1);
}

#pun-navlinks .container,
#pun-ulinks .container {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--4);
    padding: 0;
    text-align: center;
}

#pun-navlinks li,
#pun-ulinks li {
    display: inline-block;
    list-style: none;
}

#pun-navlinks li a {
    display: inline-flex;
    align-items: center;
    gap: var(--6);
    padding: var(--6) var(--4);
    color: rgb(var(--nav-link));
    font: 600 .98rem / 100% 'Inter', verdana, arial, sans-serif;
    text-transform: uppercase;
}

#pun-navlinks li a::before {
    color: rgb(var(--accent-gold));
    font-family: var(--font-icons);
    font-weight: 400;
    font-size: .92rem;
    line-height: 1;
}

#navindex a::before { content: '\f015'; }
#navuserlist a::before { content: '\f0c0'; }
#navsearch a::before { content: '\f002'; }
#navprofile a::before { content: '\f007'; }
#navpm a::before { content: '\f0e0'; }
#navadmin a::before { content: '\f013'; }
#navlogout a::before { content: '\f2f5'; }
#navlogin a::before { content: '\f2f6'; }
#navregister a::before { content: '\f234'; }
#navpr_1 a::before { content: '\f1ea'; }
#navpr_2 a::before { content: '\f5da'; }
#pun-navlinks li a:hover,
#pun-navlinks li a:focus,
#pun-navlinks li.isactive a {
    background: none;
    color: rgb(var(--accent-tea));
}

#pun-navlinks li a:hover::before,
#pun-navlinks li a:focus::before,
#pun-navlinks li.isactive a::before {
    color: rgb(var(--accent-tea));
}

#pun-ulinks {
    border-bottom: 1px solid rgb(var(--line-warm) / .36);
}

#pun-ulinks li a {
    display: inline-block;
    padding: var(--4);
    color: rgb(var(--quick-link));
    font-size: .9rem;
    font-weight: 500;
    text-transform: lowercase;
}

#pun-ulinks li a:hover,
#pun-ulinks li a:focus {
    background: none;
    color: rgb(var(--accent-tea));
}

.punbb:not(.punbb-admin) #pun-navlinks,
.punbb:not(.punbb-admin) #pun-ulinks {
    position: relative;
    z-index: 2;
    width: calc(100% + var(--64) + var(--16));
    margin-left: calc((var(--32) + var(--8)) * -1);
    margin-right: calc((var(--32) + var(--8)) * -1);
}

.punbb:not(.punbb-admin) #pun-navlinks {
    margin-bottom: 0;
}

.punbb:not(.punbb-admin) #pun-ulinks {
    border-bottom: 0;
}

.punbb:not(.punbb-admin) #pun-navlinks .container,
.punbb:not(.punbb-admin) #pun-ulinks .container {
    background: rgb(var(--panel-bg));
    border-left: 1px solid rgb(var(--line-warm) / .55);
    border-right: 1px solid rgb(var(--line-warm) / .55);
}

.punbb:not(.punbb-admin) #pun-navlinks .container {
    min-height: 36px;
    margin-top: calc(var(--24) * -1);
    padding: 0 var(--20);
    border-top: 1px solid rgb(var(--line-warm) / .55);
    border-radius: var(--radius-main) var(--radius-main) 0 0;
}

.punbb:not(.punbb-admin) #pun-ulinks .container {
    min-height: 30px;
    padding: 0 var(--20) var(--4);
    border-bottom: 1px solid rgb(var(--line-warm) / .55);
    border-radius: 0 0 var(--radius-main) var(--radius-main);
}

/**************************************************************
* 06. Красивишная шапка
**************************************************************/

#header_table {
    position: relative;
    top: auto;
    left: auto;
    width: calc(100% + var(--64));
    height: var(--hero-height);
    margin: 0 calc(var(--32) * -1);
    background: var(--hero-image) no-repeat center center / cover;
    border: 0;
    border-radius: calc(var(--radius-main) - 1px) calc(var(--radius-main) - 1px) 0 0;
    overflow: hidden;
}

#header_table .gm-title,
#header_table .gm-subtitle,
#header_table .gm-note,
#header_table .gm-admins,
#header_table .gm-quicklinks {
    position: absolute;
    z-index: 2;
}

#header_table .gm-admins {
    position: absolute;
    top: 45px;
    left: 0;
    right: var(--32);
    display: flex;
    justify-content: center;
    align-items: center;
    gap: var(--8);
    color: rgb(var(--hero-note));
    font: 700 .72rem / 1.2 'Inter', verdana, arial, sans-serif;
    text-transform: lowercase;
}

#header_table .gm-admin {
    display: inline-flex;
    align-items: center;
    color: rgb(var(--hero-note));
}

#header_table .gm-admin + .gm-admin::before {
    content: '//';
    margin-right: var(--8);
    color: rgb(var(--quick-link));
}

#header_table .gm-admin:hover,
#header_table .gm-admin:focus {
    color: rgb(var(--quick-link));
    transform: none;
}

#header_table .gm-title {
    top: 80px;
    left: 35%;
    width: min(560px, calc(100% - var(--64)));
    color: rgb(var(--hero-title));
    font-family: var(--font-header);
    font-size: 7.4rem;
    font-weight: 400;
    line-height: .78;
    letter-spacing: 0;
    text-transform: uppercase;
}

#header_table .gm-title span {
    display: block;
}

#header_table .gm-title-garam {
    transform: translateX(-28px);
}

#header_table .gm-title-masala {
    color: rgb(var(--hero-title));
    transform: translateX(18px);
    font-size: 6.5rem;
}

#header_table .gm-subtitle {
    top: 219px;
    left: 37%;
    width: min(430px, calc(100% - var(--64)));
    color: rgb(var(--hero-subtitle));
    font: 700 1.4rem / 1.15 'Inter', verdana, arial, sans-serif;
    letter-spacing: .42em;
    text-transform: lowercase;
}

#header_table .gm-note {
    top: 256px;
    left: 34%;
    width: min(347px, calc(100% - var(--64)));
    color: rgb(var(--hero-note) / .88);
    font: 500 .82rem / 1.24 'Inter', verdana, arial, sans-serif;
    letter-spacing: 0;
    text-align: left;
    overflow: visible;
}

#gm-theme-toggle {
    position: absolute;
    left: var(--20);
    top: var(--20);
    z-index: 5;
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgb(var(--line-warm) / .72);
    border-radius: 50%;
    background: rgb(var(--theme-toggle-bg) / .88);
    color: rgb(var(--accent-gold));
    box-shadow: 0 10px 30px rgb(var(--theme-toggle-shadow) / .18);
    cursor: pointer;
    transition: color .2s ease, background .2s ease, border-color .2s ease, transform .2s ease;
}

#pun #header_table .gm-quicklinks {
    position: absolute;
    left: var(--32);
    right: var(--32);
    bottom: var(--20);
    z-index: 2;
    transform: none;
    display: flex;
    justify-content: center;
    gap: var(--8);
}

#pun #header_table .gm-quicklinks a {
    display: inline-block;
    padding: var(--4) var(--12);
    background: rgb(var(--surface-soft) / .78);
    border: 1px solid rgb(var(--line-warm) / .55);
    border-radius: var(--radius-small);
    color: rgb(var(--quick-link));
    font-weight: 600;
    text-transform: lowercase;
}

#gm-theme-toggle:hover,
#gm-theme-toggle:focus {
    color: rgb(var(--accent-tea));
    transform: translateY(-2px);
}

#gm-theme-toggle::before {
    content: '\f185';
    font-family: var(--font-icons);
    font-weight: 400;
    font-size: 1.25rem;
    line-height: 1;
}

html[data-theme="dark"] #gm-theme-toggle::before {
    content: '\f186';
}

html[data-theme="gray"] #gm-theme-toggle::before {
    content: '\f042';
}

/**************************************************************
* 07. Главная страница: категории и статистика
**************************************************************/

#pun-index h2 {
    margin: 0 calc(var(--32) * -1);
}

.punbb:not(#pun-index, #pun-mod, #pun-online, .punbb-admin) .tcl {
    width: 45%;
}

.punbb:not(#pun-index, #pun-mod, .punbb-admin) .tc2 {
    width: 15%;
}

.punbb:not(#pun-index, #pun-mod, .punbb-admin) .tc3 {
    width: 10%;
}

.punbb:not(#pun-index, #pun-mod, .punbb-admin) .tcr {
    width: 30%;
}

.punbb:not(#pun-index, #pun-mod, .punbb-admin) .tcr > a {
    display: inline-block;
    margin-top: var(--8);
}

#pun-index.punbb {
    padding-top: 0;
}

#pun-index #pun-status .container {
padding: 0 var(--4);
    color: rgb(var(--muted-text));
    font-size: 0.9rem;
    text-transform: lowercase;
    padding-bottom: 0px;
    margin-top: var(--16);
    margin-bottom: var(--8);
}

#pun-index #pun-status a {
    color: rgb(var(--accent-tea));
}

#pun-index .category {
    margin-top: var(--24);
    border: 1px solid rgb(var(--line-warm) / .55);
    border-radius: var(--radius-main);
    overflow: hidden;
    background: rgb(var(--category-bg) / .88);
}

#pun-index .category .container {
    padding: 0;
}

#pun-index .category h2 {
    margin: 0;
    padding: var(--12) var(--32);
    border-bottom: 1px solid rgb(var(--line-warm) / .45);
}

#pun-index .category h2 span {
    background: transparent;
    color: rgb(var(--muted-text));
    font: normal 400 1.35rem/1 var(--font-title);
    text-transform: uppercase;
    letter-spacing: 0;
    transform: none;
}

#pun-index .category h2 span::before,
#pun-index .category h2 span::after {
    content: '\f06c';
    display: inline-block;
    margin: 0 var(--16);
    color: rgb(var(--accent-tea));
    font: normal 400 1.50rem / 1 var(--font-icons);
    vertical-align: middle;
}

#pun-index .category h2 span::before {
    transform: scaleX(-1);
}

#pun-stats h2 {
    margin: var(--32) 0 var(--16);
    padding: 0 0 var(--8);
    text-align: center !important;
}

#pun-stats h2 span {
    background: transparent;
    color: rgb(var(--muted-text));
    font: normal 400 1.15rem/1 var(--font-title);
    text-transform: uppercase;
    letter-spacing: .04em;
}

#pun-stats h2 span::before,
#pun-stats h2 span::after {
    content: '\f06c';
    display: inline-block;
    margin: 0 var(--16);
    color: rgb(var(--accent-tea));
    font: normal 400 1.50rem / 1 var(--font-icons);
    vertical-align: middle;
}

#pun-stats h2 span::before {
    transform: scaleX(-1);
}

#pun-index .category tr {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 88px 112px minmax(220px, .7fr);
    gap: 0;
    align-items: stretch;
    padding: 0;
    margin: 0;
    border-bottom: 1px solid rgb(var(--line-warm) / .38);
}

#pun-index .category tr:last-child {
    border-bottom: 0;
}

#pun-index .category tr td {
    display: flex;
    width: auto !important;
    min-width: 0;
    padding: var(--20) var(--24);
    align-items: center;
    border-left: 1px solid rgb(var(--line-warm) / .28);
}

#pun-index .category tr .tcl {
    border-left: 0;
}

#pun-index .category tr .tcl .intd {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr);
    gap: var(--16);
    align-items: center;
    width: 100%;
}

#pun-index .category tr .tc2,
#pun-index .category tr .tc3 {
    justify-content: center;
    text-align: center;
    color: rgb(var(--muted-text));
}

#pun-index .category tr h3 a {
    margin: 0 0 var(--6);
    padding: 0;
    font: 400 1.55rem/110% var(--font-title);
    letter-spacing: 0;
    text-transform: uppercase;
    color: rgb(var(--text-main));
    background: none;
}

#pun-index .category .intd {
    font-size: .95rem;
    text-transform: none;
    color: rgb(var(--text-main) / .78);
    line-height: 130%;
}

#pun-index .category tr .tcr {
    color: rgb(var(--muted-text));
    display: inline-block;
}

#pun-index .category tr .tcr .datetime {
    text-transform: lowercase;

}

#pun-index .category tr .tcr .lastpost-link {
    color: rgb(var(--accent-tea));
    font-weight: 700;
    text-transform: none;
}

#pun-index tr div.icon {
    width: 34px;
    height: 34px;
    margin: 0;
    padding: 0;
    float: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgb(var(--line-warm) / .45);
    border-radius: 50%;
    background: rgb(var(--category-head-bg) / .72);
    color: rgb(var(--line-warm));
}

#pun-index tr div.icon::before {
    content: '\f4ad';
    font-family: var(--font-icons);
    font-weight: 400;
    font-size: 1rem;
    line-height: 1;
}

#pun-index tr.inew div.icon {
    background: rgb(var(--accent-tea));
    border-color: rgb(var(--accent-tea));
    color: rgb(var(--surface-soft));
    box-shadow: 0 0 0 4px rgb(var(--accent-tea) / .16);
}

#pun-index tr.inew div.icon::before {
    content: '\f0e0';
    font-weight: 900;
}

#pun-index tr.inew h3 a {
    color: rgb(var(--accent-tea));
}

#pun-index .user-avatar .avatar-image {
    border: 1px solid rgb(var(--line-warm));
    border-radius: 50%;
}

#pun-stats .container {
    padding: 0;
    list-style: none;
    display: flex;
    gap: var(--16);
    flex-direction: column;
    padding: var(--16) 0;
    text-transform: lowercase;
}

#pun-stats .container::after {
    display: none;
}

#pun-stats .statsinfo {
    display: flex;
    justify-content: center;
    gap: var(--16);
}

#pun-stats .statsinfo li {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--6);
    background: rgb(var(--stats-bg) / .64);
    line-height: 100%;
    padding: var(--8) var(--16);
    border-radius: var(--radius-main);
    flex-grow: 1;
    font-size: 0.9rem;
    text-align: center;
}

#pun-stats .statsinfo li::before {
    flex: 0 0 auto;
    color: rgb(var(--accent-tea));
    font-family: var(--font-icons);
    font-weight: 400;
    font-size: .9rem;
    line-height: 1;
}

#pun-stats .statsinfo li.item1::before {
    content: '\f02d';
}

#pun-stats .statsinfo li.item2::before {
    content: '\f086';
}

#pun-stats .statsinfo li.item3::before {
    content: '\f0c0';
}

#pun-stats .statsinfo li.item4::before {
    content: '\f234';
}

#pun-stats .statsinfo li.item4 {
    flex-shrink: 0;
}

#pun-stats .statsinfo li strong {
    font-weight: 700;
}

#pun-stats #onlinelist {
    color: rgb(var(--text-main) / .6);
}

/**************************************************************
* 08. Таблицы и списочные страницы
**************************************************************/

.punbb#pun-searchtopics td.tc2,
.punbb#pun-searchtopics th.tc2 {
    width: 15%;
}

.punbb#pun-searchtopics td.tc3,
.punbb#pun-searchtopics th.tc3 {
    width: 10%;
}

#pun-userlist form input,
#pun-userlist form select {
    height: var(--24);
}

#pun-viewforum table,
#pun-modviewforum table,
#pun-searchtopics table,
#pun-userlist table,
#pun-statistic table,
#pun-respect table,
#pun-positive table,
#pun-messages #messages table,
.profile-awards-container table {
    overflow: hidden;
}

#pun-viewforum table tr,
#pun-modviewforum table tr,
#pun-searchtopics table tr,
#pun-userlist table tr,
#pun-statistic table tr,
#pun-respect table tr,
#pun-positive table tr,
#pun-messages #messages table tr,
.profile-awards-container table tr {
    display: flex;
    align-items: center;
    margin-top: var(--8);
    color: rgb(var(--text-main) / .6);
    font-size: 1.11rem;
}

#pun-viewforum table th,
#pun-modviewforum table th,
#pun-searchtopics table th,
#pun-userlist table th,
#pun-statistic table th,
#pun-respect table th,
#pun-positive table th,
#pun-messages #messages table th,
.profile-awards-container table th {
    text-transform: lowercase;
    font-weight: 400;
    color: rgb(var(--text-main) / .6);
}

#pun-userlist tr .tcl,
#pun-viewforum tr .tcl .intd,
#pun-modviewforum tr .tcl .intd,
#pun-searchtopics tr .tcl .intd,
#pun-messages #messages tr .tcl .intd,
#pun-userlist tr .tcl .intd {
    display: flex;
    align-items: center;
    gap: var(--12);
}

#pun-viewforum table tr.inew strong,
#pun-modviewforum table tr.inew strong,
#pun-searchtopics table tr.inew strong {
    font-weight: 400;
}

#pun-viewforum table tr.inew a,
#pun-modviewforum table tr.inew a,
#pun-searchtopics table tr.inew a {
    font-weight: 700;
}

#pun-viewforum table .tcr a,
#pun-modviewforum table .tcr a,
#pun-searchtopics table .tcr a {
    text-transform: lowercase;
}

.profile-awards-container th,
.profile-awards-container td {
    width: 20% !important;
}

.profile-awards-container td {
    padding: var(--16);
}

th input[type="checkbox"] {
    margin: 0 !important;
}

#pun-messages #messages td.tc2.pmtc22 {
    display: flex !important;
    align-items: center;
    gap: var(--12);
}

#pun-userlist table tr,
#pun-statistic table tr {
    text-transform: lowercase;
}

.punbb#pun-userlist .tcl {
    width: 25%;
}

.punbb#pun-userlist .tc2,
.punbb#pun-userlist .tc3 {
    width: 15%;
}

#pun-statistic .main .container {
    padding: 0 0 var(--16) 0;
}

.punbb#pun-statistic .tcl {
    width: 40%;
}

.punbb#pun-statistic .tc2,
.punbb#pun-statistic .tc3 {
    width: 15%;
}

.punbb:not(.punbb-admin) .pagelink,
.punbb:not(.punbb-admin) .postlink {
    display: inline-block;
    margin: var(--8) 0;
}

.punbb:not(.punbb-admin) .postlink {
    float: right;
    width: unset;
}

.punbb:not(.punbb-admin) .pagelink a,
.punbb:not(.punbb-admin) .pagelink strong {
    display: inline-block;
    padding: 0 var(--4) !important;
    border-radius: var(--radius-small) !important;
}

.punbb:not(.punbb-admin) .pagelink span {
    margin: 0 var(--4);
}

.punbb tr .stickytext,
.punbb tr .closedatafield {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: var(--20);
    height: var(--20);
    margin: 0 var(--4) 0 0;
    border-radius: 50%;
    font-size: 0;
    line-height: 1;
    vertical-align: middle;
}

.punbb tr .stickytext::before,
.punbb tr .closedatafield::before {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-icons);
    font-size: 0.85rem;
    font-weight: 400;
    line-height: 1;
}

.punbb tr .stickytext {
    background: rgb(var(--accent-tea) / .6);
}

.punbb tr .closedatafield {
    background: rgb(var(--line-warm) / .38);
}

.punbb tr .stickytext::before {
    content: '\f08d';
}

.punbb tr .closedatafield::before {
    content: '\f023';
}

/**************************************************************
* 09. Формы, поля, чекбоксы, кнопки
**************************************************************/

.inputfield label,
.selectfield label {
    font-size: 0.9rem;
    display: inline-block;
    font-weight: 400;
    text-transform: lowercase;
}

.inline .inputfield,
.inline .selectfield {
    display: inline-block;
}

.punbb .fs-box p,
.punbb .fs-box fieldset {
    padding: 0 0 var(--8) 0;
}

input,
textarea,
#pun #sTheme {
    padding: var(--6) var(--6);
    box-sizing: border-box;
    background: rgb(var(--stats-bg) / .64);
    border-radius: var(--radius-main);
    color: rgb(var(--text-main));
    font: normal 1rem/130% 'Inter', verdana, arial, tahoma, trebuchet ms, sans-serif;
    border: none;
    margin: 0 var(--4) var(--4) 0 !important;
    max-width: 100%;
}

select {
    background: rgb(var(--stats-bg) / .64);
    color: rgb(var(--text-main));
    font-family: 'Inter', verdana, arial, tahoma, trebuchet ms, sans-serif;
    padding: var(--4) var(--6);
    margin: 0 var(--4) var(--4) 0 !important;
    border-radius: var(--radius-main);
    max-width: 100%;
    font-size: 1rem;
    text-transform: lowercase;
}

select option {
    background: rgb(var(--surface-soft));
}

select:hover {
    cursor: pointer;
}

::placeholder {
  color: rgb(var(--text-main) / .38);
  opacity: 1;
}

input[type="checkbox"],
input[type="radio"] {
    -webkit-appearance: none;
    appearance: none;
    width: var(--12);
    height: var(--12);
    min-width: var(--12);
    min-height: var(--12);
    margin: 0 var(--2) 0 0 !important;
    border-radius: var(--radius-small);
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    vertical-align: middle;
    padding: 0;
}

input[type="radio"] {
    border-radius: var(--6);
}

input[type="checkbox"]:hover,
input[type="radio"]:hover {
    cursor: pointer;
    background: rgb(var(--line-warm) / .6);
}

input[type="checkbox"]:checked {
    background: rgb(var(--accent-tea));
}

input[type="radio"]:checked:hover {
    cursor: default;
}

input[type="radio"]:checked {
    background: transparent;
    box-shadow: inset 0 0 0 2px rgb(var(--accent-tea));
}

input[type="radio"]:checked::before {
    content: '\f111';
    font: 900 var(--6)/100% var(--font-icons);
    color: rgb(var(--accent-tea));
}

input[type="checkbox"]:checked::before {
    content: '\f00c';
    font: 900 var(--8)/100% var(--font-icons);
}

input[type="checkbox"]:checked:hover {
    background: rgb(var(--line-warm) / .6);
}

p[class="checkfield"] *,
div[class="checkfield"] *,
fieldset[class="radiofield"] * {
    line-height: 100%;
    vertical-align: middle;
}

.radio label,
.checkfield label {
    padding: 0 var(--8) 0 var(--4);
}

.checkfield label {
    line-height: 120%;
}

.radio *:hover,
.checkfield *:hover {
    cursor: pointer;
}

button,
.button,
input[type="button"],
input[type="submit"] {
    border-radius: var(--radius-main);
    background: rgb(var(--accent-tea));
    color: rgb(var(--text-main));
    margin: var(--4) !important;
    font-weight: 700 !important;
    font-family: 'Inter', verdana, arial, tahoma, trebuchet ms, sans-serif !important;
    line-height: 100%;
    font-size: 1rem;
    text-transform: lowercase;
    transition: all .2s ease;
    padding-left: var(--12);
    padding-right: var(--12);
}

button[disabled],
.button[disabled],
input[disabled] {
    background: rgb(var(--text-main) / .12);
    color: rgb(var(--text-main) / .388);
}

.button[name="preview"],
.button.full,
.button.cancel,
.button[name="cancel"] {
    background: rgb(var(--stats-bg) / .64);
    color: rgb(var(--text-main));
}

.formsubmit input,
.formsubmit a,
.formsubmit span {
    margin: 0 var(--8) 0 0;
}

button:hover,
.button:hover,
input[type="button"]:hover,
input[type="submit"]:hover {
    background: rgb(var(--text-main)) !important;
    color: rgb(var(--surface-soft)) !important;
    cursor: pointer;
}

button:active,
.button:active,
input[type="button"]:active,
input[type="submit"]:active {
    background: rgb(var(--text-main)) !important;
    color: rgb(var(--surface-soft)) !important;
    transform: scale(0.9);
    cursor: pointer;
}

button[disabled]:hover,
.button[disabled]:hover,
input[disabled]:hover {
    background: rgb(var(--text-main) / .12) !important;
    color: rgb(var(--text-main) / .38) !important;
    cursor: not-allowed;
}

.punbb #isk {
    border-radius: var(--radius-main);
    border: none;
    background: rgb(var(--accent-tea));
    color: rgb(var(--text-main));
    margin-left: var(--4);
    position: relative;
    height: var(--24);
    transition: all .2s ease;
}

.punbb #isk:hover {
    background: rgb(var(--text-main));
    color: rgb(var(--surface-soft));
}

.punbb #isk::before {
    content: '\f002';
    font: 400 1rem/100% var(--font-icons);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0;
}

#pun #sTheme {
    height: var(--24);
}

div.checkfield .sub {
    margin-left: 0 !important;
}

div.checkfield:has(.sub) {
    margin-left: var(--24);
}

#post > .fs-box > .inputfield.required {
    order: -1;
}

#keyboard-area input {
    line-height: 100%;
}

.punbb #table-area td.selected,
.punbb #table-area td:hover {
    background: rgb(var(--accent-tea));
}

.punbb #keyboard-span input {
    margin: var(--2) !important;
    background: rgb(var(--stats-bg) / .64);
    border: none;
    font-weight: 400 !important;
    height: 20px;
    padding: 0 var(--4);
}

#pun #form-buttons table,
#pun #form-buttons tbody {
    width: 100%;
}

#pun #form-buttons td img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

#pun #form-buttons td {
    border: none;
    background: transparent;
    position: relative;
    display: inline-block;
    width: 2.4rem;
    height: 2.4rem;
    transition: all .2s ease;
}

#pun #form-buttons td:hover {
    cursor: pointer;
    color: rgb(var(--accent-tea));
}

#form-buttons table tr {
    display: flex;
    justify-content: space-between;
    gap: var(--4);
    margin-bottom: var(--8);
}

#form-buttons td::before {
    font: 400 1.2rem/100% var(--font-icons);
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
    z-index: 1;
}

#button-font::before {
    content: '\f031';
}

#button-size::before {
    content: '\f894';
}

#button-bold::before {
    content: '\f032';
}

#button-italic::before {
    content: '\f033';
}

#button-underline::before {
    content: '\f0cd';
}

#button-strike::before {
    content: '\f0cc';
}

#button-left::before {
    content: '\f036';
}

#button-right::before {
    content: '\f038';
}

#button-center::before {
    content: '\f037';
}

#button-link::before {
    content: '\f0c1';
}

#button-spoiler::before {
    content: '\f518';
}

#button-image::before {
    content: '\f302';
}

#button-video::before {
    content: '\f144';
}

#button-hide::before {
    content: '\f30d';
}

#button-quote::before {
    content: '\f27a';
}

#button-code::before {
    content: '\f121';
}

#button-color::before {
    content: '\f53f';
}

#button-table::before {
    content: '\f009';
}

#button-smile::before {
    content: '\f118';
}

#button-keyboard::before {
    content: '\f11c';
}

#button-addition::before {
    content: '\f0d7';
}

/* Дополнительные кнопки в форму ответа
-------------------------------------------------------------*/
/* кнопка вставки запомненного поста в BB-панели */
#button-savedpost,
#button-indent,
td#floatbut {
    background: none !important;
    width: 24px;
    height: 24px;
    padding: 0 3px;
    text-align: center;
    vertical-align: middle;
    cursor: pointer;
}

#button-savedpost::before,
#button-indent::before,
td#floatbut::before {
    font-family: var(--font-icons);
    font-weight: 400;
    font-size: 14px;
    line-height: 24px;
    color: rgb(var(--text-main));
}

#button-savedpost::before {
    content: "\f1da";
}

#button-savedpost:hover::before,
#button-indent:hover::before,
td#floatbut:hover::before {
    color: rgb(var(--accent-tea));
}

/* прячем родную страшную кнопку */
.saved-post-original {
    position: absolute !important;
    left: -9999px !important;
    top: auto !important;
    right: auto !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
}

/* ещё иконки в панели */

#form-buttons #button-mask,
#form-buttons #button-sticker {
    position: relative;
    font-size: 0 !important;
    background-image: none !important;
}

#form-buttons #button-mask img,
#button-indent img {
    display: none !important;
}

#form-buttons #button-mask::before,
#form-buttons #button-sticker::before {
    font-family: var(--font-icons);
    font-weight: 400;
    font-size: 1.2rem;
    line-height: 1;
}

#form-buttons #button-mask::before {
    content: '\f630';
}

#form-buttons #button-sticker::before {
    content: '\f118';
}

/* Отступы абзаца */
#button-indent::before {
    content: "\f035";
}

.post-content .bb-indent {
    display: inline-block;
    margin: 0 0 1em 1.5em;
}

/* Обтекание изображения */
td#floatbut {
    display: table-cell;
    min-width: 24px;
    background-image: none !important;
}

td#floatbut::before {
    content: "\f03c";
}

#float {
    display: none;
    position: absolute;
    z-index: 9999;

    width: max-content;
    min-width: 130px;
    padding: var(--8);

    background: rgb(var(--surface-soft));
    border: 1px solid rgb(var(--line-warm));
    border-radius: var(--radius-small);
    box-shadow: 0 6px 18px rgba(var(--forum-shadow), .16);

    color: rgb(var(--text-main));
    font-size: 11px;
    line-height: 1.2;
    text-align: center;
}

#float strong {
    display: block;
    margin-bottom: var(--8);
    font-size: 11px;
    font-weight: 700;
    color: rgb(var(--text-main));
}

#float .float-options {
    display: flex;
    justify-content: center;
    gap: var(--6);
}

#float .vibor {
    display: inline-flex;
    align-items: center;
    justify-content: center;

    width: 28px;
    height: 24px;
    padding: 0;

    border: 1px solid rgb(var(--line-warm));
    border-radius: var(--radius-small);
    background: rgb(var(--post-bg));

    cursor: pointer;
    color: rgb(var(--muted-text));
}

#float .vibor:hover {
    color: rgb(var(--accent-tea));
    border-color: rgb(var(--accent-tea));
}

#float .vibor::before {
    font-family: var(--font-icons);
    font-weight: 400;
    font-size: 14px;
    line-height: 1;
}

#float .vibor[data-float="left"]::before {
    content: "\f036";
}

#float .vibor[data-float="right"]::before {
    content: "\f038";
}

/* результат BB-кода в посте */
.post-content .bb-float {
    display: inline-block;
    max-width: 45%;
    margin: var(--8) var(--16) var(--8) 0;
}

.post-content .bb-float-left {
    float: left;
    margin-right: var(--16);
}

.post-content .bb-float-right {
    float: right;
    margin-left: var(--16);
    margin-right: 0;
}

.post-content .bb-float img {
    max-width: 100%;
    height: auto;
    display: block;
}

/* Вторая кнопка изображения */
#form-buttons #button-image2::before {
    content: '\f03e' !important;
}

/* Прокрутка */ 
::selection {
    color: rgb(var(--text-main));
    background: rgb(var(--accent-tea));
}

@supports selector(::-webkit-scrollbar) {
    *::-webkit-scrollbar-thumb {
        background: rgb(var(--text-main));
    }
    *::-webkit-scrollbar-thumb:hover {
        background: rgb(var(--accent-tea));
        cursor: default;
    }
    *::-webkit-scrollbar-track {
        background: rgb(var(--line-warm));
    }
    *::-webkit-scrollbar {
        max-width: 4px;
        max-height: 4px;
    }
}

@supports not selector(::-webkit-scrollbar) {
    * {
        scrollbar-width: thin;
        scrollbar-color: rgb(var(--text-main)) rgb(var(--line-warm));
    }
}

/**************************************************************
* 10. Профиль, просмотр профиля, подпись и права модераторов
**************************************************************/
/* Просмотр профиля */
#pun-profile #viewprofile-next {
    padding: var(--24) var(--32) !important;
    border: 1px solid rgb(var(--line-warm) / .38);
    border-radius: var(--radius-main);
    box-sizing: border-box;
    margin-top: var(--16);
    margin-bottom: var(--16);
}

#pun-profile #viewprofile-next #profilenav {
    display: none !important;
}

#pun-profile #viewprofile-next table,
#pun-profile #viewprofile-next tbody {
    display: block;
    width: 100%;
}

#pun-profile #viewprofile-next tr {
    display: grid;
    grid-template-columns: 250px minmax(0, 1fr);
    column-gap: var(--32);
    align-items: start;
    width: 100%;
}

#pun-profile #viewprofile-next td {
    display: block;
    width: auto !important;
    padding: 0 !important;
    vertical-align: top;
}

#pun-profile #profile-left {
    width: 250px !important;
    max-width: 250px;
    text-align: center;
}

#pun-profile #profile-left ul {
    margin: 0 !important;
    padding: 0 !important;
}

#pun-profile #profile-left li {
    list-style: none;
    box-sizing: border-box;
}

#pun-profile #profile-name {
    margin: 0 0 var(--4) !important;
    padding: 0 !important;
    font-weight: 700;
    text-align: center;
    line-height: 1.2;
}

#pun-profile #profile-left li:not(#profile-name) {
    margin-bottom: var(--8);
    padding: 0;
    text-transform: lowercase;
}

#pun-profile #profile-left img {
    display: block;
    width: 180px;
    max-width: 100% !important;
    height: auto !important;
    margin: var(--12) auto;
    object-fit: cover;
}

#pun-profile #profile-left #pa-edit {
    display: block;
    margin: var(--12) auto 0;
    text-align: center;
    text-transform: lowercase;
}

#pun-profile #profile-left #pa-edit a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 170px;
    padding: var(--6) var(--12);
    border-radius: var(--radius-small);
    background: rgb(var(--accent-tea) / .18);
    color: rgb(var(--accent-tea)) !important;
    font: 700 .9rem/1.2 'Inter', verdana, arial, sans-serif;
    text-decoration: none;
    cursor: pointer;
}

#pun-profile #profile-left #pa-edit a:hover {
    background: rgb(var(--accent-tea) / .3);
    color: rgb(var(--text-main)) !important;
}

#pun-profile #profile-right {
    width: auto !important;
    max-width: none;
    padding-top: var(--4) !important;
    text-align: left;
}

#pun-profile #profile-right ul {
    margin: 0 !important;
    padding: 0 !important;
}

#pun-profile #profile-right li {
    display: grid;
    grid-template-columns: 150px minmax(0, 1fr);
    column-gap: var(--16);
    align-items: start;
    margin: 0 0 var(--8);
    padding: var(--8);
    list-style: none;
    box-sizing: border-box;
    line-height: 1.35;
    text-transform: none;
    background: rgb(var(--accent-tea) / .08);
}

#pun-profile #profile-right li > span {
    display: block;
    width: auto !important;
    min-width: 0;
    color: rgb(var(--muted-text));
    font-weight: 500;
    text-transform: none;
}

#pun-profile #profile-right li > strong {
    display: block;
    min-width: 0;
    padding: 0;
    color: rgb(var(--text-main));
    font-weight: 400;
}

#pun-profile #profile-right li > strong > a,
#pun-profile #profile-right a {
    font-weight: 700;
}

#profile > .container {
    padding-left: 12em;
}

#profile #profilenav {
    display: inline-block !important;
    float: left;
    width: 12em;
    margin-left: -12em;
    padding-top: var(--16);
}

#profilenav li {
    list-style: none;
    text-transform: lowercase;
}

#profilenav li a {
    display: inline-block;
    margin-bottom: var(--2);
}

#profilenav li.isactive a {
    font-weight: 700;
    color: rgb(var(--accent-tea));
}

#pun-profile #profile-signature {
    margin-top: var(--32);
    text-align: center;
}

.punbb #profile-signature ul {
    display: block;
    margin: 0 auto;
    padding: 0;
    border: none;
}

#pun-profile #profile-signature img {
    max-width: 100%;
    height: auto;
}

.post-sig::before,
.punbb #profile-signature ul::before {
    content: '';
    display: block;
    margin: var(--16) auto var(--8);
    width: 30%;
    border-top: 1px solid rgb(var(--line-warm) / .36);
}

/* Права модераторов, как будто у них есть права */
#setmods dl dl {
    padding: 0 var(--8);
    background: rgb(var(--stats-bg) / .64);
    margin-bottom: var(--8);
    border-radius: var(--8);
}

#setmods dl dl:hover {
    background: rgb(var(--line-warm) / .38);
}

#setmods dt {
    font-weight: bold;
    display: inline-block;
    width: 20%;
    vertical-align: top;
    padding: var(--8);
}

#setmods dd {
    display: inline-block;
    padding: var(--8);
}

#setmods dd div {
    display: block;
}

/* Личные сообщения */
#pun-messages #profilenav {
    float: left;
    margin-right: var(--32);
}

#pun-messages #profilenav h2 {
    margin-left: 0;
    margin-right: 0;
}

/**************************************************************
* 11. Посты: наконец мы дошли до главного, зачем тут собрались
**************************************************************/
.post .container {
    padding: 0;
    margin: var(--16) 0;
    width: 100%;
    display: flex;
    flex-flow: wrap;
}

.post-author {
    width: var(--profile-width);
    align-self: start;
}

.post-body {
    padding-left: var(--32);
    box-sizing: border-box;
    width: calc(100% - var(--profile-width));
}

.post-links {
    width: 100%;
    text-align: right;
    margin-top: var(--16);
    padding: 0 var(--8);
   word-spacing: 8px;
}

#poll-special td {
    padding: var(--4);
}

.post-links li {
    display: inline-block;
}

.post-links li a {
    text-transform: lowercase;
}

.post-links .pl-email,
.post-links .pl-website {
    float: left;
}

.post-links .pl-email a {
    margin: 0 var(--8) 0 0;
}

.post-links li a:not(.pl-email) a {
    margin: 0 0 0 var(--4);
}

.post-links li.approve {
    margin-left: var(--4);
}

.modmenu {
    text-transform: lowercase;
}

#topic-modmenu span,
.forum ~ .modmenu span {
    float: right;
}

#topic-modmenu .container {
    text-transform: lowercase;
}

.subscribelink {
    text-align: right;
    text-transform: lowercase;
}

#topic-users-in {
    text-transform: lowercase;
}

#topic-users-in a:not(:last-child)::after {
    content: ',';
}

.post h3 {
    text-transform: lowercase;
    float: right;
    position: relative;
    z-index: 1;
    width: calc(100% - var(--profile-width) - var(--32));
    margin-top: var(--16);
    margin-bottom: var(--16);
    padding: 0 var(--8);
    border-radius: var(--radius-main);
    font-size: 1.08rem;
}

.post h3 em {
    font-style: normal;
}

.post h3 strong {
    float: right;
    font-weight: 400;
    margin-left: var(--16);
}

#pun-premoderation .post h3 span > em:last-child {
    padding-left: var(--4);
}

.post-author {
    padding: var(--8);
    margin-top: calc(var(--2) * -1);
    position: relative;
    border-radius: var(--radius-main);
    text-align: center;
    background: rgb(var(--post-bg));
    border: 1px solid rgb(var(--line-warm) / .24);
}

.post-author li {
    list-style: none;
    color: rgb(var(--text-main) / .6);
    font-size: 0.9rem;
}

.post-author li:not(:last-child) {
    padding-bottom: var(--8);
}

.post-author li:not(.pa-author, .pa-posts, .pa-respect) a {
    font-weight: normal;
    color: rgb(var(--text-main) / .6);
}

.punbb:not(#pun-post) .post-author .pa-author {
    padding-bottom: var(--4) !important;
}

.punbb .pa-author,
.punbb .pa-author a,
.punbb .pa-author strong {
    font-size: 1.2rem;
    font-weight: 700;
    color: rgb(var(--text-main));
}

.pa-title {
    font-size: 0.8rem !important;
    text-transform: lowercase;
    line-height: 120%;
}

.pa-avatar img {
    max-width: 180px;
}

.pa-posts,
.pa-respect {
    display: inline-block;
    width: 49%;
}

.pa-posts .fld-name,
.pa-respect .fld-name {
    display: block;
    font-weight: 700;
}

.pa-posts .fld-name a,
.pa-respect .fld-name a {
    color: rgb(var(--text-main) / .6);
}

/* индикатор онлайна */
.post-author .pa-online {
    display: none;
}

.post-author .pa-author {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--6);
}

/* оффлайн */
.post-author .pa-author::before {
    content: '';
    flex: 0 0 auto;
    width: 6px;
    height: 6px;
    border: 2px solid rgb(var(--surface-soft));
    border-radius: 50%;
    background: rgb(var(--muted-text) / .55);
    box-shadow: 0 0 0 1px rgb(var(--line-warm) / .32);
    box-sizing: content-box;
}

/* онлайн */
.post-author:has(.pa-online strong) .pa-author::before {
    background: rgb(var(--accent-tea));
    box-shadow:
        0 0 0 1px rgb(var(--accent-tea) / .28),
        0 0 0 0 rgb(var(--accent-tea) / .55);
    animation: profileOnlinePulse 1.8s ease-in-out infinite;
}

@keyframes profileOnlinePulse {
    0%,
    100% {
        box-shadow:
            0 0 0 1px rgb(var(--accent-tea) / .28),
            0 0 0 0 rgb(var(--accent-tea) / .45);
    }

    50% {
        box-shadow:
            0 0 0 1px rgb(var(--accent-tea) / .28),
            0 0 0 5px rgb(var(--accent-tea) / 0);
    }
}

/**************************************************************
* 12. Форма ответа и панель BB-кодов
**************************************************************/
#main-reply {
    width: 100%;
    box-sizing: border-box;
    font-size: 1rem;
}

#post-errors ul {
    padding-bottom: var(--4);
}

#post-errors li {
    list-style: none;
    padding-bottom: var(--4);
}

#post > .fs-box {
    display: flex;
    flex-direction: column;
}

#pun #post-form div.container {
    right: 0;
    margin-top: calc(var(--4) * -1);
    background: rgb(var(--surface-soft));
    border-radius: var(--radius-main);
    padding: var(--8) !important;
    top: unset;
    border: 1px solid rgb(var(--line-warm));
    overflow: hidden auto;
    max-height: 200px;
}

#size-area img {
    width: 100%;
    margin-top: -20px;
}

#size-area span,
#size-area img {
    height: 20px;
}

#size-area div {
    line-height: 120%;
}

#pun #size-area span {
    width: unset;
    height: unset;
    margin: 0;
}

#pun #addition-area div {
    height: unset;
}

#size-area div:not(:last-child),
#addition-area div:not(:last-child),
#font-area div:not(:last-child) {
    margin-bottom: var(--4);
}

/**************************************************************
* 13. Контент поста: текст, ссылки, списки, картинки и таблицы
**************************************************************/
.post-content {
    padding: var(--16);
    word-break: break-word;
    background: rgb(var(--post-bg));
    border: 1px solid rgb(var(--line-warm) / .24);
    border-radius: var(--radius-main);
}

.post-content img,
.post-sig img {
    max-width: 100%;
    vertical-align: middle;
}

.post-content p {
    line-height: 150%;
    padding: var(--4) 0;
    text-align: justify;
}

.post-box .post-content ul {
    padding: 0.4rem 0 0.8rem 2.4rem;
}

.post-box .post-content ul ul {
    padding-top: var(--4);
    padding-bottom: 0;
}

.post-content li p {
    padding: 0 0 var(--4) 0;
}

del {
    text-decoration: none;
    filter: blur(2px);
    transition: all .2s ease;
}

del:hover {
    filter: blur(0);
}

.bbuline {
    font-style: unset;
    text-decoration: underline;
    text-decoration-color: rgb(var(--accent-tea));
}

#pun .highlight-text {
    background-color: rgb(var(--accent-tea) / .6);
    padding: 0.1rem 0.2rem 0.2rem;
}

.post-content abbr[title] {
    position: relative;
    text-decoration: underline dotted rgb(var(--accent-tea));
    cursor: help;
}

.mobile-abbr-tooltip {
    position: absolute !important;
    left: 0;
    top: 0;
    bottom: auto !important;
    transform: none !important;
    box-sizing: border-box !important;
    display: none !important;
    max-width: 90vw !important;
    min-width: 220px !important;
    padding: 16px 18px !important;
    background: rgb(var(--accent-tea)) !important;
    color: #fff !important;
    border-radius: 14px !important;
    box-shadow: 0 10px 35px rgba(0, 0, 0, .35) !important;
    font-size: 16px !important;
    line-height: 1.45 !important;
    text-align: left !important;
    z-index: 999999 !important;
}

.mobile-abbr-tooltip.is-visible {
    display: block !important;
}

.post-content a {
    font-weight: 700;
}

.post-content ::marker {
    font-weight: 700;
    color: rgb(var(--accent-tea));
}

#pun .post-content hr {
    opacity: 1;
    border-top: 2px solid rgb(var(--line-warm) / .2);
    margin: var(--8) 0;
}

#pun .post-content td {
    border: none !important;
    padding: var(--8) !important;
    vertical-align: top;
}

/**************************************************************
* 14. Цитаты, код и спойлеры
**************************************************************/
.quote-box,
.code-box,
.spoiler-box {
    position: relative;
    margin: var(--12) 0;
    padding: var(--16);
    border: 1px solid rgb(var(--line-warm) / .42);
    border-radius: var(--radius-main);
    color: rgb(var(--text-main));
    overflow: hidden;
    box-sizing: border-box;
}

.quote-box {
    background: rgb(var(--quote-bg));
}

.code-box {
    background: rgb(var(--code-bg));
}

.spoiler-box {
    background: rgb(var(--spoiler-bg));
}

blockcode,
blockquote {
    overflow: hidden;
}

.quote-box cite {
    display: inline-flex;
    align-items: center;
    gap: var(--6);
    margin: 0 0 var(--8);
    padding: var(--5, 5px) var(--12) var(--6);
    border: 1px solid rgb(var(--line-warm) / .38);
    border-radius: 999px;
    background: rgb(var(--surface-soft) / .58);
    color: rgb(var(--accent-tea));
    font: 700 .92rem/1.2 'Inter', verdana, arial, sans-serif;
    font-style: normal;
    text-transform: lowercase;
}

.quote-box cite::before {
    content: '\f10d';
    font-family: var(--font-icons);
    font-weight: 400;
    font-size: .82rem;
    line-height: 1;
}

.code-box strong {
    display: block;
    margin: 0 0 var(--8);
    padding: 0;
    background: transparent;
    border: 0;
    font: inherit;
}

.code-box strong::before,
.code-box strong::after {
    display: none;
    content: none;
}

/* бля да как ты заебал */
.code-box strong a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--6);
    min-height: var(--24);
    padding: var(--5, 5px) var(--12) var(--6);
    border: 1px solid rgb(var(--line-warm) / .38);
    border-radius: 999px;
    background: rgb(var(--surface-soft) / .58);
    color: rgb(var(--accent-tea));
    font: 700 .92rem/1.2 'Inter', verdana, arial, sans-serif;
    text-transform: lowercase;
    text-decoration: none;
    cursor: pointer;
    box-sizing: border-box;
}

.code-box strong a::before {
    content: '\f0c5';
    font-family: var(--font-icons);
    font-weight: 400;
    font-size: .82rem;
    line-height: 1;
}

.code-box strong a::after {
    display: none;
    content: none;
}

.code-box strong a:hover,
.code-box strong a:focus {
    border-color: rgb(var(--accent-tea) / .55);
    background: rgb(var(--accent-tea) / .12);
    color: rgb(var(--text-main));
}

.code-box .scrollbox {
    width: 100%;
    max-height: 24vh;
    overflow: auto;
    padding: var(--10, 10px) var(--12);
    border-radius: var(--radius-small);
    box-sizing: border-box;
}

.code-box pre {
    margin: 0;
    color: rgb(var(--text-main));
    font: 500 .95rem/1.45 'Inter', arial, sans-serif;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
}

.spoiler-box {
    padding: var(--12) var(--16);
}

.spoiler-box::before,
.spoiler-box::after {
    display: none;
    content: none;
}

#pun .spoiler-box > div {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: var(--6);
    width: 100%;
    min-height: var(--32);
    margin: 0;
    padding: var(--6) var(--12);
    border: 1px solid rgb(var(--line-warm) / .38);
    border-radius: var(--radius-small);
    background: rgb(var(--surface-soft) / .58);
    color: rgb(var(--accent-tea));
    font: 700 .92rem/1.2 'Inter', verdana, arial, sans-serif;
    text-align: left;
    text-transform: lowercase;
    cursor: pointer;
    box-sizing: border-box;
}

#pun .spoiler-box > div::before {
    content: '\f06e';
    flex: 0 0 auto;
    font-family: var(--font-icons);
    font-weight: 400;
    font-size: .82rem;
    line-height: 1;
}

#pun .spoiler-box > div:hover,
#pun .spoiler-box > div:focus {
    border-color: rgb(var(--accent-tea) / .55);
    background: rgb(var(--accent-tea) / .12);
    color: rgb(var(--text-main));
}

/**************************************************************
* 15. Админка, модалки и скроллбары и всё драконье добро
**************************************************************/
a,
body #pun-admain a,
body #pun #pun-adnav ul.adsubnav a {
    text-decoration: none;
    color: rgb(var(--accent-tea));
    transition: color .2s ease;
}

a:hover,
a:focus,
body #pun-admain a:hover,
body #pun-admain a:focus,
body #pun #pun-adnav ul.adsubnav a:hover,
body #pun #pun-adnav ul.adsubnav a:focus {
    color: rgb(var(--text-main));
    text-decoration: none;
}

.title-logo-tdr {
    display: none;
}

.punbb-admin #filetable .tc3 {
    width: 10% !important;
}

#pun-adnav li {
    list-style: none;
}

#pun-adnav sup {
    display: none;
}

#pun-adnav li.isactive > a {
    color: rgb(var(--accent-tea));
    background: none;
}

#pun-report .inner,
#pun-reputation .inner,
#pun-admin-award-form .inner {
    background: rgb(var(--surface-soft));
    border-radius: var(--radius-main);
    box-shadow: 0 var(--8) var(--64) rgb(var(--text-main) / .38) !important;
}

#pun-report .container,
#pun-reputation .container,
#pun-admin-award-form .container {
    padding: 0 !important;
}

#pun-report h1,
#pun-reputation h1,
#pun-admin-award-form h1 {
    margin-top: 0;
}