/*
  Copyparty custom theme: "Figure Skating Club Dark v2"
  Mood: soft dark, blue/gold accents, friendlier for parents/clubs.
  Intended as an override stylesheet loaded through html-head.
  Best with a built-in dark/flat theme as the base.
*/

:root {
  --cp-bg: #0d1420;
  --cp-bg-2: #111a28;
  --cp-bg-3: #142032;
  --cp-panel: rgba(19, 28, 42, 0.94);
  --cp-panel-2: rgba(24, 35, 52, 0.96);
  --cp-panel-3: rgba(30, 44, 66, 0.98);
  --cp-topbar: rgba(12, 19, 31, 0.88);
  --cp-topbar-2: rgba(20, 30, 47, 0.92);
  --cp-border: rgba(124, 156, 196, 0.24);
  --cp-border-strong: rgba(154, 191, 238, 0.32);
  --cp-border-soft: rgba(255, 255, 255, 0.06);
  --cp-text: #ecf4ff;
  --cp-text-soft: #c6d6ea;
  --cp-text-faint: #92a6bf;
  --cp-link: #9fd0ff;
  --cp-link-hover: #d3e9ff;
  --cp-accent: #d9b76f;
  --cp-accent-2: #efd494;
  --cp-accent-soft: rgba(217, 183, 111, 0.14);
  --cp-blue-soft: rgba(111, 169, 231, 0.18);
  --cp-row-hover: rgba(159, 208, 255, 0.08);
  --cp-row-alt: rgba(255, 255, 255, 0.02);
  --cp-shadow: 0 18px 50px rgba(0, 0, 0, 0.34);
  --cp-glow: 0 0 0 3px rgba(217, 183, 111, 0.15);
  --cp-radius: 18px;
  --cp-radius-lg: 22px;
  --cp-radius-sm: 12px;
  --cp-font-main: Inter, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --cp-font-mono: "Cascadia Code", "Source Code Pro", "Fira Code", Consolas, monospace;
}

html {
  color-scheme: dark;
}

html,
body {
  min-height: 100%;
  background:
    radial-gradient(circle at top left, rgba(159, 208, 255, 0.10), transparent 28%),
    radial-gradient(circle at top right, rgba(217, 183, 111, 0.09), transparent 20%),
    linear-gradient(180deg, #0b121c 0%, #0f1724 45%, #111b2a 100%) !important;
  color: var(--cp-text) !important;
  font-family: var(--cp-font-main) !important;
}

body,
button,
input,
select,
textarea,
td,
th,
label,
div,
span {
  font-family: var(--cp-font-main) !important;
}

code,
pre,
kbd {
  font-family: var(--cp-font-mono) !important;
}

a {
  color: var(--cp-link) !important;
  text-decoration: none !important;
  transition: color 130ms ease, opacity 130ms ease, background-color 130ms ease, border-color 130ms ease;
}

a:hover {
  color: var(--cp-link-hover) !important;
}

a:visited {
  color: #bfdcff !important;
}

/* global rounded corners */
button,
input[type="button"],
input[type="submit"],
input[type="reset"],
select,
summary,
input,
textarea,
.op,
.btn,
label[for] {
  border-radius: var(--cp-radius-sm) !important;
}

/* top utility bar / action buttons */
#ops,
.toolbar,
.topbar,
.mbar,
#path,
.path,
.bread,
.breadcrumbs,
.thead,
#thead,
#srvinfo {
  background:
    linear-gradient(180deg, var(--cp-topbar) 0%, var(--cp-topbar-2) 100%) !important;
  border: 1px solid var(--cp-border) !important;
  box-shadow: var(--cp-shadow) !important;
  backdrop-filter: blur(10px);
}

#ops,
.toolbar,
.topbar,
.mbar {
  border-radius: var(--cp-radius) !important;
}

button,
input[type="button"],
input[type="submit"],
input[type="reset"],
.op,
.btn {
  background:
    linear-gradient(180deg, rgba(36, 50, 73, 0.95) 0%, rgba(24, 35, 53, 0.95) 100%) !important;
  color: var(--cp-text) !important;
  border: 1px solid var(--cp-border) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04) !important;
}

button:hover,
input[type="button"]:hover,
input[type="submit"]:hover,
input[type="reset"]:hover,
.op:hover,
.btn:hover {
  background:
    linear-gradient(180deg, rgba(47, 65, 92, 0.98) 0%, rgba(29, 43, 64, 0.98) 100%) !important;
  border-color: var(--cp-border-strong) !important;
}

button:focus,
input:focus,
select:focus,
textarea:focus {
  outline: none !important;
  border-color: var(--cp-accent) !important;
  box-shadow: var(--cp-glow) !important;
}

input,
select,
textarea {
  background: rgba(14, 22, 34, 0.96) !important;
  color: var(--cp-text) !important;
  border: 1px solid var(--cp-border) !important;
}

/* main content containers */
#tree,
#files,
#main,
#content,
#listing,
#browser,
#widget,
#wrap,
#w,
.panel,
.card,
.bbox,
#bb,
#path,
.path,
.bread,
.breadcrumbs,
.thead,
#thead,
#srvinfo,
nav,
.sidebar,
#navpane {
  background:
    linear-gradient(180deg, var(--cp-panel) 0%, var(--cp-panel-2) 100%) !important;
  border: 1px solid var(--cp-border-soft) !important;
  box-shadow: var(--cp-shadow) !important;
}

#files,
#main,
#content,
#listing,
#browser,
#widget,
.panel,
.card,
.bbox,
#bb {
  border-radius: var(--cp-radius-lg) !important;
}

#tree,
nav,
.sidebar,
#navpane {
  border-radius: var(--cp-radius) !important;
  background:
    linear-gradient(180deg, rgba(14, 22, 34, 0.98) 0%, rgba(18, 27, 41, 0.98) 100%) !important;
}

/* headings */
h1,
h2,
h3,
.title,
#title,
legend {
  color: #f5f9ff !important;
  letter-spacing: 0.01em;
}

h1,
#title {
  font-weight: 700 !important;
}

/* make the page title feel more polished */
h1,
#title,
.title {
  text-shadow: 0 1px 0 rgba(255,255,255,0.03);
}

/* sidebar tree */
#tree a,
.tree a,
#navpane a,
.sidebar a {
  color: var(--cp-text-soft) !important;
  border-radius: 10px;
}

#tree a:hover,
.tree a:hover,
#navpane a:hover,
.sidebar a:hover {
  color: #ffffff !important;
  background: rgba(159, 208, 255, 0.08) !important;
}

/* file listing */
table {
  width: 100%;
  border-collapse: collapse !important;
  background: transparent !important;
}

thead,
tr,
th,
td {
  background: transparent !important;
}

th {
  color: var(--cp-text-soft) !important;
  font-weight: 650 !important;
  border-bottom: 1px solid rgba(159, 208, 255, 0.16) !important;
  padding-top: 0.95rem !important;
  padding-bottom: 0.95rem !important;
}

td {
  color: var(--cp-text) !important;
  border-bottom: 1px solid rgba(255,255,255,0.05) !important;
}

tr:nth-child(even) td {
  background: var(--cp-row-alt) !important;
}

tr:hover td,
tr:hover th {
  background: var(--cp-row-hover) !important;
}

th,
td {
  padding-left: 0.9rem !important;
  padding-right: 0.9rem !important;
}

/* folder/file links */
td a,
th a,
.file a,
.dir a,
.path a,
.bread a,
.breadcrumbs a {
  color: var(--cp-text) !important;
}

td a:hover,
.file a:hover,
.dir a:hover,
.path a:hover,
.bread a:hover,
.breadcrumbs a:hover {
  color: var(--cp-link-hover) !important;
}

/* subtle gold cues for active elements */
.current,
.active,
.sel,
.selected,
.marked,
.focus,
.on,
input:checked + label,
button.primary,
.btn-primary {
  border-color: var(--cp-accent) !important;
}

.selected,
.marked,
.sel {
  background: linear-gradient(180deg, rgba(217, 183, 111, 0.18), rgba(217, 183, 111, 0.10)) !important;
}

/* cards, dialogs, overlays */
.modal,
.dialog,
.pop,
.popup,
.menu,
.ctx,
#menu {
  background: linear-gradient(180deg, rgba(20, 30, 46, 0.99), rgba(14, 22, 35, 0.99)) !important;
  border: 1px solid var(--cp-border) !important;
  border-radius: 16px !important;
  box-shadow: 0 22px 56px rgba(0,0,0,0.42) !important;
}

/* metadata and softer text */
small,
.muted,
.dim,
.hint,
.note,
.meta,
.perms,
#status,
#srvinfo {
  color: var(--cp-text-faint) !important;
}

hr {
  border: 0;
  border-top: 1px solid var(--cp-border) !important;
}

/* thumbnails / previews */
img,
video,
canvas,
.thumb,
.preview,
.thumb img {
  border-radius: 14px;
}

/* nice top-row polish when present */
#ops a,
.toolbar a,
.topbar a,
.mbar a,
#ops button,
.toolbar button,
.topbar button,
.mbar button {
  margin-top: 0.1rem;
  margin-bottom: 0.1rem;
}

/* make primary action-ish things slightly richer */
button[aria-selected="true"],
button[aria-pressed="true"],
.op.on,
.btn.on {
  background:
    linear-gradient(180deg, rgba(72, 99, 136, 0.98) 0%, rgba(44, 64, 95, 0.98) 100%) !important;
  border-color: rgba(211, 233, 255, 0.35) !important;
}

/* scrollbars */
* {
  scrollbar-width: thin;
  scrollbar-color: rgba(123, 153, 190, 0.7) rgba(12, 18, 29, 0.9);
}

*::-webkit-scrollbar {
  width: 12px;
  height: 12px;
}

*::-webkit-scrollbar-track {
  background: rgba(12, 18, 29, 0.9);
}

*::-webkit-scrollbar-thumb {
  background: rgba(123, 153, 190, 0.7);
  border-radius: 999px;
  border: 2px solid rgba(12, 18, 29, 0.9);
}

*::-webkit-scrollbar-thumb:hover {
  background: rgba(157, 193, 236, 0.84);
}

/* spacing / breathing room */
#files,
#main,
#content,
#listing,
#browser,
#widget,
#tree,
#srvinfo,
.panel,
.card,
.bbox,
#bb {
  padding-top: 0.18rem;
}

/* optional hook for built-in theme variants */
html.a,
html.b,
html.z,
html.bz {
  --font-main: var(--cp-font-main);
  --font-mono: var(--cp-font-mono);
}
