:root {
    --bg: #0b1020;
    --panel: #11182b;
    --panel-2: #151f36;
    --text: #e9eefc;
    --muted: #9aa8c7;
    --line: rgba(255,255,255,.1);
    --accent: #64d2ff;
    --accent-2: #7c5cff;
    --danger: #ff6b76;
    --success: #47d18c;
    --shadow: 0 24px 80px rgba(0,0,0,.35);
    --radius: 22px;
}

* { box-sizing: border-box; }

body {
    margin: 0;
    min-height: 100vh;
    color: var(--text);
    background:
        radial-gradient(circle at 18% 8%, rgba(100, 210, 255, .18), transparent 34%),
        radial-gradient(circle at 85% 12%, rgba(124, 92, 255, .20), transparent 30%),
        linear-gradient(135deg, #080c18 0%, var(--bg) 55%, #0a1322 100%);
    font: 15px/1.5 Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
}

button, input, textarea, select { font: inherit; }

a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

.app-shell {
    width: min(1180px, calc(100% - 28px));
    margin: 0 auto;
    padding: 22px 0 54px;
}

.topbar {
    position: sticky;
    top: 14px;
    z-index: 10;
    display: flex;
    align-items: center;
    gap: 16px;
    min-height: 70px;
    padding: 12px 14px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: rgba(13, 20, 38, .78);
    backdrop-filter: blur(18px);
    box-shadow: var(--shadow);
}

.brand {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--text);
    font-weight: 800;
    letter-spacing: -.02em;
    text-decoration: none;
    white-space: nowrap;
}

.brand-mark {
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--accent), var(--accent-2));
    color: #06101e;
    font-weight: 950;
}

.main-nav {
    display: flex;
    gap: 6px;
    flex: 1;
    justify-content: center;
    overflow-x: auto;
    scrollbar-width: none;
}
.main-nav::-webkit-scrollbar { display: none; }

.main-nav a,
.logout {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 16px;
    border-radius: 999px;
    color: var(--muted);
    text-decoration: none;
    transition: .2s ease;
}

.main-nav a.active,
.main-nav a:hover,
.logout:hover {
    color: var(--text);
    background: rgba(255,255,255,.08);
}

.content { padding-top: 28px; }

.flash {
    margin: 18px 6px 0;
    padding: 14px 18px;
    border-radius: 18px;
    border: 1px solid var(--line);
    background: rgba(71, 209, 140, .12);
    color: #c6ffde;
}
.flash.error { background: rgba(255, 107, 118, .14); color: #ffd2d6; }

.page-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 20px;
    margin: 8px 0 22px;
}

h1, h2, h3, p { margin-top: 0; }
h1 { font-size: clamp(32px, 5vw, 56px); line-height: 1; letter-spacing: -.055em; margin-bottom: 10px; }
h2 { font-size: 22px; letter-spacing: -.025em; margin-bottom: 0; }
h3 { font-size: 18px; margin-bottom: 4px; }

.eyebrow {
    color: var(--accent);
    text-transform: uppercase;
    letter-spacing: .14em;
    font-weight: 800;
    font-size: 12px;
    margin-bottom: 10px;
}

.muted, .hint, small { color: var(--muted); }
.hint { font-size: 13px; margin: 12px 0 0; }
.empty { color: var(--muted); margin: 0; }

.card {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.035));
    box-shadow: var(--shadow);
    padding: 22px;
}

.wide-card { margin-top: 18px; }
.grid { display: grid; gap: 18px; }
.grid.two { grid-template-columns: repeat(2, minmax(0, 1fr)); }

.section-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 18px;
}

.badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 34px;
    height: 30px;
    padding: 0 10px;
    border: 1px solid var(--line);
    border-radius: 999px;
    color: var(--accent);
    background: rgba(100,210,255,.08);
    font-weight: 800;
}

.time-widget {
    min-width: 270px;
    padding: 16px 20px;
}
.time-widget span { display: block; color: var(--muted); font-size: 13px; }
.time-widget strong { display: block; font-size: 22px; letter-spacing: -.03em; }
.date-line { font-size: 34px; font-weight: 900; letter-spacing: -.04em; margin-bottom: 8px; }

.stack-form, .note-form, .inline-form, .server-form, .update-form {
    display: grid;
    gap: 14px;
}

.inline-form {
    grid-template-columns: 1fr 1.4fr auto;
    align-items: end;
}

.server-form {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: end;
}

.server-form .span-2 { grid-column: span 2; }
.server-form.compact { grid-template-columns: repeat(2, minmax(0, 1fr)); margin-top: 14px; }

.note-form {
    grid-template-columns: 1fr 2fr auto;
    align-items: start;
    margin-bottom: 18px;
}

label { display: grid; gap: 7px; color: var(--muted); font-weight: 700; font-size: 13px; }

input, textarea, select {
    width: 100%;
    border: 1px solid rgba(255,255,255,.13);
    border-radius: 15px;
    padding: 13px 14px;
    color: var(--text);
    background: rgba(4, 8, 17, .45);
    outline: none;
    transition: .18s ease;
}

textarea { resize: vertical; }
select { appearance: none; background-image: linear-gradient(45deg, transparent 50%, var(--muted) 50%), linear-gradient(135deg, var(--muted) 50%, transparent 50%); background-position: calc(100% - 20px) 50%, calc(100% - 14px) 50%; background-size: 6px 6px, 6px 6px; background-repeat: no-repeat; padding-right: 38px; }
select option { color: #101827; background: #ffffff; }
input:focus, textarea:focus, select:focus {
    border-color: rgba(100,210,255,.8);
    box-shadow: 0 0 0 4px rgba(100,210,255,.12);
}

.btn, .icon-btn {
    border: 0;
    border-radius: 15px;
    padding: 13px 18px;
    min-height: 46px;
    color: var(--text);
    background: rgba(255,255,255,.1);
    cursor: pointer;
    font-weight: 800;
    transition: .2s ease;
}

.btn:hover, .icon-btn:hover { transform: translateY(-1px); background: rgba(255,255,255,.15); }
.btn.primary { color: #06101e; background: linear-gradient(135deg, var(--accent), #b6ecff); }
.icon-btn { min-height: 38px; padding: 9px 12px; font-size: 13px; }
.icon-btn.danger { color: #ffd4d8; background: rgba(255,107,118,.14); }

.resource-pills { display: flex; flex-wrap: wrap; gap: 10px; }
.resource-pills a {
    padding: 10px 14px;
    border: 1px solid rgba(100,210,255,.25);
    border-radius: 999px;
    background: rgba(100,210,255,.09);
    text-decoration: none;
    color: var(--text);
}

.resource-tiles {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
    gap: 14px;
}
.resource-tile {
    position: relative;
    min-height: 116px;
    border: 1px solid rgba(100,210,255,.22);
    border-radius: 22px;
    background:
        radial-gradient(circle at 14% 16%, rgba(100,210,255,.16), transparent 32%),
        linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.035));
    box-shadow: 0 18px 46px rgba(0,0,0,.16);
    transition: transform .18s ease, border-color .18s ease, opacity .18s ease, background .18s ease;
    overflow: hidden;
}
.resource-tile:hover {
    transform: translateY(-2px);
    border-color: rgba(100,210,255,.55);
}
.resource-tile a {
    display: grid;
    align-content: space-between;
    gap: 16px;
    min-height: 116px;
    padding: 20px;
    color: var(--text);
    text-decoration: none;
}
.resource-tile strong {
    font-size: 18px;
    letter-spacing: -.025em;
}
.resource-tile span:not(.drag-handle) {
    display: block;
    overflow: hidden;
    color: var(--muted);
    font-size: 13px;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.resource-tiles.is-sortable .resource-tile {
    cursor: grab;
}
.resource-tiles.is-sortable .resource-tile:active {
    cursor: grabbing;
}
.resource-tile.is-dragging {
    opacity: .45;
    transform: scale(.98);
    border-style: dashed;
}
.drag-handle {
    position: absolute;
    top: 12px;
    right: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 10px;
    color: var(--muted);
    background: rgba(255,255,255,.07);
    pointer-events: none;
    letter-spacing: -4px;
}
.error-text { color: var(--danger); }

.cards-list, .table-list, .server-list { display: grid; gap: 14px; }
.mini-card, .row-card, .server-card {
    border: 1px solid var(--line);
    border-radius: 18px;
    background: rgba(5, 10, 22, .35);
    padding: 18px;
}

.mini-card-head, .server-top, .row-card {
    display: flex;
    gap: 14px;
    justify-content: space-between;
    align-items: flex-start;
}

.row-card { flex-wrap: wrap; }
.row-main { display: flex; align-items: center; gap: 14px; min-width: 260px; }
.order {
    display: grid;
    place-items: center;
    width: 46px;
    height: 46px;
    border-radius: 15px;
    background: rgba(255,255,255,.08);
    color: var(--muted);
    font-weight: 900;
}
.row-actions { display: flex; gap: 8px; }
.full { width: 100%; }

.edit-box {
    margin-top: 14px;
    border-top: 1px solid var(--line);
    padding-top: 12px;
}
.edit-box summary {
    cursor: pointer;
    color: var(--accent);
    font-weight: 800;
}


.inline-ip {
    display: inline-flex;
    align-items: center;
    max-width: 100%;
    min-height: 28px;
    padding: 4px 10px;
    border: 1px solid var(--line);
    border-radius: 999px;
    color: var(--accent);
    background: rgba(100,210,255,.08);
    font-size: 13px;
    letter-spacing: 0;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.secret-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 10px;
    margin-top: 16px;
}
.secret-grid button {
    text-align: left;
    border: 1px solid var(--line);
    border-radius: 16px;
    padding: 13px;
    color: var(--text);
    background: rgba(255,255,255,.05);
    cursor: pointer;
}
.secret-grid button:hover { border-color: rgba(100,210,255,.5); }
.secret-grid span { display: block; color: var(--muted); font-size: 12px; margin-bottom: 5px; }
.secret-grid b {
    display: block;
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: break-word;
    white-space: normal;
}
.secret-grid .copied { color: var(--success); }


.server-tiles {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 320px), 1fr));
    gap: 14px;
}
.server-tile {
    position: relative;
    min-width: 0;
    min-height: 132px;
    padding: 0;
    overflow: hidden;
    transition: transform .18s ease, border-color .18s ease, opacity .18s ease, background .18s ease;
}
.server-tile:hover {
    transform: translateY(-2px);
    border-color: rgba(100,210,255,.5);
}
.server-tiles.is-sortable .server-tile { cursor: grab; }
.server-tiles.is-sortable .server-tile:active { cursor: grabbing; }
.server-tile.is-dragging {
    opacity: .45;
    transform: scale(.98);
    border-style: dashed;
}
.server-tile-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
    min-height: 132px;
    padding: 20px 20px 12px;
}
.server-tile-main {
    flex: 1 1 auto;
    min-width: 0;
}
.server-tile-main h3 {
    max-width: 100%;
    margin-bottom: 12px;
    overflow-wrap: anywhere;
    word-break: break-word;
}
.server-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    min-width: 0;
}
.server-meta a,
.server-meta span {
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: break-word;
}
.server-delete-form {
    flex: 0 0 auto;
    margin-left: auto;
}
.server-tile .drag-handle {
    position: static;
    flex: 0 0 28px;
    margin-top: 0;
    background: rgba(255,255,255,.07);
}
.server-details {
    padding: 0 20px 20px;
    border-top: 1px solid var(--line);
}
.server-details[hidden] { display: none; }
.server-tile.is-open {
    grid-column: span 2;
    border-color: rgba(100,210,255,.48);
}
.server-tile.is-open .server-tile-head { min-height: auto; }
.server-tile::after {
    content: 'Нажмите, чтобы открыть доступы';
    display: block;
    padding: 0 20px 16px;
    color: var(--muted);
    font-size: 12px;
    pointer-events: none;
}
.server-tile.is-open::after { content: 'Нажмите по верхней части, чтобы скрыть доступы'; }
.server-tile.is-open .server-details::before {
    content: '';
    display: block;
    height: 16px;
}
.comment {
    margin: 14px 0 0;
    padding: 12px 14px;
    border-radius: 14px;
    background: rgba(255,255,255,.055);
    color: #d6def6;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.clean-list, .timeline ul { margin: 0; padding-left: 20px; color: #d6def6; }
.clean-list li + li, .timeline li + li { margin-top: 7px; }
.version-number { font-size: 48px; font-weight: 950; letter-spacing: -.06em; margin-bottom: 10px; }

.update-form { grid-template-columns: 1fr auto; align-items: end; }
.timeline { display: grid; gap: 14px; }
.timeline article {
    position: relative;
    padding: 16px 16px 16px 20px;
    border-left: 3px solid var(--accent);
    border-radius: 14px;
    background: rgba(255,255,255,.045);
}
.timeline strong { font-size: 19px; margin-right: 10px; }
.timeline span { color: var(--muted); }
.timeline ul { margin-top: 8px; }

.history-panel summary {
    display: flex;
    align-items: center;
    gap: 10px;
    list-style: none;
    cursor: pointer;
    user-select: none;
}
.history-panel summary::-webkit-details-marker { display: none; }
.history-panel summary::before {
    content: '▸';
    color: var(--accent);
    font-weight: 900;
    transition: transform .18s ease;
}
.history-panel[open] summary::before { transform: rotate(90deg); }
.history-summary-title {
    font-size: 22px;
    font-weight: 900;
    letter-spacing: -.03em;
}
.history-summary-hint {
    margin-left: auto;
    color: var(--muted);
    font-size: 13px;
}
.history-panel .timeline { margin-top: 14px; }
.pagination {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 16px;
}
.pagination a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 38px;
    min-height: 38px;
    padding: 0 12px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: rgba(255,255,255,.055);
    color: var(--text);
    font-weight: 900;
}
.pagination a:hover,
.pagination a.active {
    border-color: rgba(100,210,255,.55);
    background: rgba(100,210,255,.12);
    color: var(--accent);
}


.login-layout {
    display: grid;
    place-items: center;
    min-height: calc(100vh - 150px);
}
.login-card { width: min(460px, 100%); }
.login-card h1 { font-size: 40px; }

.small-link { font-weight: 800; }

@media (max-width: 900px) {
    .topbar { border-radius: 24px; flex-wrap: wrap; }
    .brand { width: 100%; }
    .main-nav { justify-content: flex-start; width: calc(100% - 80px); }
    .logout { margin-left: auto; }
    .page-head, .mini-card-head, .server-top { align-items: stretch; flex-direction: column; }
    .grid.two, .inline-form, .note-form, .server-form, .server-form.compact, .secret-grid, .update-form { grid-template-columns: 1fr; }
    .server-tile.is-open { grid-column: auto; }
    .server-tile-head { flex-wrap: wrap; }
    .server-delete-form { width: 100%; margin-left: 0; }
    .server-delete-form .icon-btn { width: 100%; }
    .history-panel summary { flex-wrap: wrap; }
    .history-summary-hint { width: 100%; margin-left: 28px; }
    .server-form .span-2 { grid-column: auto; }
    .time-widget { min-width: unset; width: 100%; }
}

body[data-theme="light"] {
    --bg: #eef3fb;
    --panel: #ffffff;
    --panel-2: #f7faff;
    --text: #111827;
    --muted: #657084;
    --line: rgba(17,24,39,.12);
    --accent: #1174d8;
    --accent-2: #6d5dfc;
    --danger: #d93343;
    --success: #147a4c;
    --shadow: 0 22px 60px rgba(16, 24, 40, .12);
    background:
        radial-gradient(circle at 18% 8%, rgba(17, 116, 216, .14), transparent 34%),
        radial-gradient(circle at 85% 12%, rgba(109, 93, 252, .13), transparent 30%),
        linear-gradient(135deg, #f8fbff 0%, var(--bg) 58%, #e9f0fb 100%);
}

body[data-theme="light"] .topbar {
    background: rgba(255,255,255,.82);
}

body[data-theme="light"] .card {
    background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(247,250,255,.9));
}

body[data-theme="light"] input,
body[data-theme="light"] textarea,
body[data-theme="light"] select {
    color: var(--text);
    background: rgba(255,255,255,.86);
    border-color: rgba(17,24,39,.14);
}

body[data-theme="light"] .mini-card,
body[data-theme="light"] .row-card,
body[data-theme="light"] .server-card {
    background: rgba(255,255,255,.72);
}

body[data-theme="light"] .resource-tile,
body[data-theme="light"] .server-tile {
    background:
        radial-gradient(circle at 14% 16%, rgba(17,116,216,.12), transparent 32%),
        linear-gradient(180deg, rgba(255,255,255,.94), rgba(247,250,255,.82));
    box-shadow: 0 18px 46px rgba(16,24,40,.10);
}

body[data-theme="light"] .main-nav a.active,
body[data-theme="light"] .main-nav a:hover,
body[data-theme="light"] .logout:hover,
body[data-theme="light"] .btn,
body[data-theme="light"] .icon-btn,
body[data-theme="light"] .order,
body[data-theme="light"] .secret-grid button,
body[data-theme="light"] .comment,
body[data-theme="light"] .timeline article {
    background: rgba(17,24,39,.055);
}

body[data-theme="light"] .comment,
body[data-theme="light"] .clean-list,
body[data-theme="light"] .timeline ul {
    color: #25324a;
}

body[data-theme="light"] .flash {
    background: rgba(20, 122, 76, .10);
    color: #12613f;
}
body[data-theme="light"] .flash.error {
    background: rgba(217, 51, 67, .10);
    color: #a52532;
}

.theme-settings-form {
    display: grid;
    grid-template-columns: minmax(220px, 320px) auto;
    align-items: end;
    gap: 14px;
}

@media (max-width: 900px) {
    .theme-settings-form { grid-template-columns: 1fr; }
}

.user-pill,
.role-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0 12px;
    border: 1px solid var(--line);
    border-radius: 999px;
    color: var(--muted);
    background: rgba(255,255,255,.06);
    font-size: 12px;
    font-weight: 800;
    white-space: nowrap;
}

.role-badge {
    min-height: 28px;
    margin-left: 8px;
    color: var(--accent);
}

select[multiple] {
    min-height: 128px;
    background-image: none;
    padding-right: 14px;
}

select[multiple] option {
    padding: 7px 8px;
}

@media (max-width: 900px) {
    .user-pill { width: 100%; justify-content: flex-start; }
}

/* Settings grouped categories */
.settings-page-head { margin-bottom: 18px; }
.settings-category-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin-bottom: 22px;
}
.settings-nav-card {
    display: grid;
    gap: 7px;
    min-height: 120px;
    width: 100%;
    padding: 18px;
    border: 1px solid var(--line);
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.035));
    color: var(--text);
    text-align: left;
    text-decoration: none;
    box-shadow: var(--shadow);
    cursor: pointer;
    font: inherit;
    transition: .2s ease;
}
.settings-nav-card span {
    width: fit-content;
    min-width: 42px;
    padding: 5px 10px;
    border: 1px solid var(--line);
    border-radius: 999px;
    color: var(--accent);
    font-weight: 900;
    font-size: 12px;
}
.settings-nav-card strong { font-size: 19px; letter-spacing: -.02em; }
.settings-nav-card small { color: var(--muted); font-weight: 700; }
.settings-nav-card:hover,
.settings-nav-card.is-active { transform: translateY(-2px); border-color: rgba(100,210,255,.45); }
.settings-nav-card.is-active { background: linear-gradient(180deg, rgba(100,210,255,.18), rgba(255,255,255,.045)); }
.settings-helper { margin: -4px 4px 18px; color: var(--muted); font-weight: 700; }
.settings-panel { display: none; }
.settings-panel.is-active { display: block; }

.settings-category {
    margin-top: 22px;
    scroll-margin-top: 22px;
}
.settings-category-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 20px;
    margin-bottom: 14px;
    padding: 0 4px;
}
.settings-category-head h2 { font-size: 28px; }
.settings-category-head .muted { max-width: 620px; text-align: right; }

.settings-split {
    display: grid;
    grid-template-columns: minmax(280px, .82fr) minmax(0, 1.38fr);
    gap: 18px;
    align-items: start;
}
.settings-split.single { grid-template-columns: minmax(0, 1fr); }
.settings-block { min-width: 0; }
.settings-block-title {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    margin-bottom: 18px;
}
.settings-block-title h3 { margin: 0; }
.vertical-form {
    grid-template-columns: 1fr;
    align-items: stretch;
}
.vertical-form .span-2 { grid-column: auto; }
.settings-card-list {
    display: grid;
    gap: 14px;
    max-height: 860px;
    overflow: auto;
    padding-right: 4px;
}
.settings-list-card { box-shadow: none; }
.settings-role-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 16px;
}
.settings-role-grid div {
    display: grid;
    gap: 4px;
    min-height: 74px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: rgba(255,255,255,.045);
}
.settings-role-grid strong { color: var(--text); font-size: 13px; }
.settings-role-grid span { color: var(--muted); font-size: 12px; line-height: 1.35; }

body[data-theme="light"] .settings-nav-card {
    background: linear-gradient(180deg, rgba(255,255,255,.94), rgba(246,248,252,.94));
}
body[data-theme="light"] .settings-nav-card.is-active {
    background: linear-gradient(180deg, rgba(71, 132, 255, .14), rgba(255,255,255,.96));
}
body[data-theme="light"] .settings-role-grid div { background: rgba(15, 23, 42, .035); }

@media (max-width: 1100px) {
    .settings-category-grid { grid-template-columns: 1fr; }
    .settings-split { grid-template-columns: 1fr; }
    .settings-category-head { align-items: flex-start; flex-direction: column; }
    .settings-category-head .muted { text-align: left; }
}

@media (max-width: 760px) {
    .settings-role-grid { grid-template-columns: 1fr; }
    .settings-nav-card { min-height: auto; }
}
