/* Основные цвета */
:root {
    --main: #37a1d3;
    --dark-main: #18516C;
    --light-main: #6DC4F1;
    --semi-light-main: #C1E8FE;
    --secondary: #256482;
    --high-light-main: #d6f5ff;
    --black: #18191D;
    --dark-gray: #202229;
    --light-gray: #31343D;
    --white: #EEEEEF;
    --white-gray: #B4B6BD;
    --green: #34D399;
    --purple: #8b34d3;
    --red: #d33434;
    --color-panel: #3f3f4e75;
    --modal-color: #4d4f526e;
    --input-color: #31343d9f;
    --panel-border-color: #ffffff0f;
    --blur: blur(64px);
}

/* Fonts*/
body { font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol"; font-optical-sizing: auto; font-style: normal; }
@font-face { font-family: 'Accid'; src: url('/static/fonts/accid/accid.ttf') format('truetype'); }
@font-face { font-family: 'Finlandica'; src: url('/static/fonts/finlandica/finlandica-regularWeb.ttf') format('truetype'), url('/static/fonts/finlandica/finlandica-regularWeb.woff') format('woff'); }

/* Scrollbar */
* { scrollbar-color: var(--light-main) var(--dark-gray); scrollbar-width: thin;}
:root { scrollbar-gutter: stable; }
html { scroll-behavior: smooth;}

html {
    min-height: 100%;
}

/*Body*/
body {
    background: linear-gradient(to bottom, #0A2735 0%, #0A1319 50%, var(--black)  100%);
    color: var(--white); 
    line-height: 1.6; 
    background-size: cover;
}
.main_container { max-width: 1200px; margin: 0 auto; padding: 0 16px;}

/*Navbar-header*/
.mobile-menu-toggle { display: none;}
.navbar {
    height: 72px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid var(--light-gray);
    background-color: var(--black);
    padding: 0 24px;
    position: sticky;
    top: 0;
    z-index: 999;
}
.navigation_menu { display: flex; justify-content: space-between;}
.navigation_menu a { text-decoration: none; color: var(--white); padding: 8px; margin: 0 20px;}
.navigation_menu a:hover { color: var(--white-gray);}
.navbar .h1 { font-size: 32px; font-weight: 700; display: flex; align-items: center; color: var(--main); }
.logo { max-height: 48px; padding-right: 8px;}
.navbar_profile_block { display: flex; align-items: center; gap: 16px;}
.links { display: flex; gap: 16px;}
.links a { display: flex; align-items: center;}
.navbar_profile { position: relative; cursor: pointer; text-align: center; display: flex; align-items: center; gap: 4px; border: 1px solid var(--secondary); border-radius: 8px; padding: 4px 8px;}
.navbar_profile:hover { color: var(--white-gray); }

/* Footer */
.site-footer { border-top: 1px solid var(--panel-border-color); padding-top: 28px; margin-top: 40px; }
.footer-inner { display: grid; gap: 16px; grid-template-columns: 1fr; }
@media (min-width: 900px) { .footer-inner { grid-template-columns: 2fr 1fr 1fr 1fr; } }
.footer-title { font-weight: 700; margin: 0 0 10px; }
.footer-links { display: grid; gap: 8px; }
.footer-links a { color: #D9DBE3; text-decoration: none; }
.footer-links a:hover { color: #fff; }
.footer-text { color: #C9CBD2; }
.footer-bottom { display: flex; gap: 12px; align-items: center; justify-content: space-between; padding: 16px 0 28px; border-top: 1px solid var(--panel-border-color); margin-top: 16px; }
.copy, .made { color: #A5A7B0; font-size: 13px; }

/* Dropdown profile menu */
.profile-dropdown {
    visibility: hidden;
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    background-color: var(--dark-gray);
    min-width: 140px;
    border: 1px solid var(--dark-main);
    border-radius: 6px;
    z-index: 100;
    transition:
        opacity 0.2s ease,
        transform 0.2s ease,
        visibility 0.2s ease;
    opacity: 0;
    transform: translateY(-10px);
    pointer-events: none;
}
.profile-dropdown.show { visibility: visible; opacity: 1; transform: translateY(0); pointer-events: auto;}
.profile-dropdown a { color: var(--white); padding: 10px; display: block; text-decoration: none; }
.profile-dropdown a:hover { background-color: var(--light-gray); }

/* Buttons */
.btn {cursor: pointer; padding: 8px 16px; border-radius: 8px; text-decoration: none; font-weight: 600; }
.btn-primary { 
  background: var(--main); color: var(--black); border: none; 
  box-shadow: 0 4px 14px rgba(191, 233, 243, 0.2), inset 0 1px 0 rgba(255,255,255,0.25);
}
.btn-danger { border: 1px solid var(--red); background: var(--red);color: var(--white); }
.btn-danger:hover { transform: translateY(-1px); }
.btn-primary:hover { transform: translateY(-1px); background: var(--light-main); }
.btn-secondary { background: var(--panel-border-color); color: var(--main); border: 1px solid rgba(255,255,255,0.08); font-weight: 400; }
.btn-secondary:hover { background: rgba(255,255,255,0.1); }
.btn-wide { width: 100%; text-align: center; box-sizing: border-box;}
.btn-disabled {background: var(--panel-border-color); color: var(--main); border: 1px solid rgba(255,255,255,0.08);}
.btn-disabled:hover { background: rgba(255,255,255,0.1); }
.btn-center {margin: 0 auto;}
.tab-button.active { display: none;}
.btn-close { color: #aaa; position: absolute; right: 15px; top: 15px; font-size: 28px; font-weight: bold; cursor: pointer;}
.btn-close:hover,
.btn-close:focus { color: var(--main); text-decoration: none; }
.button-flex-group { display: flex; gap: 10px; }
.form-actions {margin-top: 16px;}


/* Containers */
.container { max-width: 1200px; margin: 0 auto; padding: 0 16px; }
.section { position: relative; z-index: 1; padding: 80px 0; }
.section-padding_0 { position: relative; z-index: 1; padding: 24px 0; }
.section-title {text-transform:uppercase; font-size: 48px; line-height: 1.6; margin: 0 0 12px; text-align: center; }
.section-lead { margin: 0 auto 48px; color: var(--white-gray); text-align: center; }
@media (min-width: 700px) { .section-lead{ max-width: 60%;} }
.section-muted { text-align: center; color: var(--white-gray) }
.subsection-title {text-transform:uppercase; text-align: center; font-size: 22px; margin: 16px auto 32px;}
.row { display: flex; gap: 16px;}
.w-100 { width: 100%;}
.flex-center{ display: flex; align-items: center;}
.card { padding: 16px; background: var(--color-panel); backdrop-filter: var(--blur); border: 1px solid var(--panel-border-color); border-radius: 12px; margin-bottom: 14px; box-sizing: border-box;}
.flex-horizontal { display: flex; justify-content: space-between;}
.profile_image_container { display:flex; flex-direction: column; align-items: center; }
.input_container { position: relative; display: inline-block; width: 100%; }
.input_container i { position: absolute; padding-top: 12px; top: 50%; right:0; cursor: pointer; z-index: 2; }

/* Grids */
.grid-1fr { display: grid; grid-template-columns: 1fr; }
.grid-2fr { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 700px) { .grid-2fr,.grid-3fr{ grid-template-columns: 1fr;} }
.grid-3fr { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; }

/* Modals */
.modal_container{ display: none; position: fixed; z-index: 1000; left: 0; top: 0; width: 100%; height: 100%; overflow: auto; background-color: rgba(0,0,0,0.4); align-items: center;  justify-content: center; }
.modal-content { background: var(--dark-gray); backdrop-filter: var(--blur); padding: 24px; border: 1px solid var(--white-gray); max-width: 50vw; min-width: 25vw; border-radius: 8px; position: relative;}

/* Tabs */
.auth-tabs { display: flex; }
.auth-tab-content { display: none; }
.auth-tab-content.active { display: block; }

/* hr */
.hr_small {background:linear-gradient(90deg, var(--main), var(--secondary)); height: 4px; border: 0; border-radius: 16px; max-width: 128px;}
.hr_full {background:linear-gradient(90deg, var(--main), var(--secondary)); height: 1px; border: 0; border-radius: 90%;}
.hr_dark { background:var(--black); width: 100%; height: 1px; border: 0; border-radius: 90%;}

/* Helpers */
.mt-1 { margin-top: 1em; }
.mt-2 { margin-top: 2em; }
.mb-1 { margin-bottom: 1em; }
.mb-2 { margin-bottom: 2em; }
.error-message { color: var(--red); display: none; margin-bottom: 10px;}
.scrollable-80vh {overflow-y: auto; max-height: 80vh;}
.scrollable-40vh {overflow-y: auto; max-height: 40vh;}
.scroll_up_btn { cursor: pointer; z-index: 1000; padding: 16px 16px 12px 16px; position: fixed; bottom: 64px; right: 64px; border-radius: 50%; background: var(--panel-border-color); color: var(--main); border: 1px solid rgba(255,255,255,0.08);}
.scroll_up_btn:hover { background-color: var(--main); }
.scroll_up_btn:hover svg { fill: var(--black); }
.pointer { cursor: pointer; }
.pointer-animation:hover { transform: translateX(4px); border-color: var(--dark-main); }
.action_block { display: flex; justify-content: flex-end; }
.member-avatar { width: 48px; height: 48px; border-radius: 50%; background-size: cover;  background-position: center;  margin-right: 12px; background-color: var(--white-gray);}

/* Statuses */
.status_grn { background-color: var(--green); color:#0B0D12; border-color:var(--green);}
.status_red { background-color: var(--red); color:#D9DBE3; border-color:var(--red);}
.status_yllw { background: rgba(255,215,0,0.1); color: #FFD700; border: 1px solid rgba(255,215,0,0.25);}


/* Text */
.main-colored-text { color: var(--main);}
label { display: block; padding: 8px 0; color: var(--white); font-weight: bold;}

/* Inputs */
.checkbox-container { display: flex; align-items: center; padding: 16px 0;}
.checkbox-container input { margin-right: 10px;}
input[type="radio"]{ margin-right: 16px;}

input[type="text"],
input[type="password"],
input[type="email"],
input[type="date"],
input[type="number"],
input[type="datetime-local"],
input[type="file"],
.textarea,
select {
    box-sizing: border-box;
    width: 100%;
    padding: 10px;
    border: 1px solid var(--dark-gray);
    border-radius: 4px;
    background-color: var(--input-color);
    color: var(--white);
    font-size: 16px;
    resize: none;
}

input[disabled]{ background-color: var(--dark-gray); color: var(--white-gray); }

.input_container input {
    width: 100%;
    padding-right: 40px;
    box-sizing: border-box;
}

input:focus,
textarea:focus,
select:focus { outline: none; border-color: var(--dark-main); }

.group-radio input[type=radio]{ display: none; }
.group-radio label {
    display: flex;
    flex-direction: column;
    height: 100%; 
    width: 100%; 
    box-sizing: border-box; 
	cursor: pointer;
	border: 1px solid var(--white);
	border-radius: 12px;
	user-select: none;
    background-color: var(--dark-gray);
    align-items: center;
    justify-content: center;
}
.group-radio input[type=radio]:checked + label {
    border-color: var(--main);
    color: var(--main);
    position: relative;
    padding-right: 40px;
}

.group-radio input[type=radio]:checked + label::after {
    content: "✓";
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 18px;
    color: var(--main);
}

.group-radio label:hover {
    border-color: var(--dark-main);
}
@counter-style marker-font { system: cyclic; symbols: "person"; suffix: " "; }
.player-markers { list-style-type: marker-font; }
.player-markers li::marker { font-family: 'Material Icons';	color: var(--white); font-size: 14px; }

/*FAQ*/
.faq-item { border: 3px solid var(--dark-gray); border-radius: 5px; margin-bottom: 10px; overflow: hidden; }

/* Tables */
table {
    width: 100%;
    border-collapse: collapse;
    margin: 20px 0;
    background-color: var(--light-gray);
    border: 1px solid var(--dark-main);
}

th { background-color: var(--dark-main); color: var(--black); padding: 12px; text-align: left; font-weight: bold;}
td { padding: 10px 12px; border-bottom: 1px solid var(--dark-main);}
tr:nth-child(even) { background-color: rgba(255, 215, 0, 0.05); }
tr:hover { background-color: rgba(255, 215, 0, 0.1); }
table td, table th { vertical-align: middle; }

/* Statuses */
.status-open { color: var(--green); font-weight: bold; }
.status-closed { color: var(--red); font-weight: bold; }


/* Pagination */
.pagination-wrapper { display: flex; justify-content: flex-end; }
.pagination { margin-left: auto; padding: 10px; }


/* Забыл пароль */
.forgot-password-link { margin-top: 8px; text-align: center;}
.forgot-password-link a { color: var(--white-gray); text-decoration: none;}
.forgot-password-link a:hover { text-decoration: underline;}

/* Стили для раскрывающихся фильтров */
.collapsible-filters {
    margin-bottom: 20px;
    border: 1px solid var(--main);
    border-radius: 4px;
    overflow: hidden;
}

.collapsible-header {
    padding: 10px 15px;
    background-color: var(--main);
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    user-select: none;
    color: var(--black);
    font-weight: 600;
}

.collapsible-header:hover {
    background-color: var(--light-main);
}

.collapsible-content {
    background-color: var(--dark-gray);
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease-out;
    padding: 0 15px;
}

.collapsible-content.expanded {
    max-height: 1000px;
    padding: 15px;
    transition: max-height 0.5s ease-in;
}

.toggle-icon {
    transition: transform 0.3s ease;
}

.toggle-icon.rotated {
    transform: rotate(180deg);
}

/*member_list & user_list*/
.user_list {
    list-style: none;
    padding: 0;
}

.text_group_flex{
    display: flex;
    flex-direction: column;
}

.edit_btn {
    padding: 12px;
    text-align: center;
    margin-right: 8px;
    color: var(--black);
    background: var(--main);
    border-radius: 8px;
}

.member-card {
    background: var(--light-gray);
    border-radius: 8px;
    padding: 15px;
    margin-bottom: 10px;
    position: relative;
    list-style-type: none;
}

.user-nickname{
    font-weight: bold;
    font-size: 1.2em;
    margin-bottom: 5px;
    color: var(--main);
    display: flex;
    align-items: center;
}

.member-nickname {
    font-weight: bold;
    font-size: 1.2em;
    margin-bottom: 5px;
}

.user-info{
    display: flex;
    gap: 30px;
}

.member-info {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.member-role {
    position: absolute;
    top: 15px;
    right: 15px;
    background: var(--green);
    color: var(--black);
    padding: 3px 8px;
    border-radius: 4px;
    font-size: 0.8em;
}
.member-role.superadmin {
    border: 2px solid var(--red);
}
.member-role.admin {
    background: var(--green);
}
.member-role.moderator {
    background: var(--purple);
    color: var(--white);
}
.member-role.clan_member {
    background: var(--main);
    color: var(--white);
}
.member-role.clan_friend {
    background: var(--light-gray);
    color: var(--white);
}

.user-role {
    background: var(--green);
    color: var(--dark-gray);
    margin: 0 6px;
    border-radius: 4px;
    font-size: 0.8em;
    text-align: center;
    padding: 0 4px;
}


/* Стили для заявок в клан */

.join_request{
    text-align: center;
    font-size: 18px;
    width: 100%;
    background-color: var(--light-main);
    border-radius: 8px;
    padding: 8px 0;
    color: var(--black);
}

#applicant_know_from_optional {
    transition: all 0.3s ease;
    margin-top: 5px;
}

label[for="applicant_know_from_optional"] {
    margin-top: 10px;
}

/* Cookie modal */
.cookie-consent {
    position: fixed;
    bottom: 20px;
    left: 0;
    max-width: 90%;
    margin-left: 16px;
    padding: 8px;
    background: var(--light-gray);
    border: 1px solid var(--main);
    border-radius: 16px;
    color: var(--white);
    z-index: 1000;
    display: none;
    box-sizing: border-box;
}

.cookie-consent p {
    max-width: 98%;
}


/*Карточка статистики*/
.user_stats{
    display: flex;
    flex-direction: column;
    gap: 32px;
}


.profile_container {
    display: flex;
    gap: 16px;
}

.admin-actions{
  display: flex;
  gap: 8px;
}

/* Заявки в клан */
.join_requests_actual {
    padding: 16px;
    border: 2px solid var(--main);
    border-radius: 8px;
    margin: 16px 0;
    background-color: var(--light-gray);
}

.join_request_card  {
    padding: 16px;
    border: 2px solid var(--main);
    border-radius: 8px;
    margin: 16px 0;
    background-color: var(--dark-gray);
    display: flex;
    justify-content: space-between;
}

.join_request_card_control
{
    display: flex;
    justify-content: center;
    flex-direction: column;
    min-width: 20%;
    align-items: center;
}

.join_request_card_control_buttons{
    display: flex;
    gap: 4px;
    justify-content: flex-end;
}