/* ==========================================================================
   skavenger.css - Global site overrides
   Loaded after Stucco theme CSS via header_top.php
   ========================================================================== */

/* --------------------------------------------------------------------------
   CSS Custom Properties (design tokens)
   -------------------------------------------------------------------------- */
:root {
  --sk-bg:           #0d0d0d;
  --sk-bg-mid:       #111118;
  --sk-bg-card:      #111122;
  --sk-bg-elevated:  #181828;
  --sk-border:       #2a2a4a;
  --sk-border-light: #333348;
  --sk-accent:       #6c3fff;
  --sk-accent-hover: #8a60ff;
  --sk-accent-dim:   rgba(108, 63, 255, 0.15);
  --sk-accent-light: #a88bff;
  --sk-green:        #2ecc71;
  --sk-yellow:       #f0c040;
  --sk-red:          #e74c3c;
  --sk-text:         #e0e0e0;
  --sk-text-muted:   #909090;
  --sk-text-dim:     #606060;
  --sk-white:        #ffffff;
  --sk-radius:       8px;
  --sk-radius-sm:    4px;
  --sk-transition:   0.2s ease-in-out;
}

/* --------------------------------------------------------------------------
   Page chrome overrides - darken main content areas
   -------------------------------------------------------------------------- */

/* Sub-page header banner (white by default via @header-background-color: #fff) */
.header-container {
  background-color: var(--sk-bg-mid) !important;
  border-top: none !important;
  border-bottom: 1px solid var(--sk-border);
}

.header-content-inner {
  background-color: var(--sk-bg-mid) !important;
}

/* Global nav bar below header */
.global-navi {
  background-color: var(--sk-bg) !important;
  border-top: 1px solid var(--sk-border);
}

.main-container {
  background-color: var(--sk-bg) !important;
}

.main-content-inner {
  background-color: var(--sk-bg) !important;
  padding-top: 32px;
  padding-bottom: 64px;
}

.content-secondary-inner {
  background-color: var(--sk-bg-card) !important;
  border: 1px solid var(--sk-border);
}

.area-content-accent {
  background-color: var(--sk-bg-mid) !important;
}

/* Remove harsh white on home content sections */
.home-content-inner .home-middle {
  background-color: var(--sk-bg-mid) !important;
}

.home-content-inner .home-lower {
  background-color: var(--sk-bg-elevated) !important;
}

/* --------------------------------------------------------------------------
   Typography
   -------------------------------------------------------------------------- */
body {
  color: var(--sk-text);
}

p {
  color: var(--sk-text-muted);
}

h1, .h1,
h2, .h2,
h3, .h3,
h4, .h4 {
  color: var(--sk-white) !important;
}

h5, .h5,
h6, .h6 {
  color: var(--sk-text) !important;
}

h1.page-title {
  color: var(--sk-white) !important;
  border-left-color: var(--sk-accent) !important;
}

.title-thin {
  color: var(--sk-text-muted) !important;
}

.title-caps,
.title-caps-bold {
  color: var(--sk-accent-light) !important;
}

a {
  color: var(--sk-accent-light);
}

a:visited {
  color: var(--sk-accent-light);
}

a:hover,
a:focus,
a:active {
  color: var(--sk-white);
  text-decoration: underline;
}

blockquote {
  color: var(--sk-text-muted);
  border-left: 3px solid var(--sk-accent);
  padding-left: 24px;
}

hr {
  border-top-color: var(--sk-border);
}

/* --------------------------------------------------------------------------
   Forms
   -------------------------------------------------------------------------- */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
textarea,
select {
  background-color: var(--sk-bg-elevated) !important;
  border: 1px solid var(--sk-border) !important;
  color: var(--sk-text) !important;
  border-radius: var(--sk-radius-sm);
}

input[type="text"]:focus,
input[type="email"]:focus,
textarea:focus {
  border-color: var(--sk-accent) !important;
  outline: none;
  box-shadow: 0 0 0 2px var(--sk-accent-dim);
}

input[type="submit"],
button[type="submit"] {
  background-color: var(--sk-accent) !important;
  border-color: var(--sk-accent) !important;
  color: var(--sk-white) !important;
  border-radius: var(--sk-radius-sm);
  transition: background-color var(--sk-transition), opacity var(--sk-transition);
}

input[type="submit"]:hover,
button[type="submit"]:hover {
  background-color: var(--sk-accent-hover) !important;
  opacity: 1;
}

label {
  color: var(--sk-text);
}

/* --------------------------------------------------------------------------
   Concrete5 block overrides
   -------------------------------------------------------------------------- */

/* Blog / page list */
.ccm-block-page-list-page-entry-text .ccm-block-page-list-title a,
.ccm-block-page-list-page-entry-horizontal .ccm-block-page-list-page-entry-text .ccm-block-page-list-title a {
  color: var(--sk-white) !important;
}

.ccm-block-page-list-page-entry-text .ccm-block-page-list-title a:hover,
.ccm-block-page-list-page-entry-horizontal .ccm-block-page-list-page-entry-text .ccm-block-page-list-title a:hover {
  color: var(--sk-accent-light) !important;
}

.ccm-block-page-list-page-entry-text .ccm-block-page-list-date,
.ccm-block-page-list-page-entry-horizontal .ccm-block-page-list-page-entry-text .ccm-block-page-list-date {
  color: var(--sk-text-dim) !important;
}

.ccm-block-page-list-page-entry a.ccm-block-page-list-read-more {
  color: var(--sk-accent-light) !important;
  border-color: var(--sk-accent) !important;
  background-color: var(--sk-accent-dim) !important;
}

.ccm-block-page-list-page-entry a.ccm-block-page-list-read-more:hover {
  background-color: var(--sk-accent) !important;
  color: var(--sk-white) !important;
}

/* Feature items */
div.ccm-block-feature-item h4 {
  color: var(--sk-accent-light) !important;
}

div.ccm-block-feature-item h4 a {
  color: var(--sk-accent-light) !important;
}

div.ccm-block-feature-item i {
  background-color: var(--sk-accent) !important;
}

/* Sidebar */
.block-sidebar-wrapped ul a {
  color: var(--sk-text-muted) !important;
}

.block-sidebar-wrapped ul a:hover {
  color: var(--sk-accent-light) !important;
}

/* Content secondary (sidebar) */
.content-secondary h5,
.block-sidebar-wrapped h5,
.content-secondary .ccm-block-topic-list-header h5,
.block-sidebar-wrapped .ccm-block-topic-list-header h5 {
  border-bottom-color: var(--sk-border) !important;
}

.content-secondary .ccm-block-topic-list-page-topics li a,
.block-sidebar-wrapped .ccm-block-topic-list-page-topics li a,
.content-secondary .ccm-block-topic-list-list li a,
.block-sidebar-wrapped .ccm-block-topic-list-list li a {
  color: var(--sk-text-muted) !important;
}

.content-secondary .ccm-block-topic-list-page-topics li a:hover,
.block-sidebar-wrapped .ccm-block-topic-list-list li a:hover {
  color: var(--sk-accent-light) !important;
}

/* Search block */
.ccm-page .ccm-search-block-form input[type="text"] {
  background: var(--sk-bg-elevated) !important;
  border-color: var(--sk-border) !important;
  color: var(--sk-text) !important;
}

.ccm-page .ccm-search-block-form input[type="submit"] {
  background: var(--sk-accent) !important;
  border-color: var(--sk-accent) !important;
  color: var(--sk-white) !important;
}

/* Breadcrumbs */
.bread-crumbs li {
  color: var(--sk-text-dim) !important;
}

.bread-crumbs li a {
  color: var(--sk-text-muted) !important;
}

.bread-crumbs li a:hover {
  color: var(--sk-white) !important;
}

/* Pagination */
div.ccm-pagination-wrapper .pagination > li > a {
  background-color: var(--sk-bg-card) !important;
  color: var(--sk-text-muted) !important;
}

div.ccm-pagination-wrapper .pagination > li > a:hover {
  background-color: var(--sk-accent) !important;
  color: var(--sk-white) !important;
}

div.ccm-pagination-wrapper .pagination > li.active span {
  background: var(--sk-accent) !important;
}

/* Page attribute display */
.ccm-block-page-attribute-display-wrapper {
  border-top-color: var(--sk-border) !important;
  color: var(--sk-text-muted) !important;
}

.ccm-block-page-attribute-display-wrapper .ccm-block-page-attribute-display-title {
  color: var(--sk-text) !important;
}

/* News list */
.news-list li {
  border-top-color: var(--sk-border) !important;
}

/* --------------------------------------------------------------------------
   Utility classes - shared across all page HTML blocks
   ========================================================================== */

/* -- Layout ---------------------------------------------------------------- */
.sk-section {
  margin-bottom: 40px;
}

.sk-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
}

.sk-grid-2 > * { flex: 1 1 300px; }
.sk-grid-3 > * { flex: 1 1 220px; }
.sk-grid-4 > * { flex: 1 1 180px; }

/* -- Cards ----------------------------------------------------------------- */
.sk-card {
  background: var(--sk-bg-card);
  border: 1px solid var(--sk-border);
  border-radius: var(--sk-radius);
  padding: 24px;
  box-sizing: border-box;
  transition: border-color var(--sk-transition);
}

.sk-card:hover {
  border-color: var(--sk-accent);
}

.sk-card h3,
.sk-card h4 {
  color: var(--sk-white) !important;
  margin-top: 0;
}

.sk-card p {
  color: var(--sk-text-muted);
  font-size: 0.9em;
  line-height: 1.65;
  margin: 0;
}

.sk-card-icon {
  font-size: 1.8em;
  color: var(--sk-accent);
  margin-bottom: 12px;
  display: block;
}

/* -- Hero / banner --------------------------------------------------------- */
.sk-hero {
  background: linear-gradient(135deg, #0d0d0d 0%, #1a1a2e 50%, #0d0d0d 100%);
  border: 1px solid var(--sk-border);
  border-radius: var(--sk-radius);
  padding: 48px 32px;
  text-align: center;
  margin-bottom: 32px;
  box-sizing: border-box;
}

.sk-hero h2 {
  font-size: 2em;
  color: var(--sk-white) !important;
  margin: 0 0 12px 0;
}

.sk-hero p {
  font-size: 1.1em;
  color: var(--sk-text-muted) !important;
  max-width: 680px;
  margin: 0 auto 20px auto;
  line-height: 1.65;
}

/* -- Pill badges ----------------------------------------------------------- */
.sk-badge-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin-top: 16px;
}

.sk-badge {
  display: inline-block;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 20px;
  padding: 5px 14px;
  font-size: 0.85em;
  color: var(--sk-text-muted);
}

.sk-badge i {
  margin-right: 5px;
  color: var(--sk-accent);
}

.sk-badge-accent {
  background: var(--sk-accent-dim);
  border-color: rgba(108,63,255,0.5);
  color: var(--sk-accent-light);
}

/* -- Highlight / callout strip --------------------------------------------- */
.sk-callout {
  background: var(--sk-bg-elevated);
  border-left: 3px solid var(--sk-accent);
  border-radius: 0 var(--sk-radius) var(--sk-radius) 0;
  padding: 20px 24px;
  margin-bottom: 24px;
  box-sizing: border-box;
}

.sk-callout-green  { border-left-color: var(--sk-green); }
.sk-callout-yellow { border-left-color: var(--sk-yellow); }
.sk-callout-red    { border-left-color: var(--sk-red); }

.sk-callout h3,
.sk-callout h4 {
  color: var(--sk-white) !important;
  margin-top: 0;
}

.sk-callout p {
  color: var(--sk-text-muted);
  margin: 0;
  font-size: 0.9em;
  line-height: 1.65;
}

/* -- Status bar ------------------------------------------------------------ */
.sk-status-bar {
  background: #0a1a0a;
  border: 1px solid rgba(46,204,113,0.35);
  border-radius: var(--sk-radius);
  padding: 16px 24px;
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 24px;
  box-sizing: border-box;
}

.sk-status-dot {
  width: 11px;
  height: 11px;
  background: var(--sk-green);
  border-radius: 50%;
  box-shadow: 0 0 8px var(--sk-green);
  flex-shrink: 0;
  animation: sk-pulse 2s infinite;
}

@keyframes sk-pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.35; }
}

.sk-status-bar p {
  margin: 0;
  color: var(--sk-text-muted) !important;
  font-size: 0.9em;
  flex: 1;
}

.sk-status-bar p strong {
  color: var(--sk-green);
}

/* -- Buttons --------------------------------------------------------------- */
.sk-btn {
  display: inline-block;
  padding: 10px 22px;
  border-radius: var(--sk-radius-sm);
  text-decoration: none !important;
  font-size: 0.9em;
  font-weight: bold;
  cursor: pointer;
  transition: opacity var(--sk-transition), background-color var(--sk-transition);
  box-sizing: border-box;
}

.sk-btn:hover { opacity: 0.85; }

.sk-btn-purple  { background: var(--sk-accent);  color: var(--sk-white) !important; }
.sk-btn-green   { background: var(--sk-green);   color: #000 !important; }
.sk-btn-yellow  { background: var(--sk-yellow);  color: #000 !important; }
.sk-btn-outline {
  background: transparent;
  border: 1px solid rgba(108,63,255,0.55);
  color: var(--sk-accent-light) !important;
}

.sk-btn + .sk-btn { margin-left: 10px; }

/* -- Divider --------------------------------------------------------------- */
.sk-divider {
  border: none;
  border-top: 1px solid var(--sk-border);
  margin: 32px 0;
}

/* -- Section heading with accent bar --------------------------------------- */
.sk-heading {
  color: var(--sk-white) !important;
  border-left: 4px solid var(--sk-accent);
  padding-left: 14px;
  margin-bottom: 24px;
}

/* -- Dark info table ------------------------------------------------------- */
.sk-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9em;
  margin-bottom: 24px;
}

.sk-table th {
  background: var(--sk-bg-elevated);
  color: var(--sk-text-muted);
  font-weight: 600;
  text-align: left;
  padding: 10px 14px;
  border-bottom: 1px solid var(--sk-border);
}

.sk-table td {
  color: var(--sk-text);
  padding: 10px 14px;
  border-bottom: 1px solid rgba(42,42,74,0.5);
}

.sk-table tr:hover td {
  background: var(--sk-bg-elevated);
}

/* -- Responsive helpers ---------------------------------------------------- */
@media (max-width: 767px) {
  .sk-hero { padding: 28px 16px; }
  .sk-hero h2 { font-size: 1.5em; }
  .sk-grid { gap: 14px; }
  .sk-btn + .sk-btn { margin-left: 0; margin-top: 8px; }
}

/* ==========================================================================
   Hero area - replace outdated image slider with a clean dark branded strip
   ========================================================================== */

/* Collapse the slider images entirely */
.hero-area .ccm-image-slider-container,
.hero-area .rslides,
.hero-area .rslides_nav,
.hero-area .rslides_tabs,
.hero-area img {
  display: none !important;
}

/* The hero-area itself becomes the branded strip */
.hero-area {
  background: linear-gradient(135deg, #0a0a14 0%, #1a1030 40%, #0d0a1a 100%);
  border-bottom: 1px solid var(--sk-border);
  padding: 40px 32px 36px;
  text-align: center;
  position: relative;
  overflow: hidden;
}

/* Subtle purple glow */
.hero-area::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 600px;
  height: 200px;
  background: radial-gradient(ellipse at center, rgba(108,63,255,0.12) 0%, transparent 70%);
  pointer-events: none;
}

/* ==========================================================================
   Front-page header fix
   The Stucco theme makes .header-content-inner position:absolute on desktop,
   designed to float the logo/nav over a full-bleed hero photo. Without the
   photo providing height, the nav collapses and overlaps page content.
   We restore normal flow positioning.
   ========================================================================== */
@media (min-width: 768px) {
  .front-page .header-content-inner {
    position: relative !important;
    background-color: var(--sk-bg-mid) !important;
    width: 100% !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
  }

  .front-page .header-navi {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    pointer-events: auto !important;
    margin-top: 8px;
  }

  .front-page .header-navi li a {
    color: var(--sk-text-muted) !important;
  }

  .front-page .header-navi li a:hover {
    color: var(--sk-white) !important;
    background: none !important;
  }
}

/* ==========================================================================
   Home page outdated images - hide circle images (feature blocks) and
   the fireworks / BTC / whats-new content images.
   Icons are injected via the html spacer blocks in the DB.
   ========================================================================== */
.home-upper .ccm-image-block,
.home-upper .ccm-image-block img {
  display: none !important;
}

.home-middle .ccm-image-block,
.home-middle .ccm-image-block img,
.home-lower .ccm-image-block,
.home-lower .ccm-image-block img {
  display: none !important;
}

/* Feature column layout - give each column a card-like appearance */
.home-upper .grid-col {
  background: var(--sk-bg-card);
  border: 1px solid var(--sk-border);
  border-radius: var(--sk-radius);
  padding: 24px 20px !important;
  transition: border-color 0.2s ease-in-out;
}

.home-upper .grid-col:hover {
  border-color: var(--sk-accent);
}

/* ==========================================================================
   Dark-on-dark fixes
   The Stucco theme uses @body-type-color:#595857, @header-navigation-type-color:#888084
   and heading vars like #2d2d2d. These are invisible on our dark backgrounds.
   ========================================================================== */

/* Header navigation links (now on dark bg #111118) */
.header-navi a,
.header-navi a:visited,
.header-navi ul a,
.header-navi ul a:visited {
  color: var(--sk-text-muted) !important;
}

.header-navi a:hover,
.header-navi a:focus,
.header-navi ul a:hover {
  color: var(--sk-white) !important;
}

/* Active/current page nav item */
.header-navi a.nav-path-selected,
.header-navi li.nav-selected > a {
  color: var(--sk-accent-light) !important;
}

/* Site title link in the header */
.header-logo a,
.header-logo a:visited,
.header-site-title a,
.header-site-title a:visited {
  color: var(--sk-white) !important;
}

/* Mobile overlay nav (ccm-responsive-overlay) */
.ccm-responsive-overlay {
  background-color: var(--sk-bg-elevated) !important;
  border-color: var(--sk-border) !important;
}

.ccm-responsive-overlay ul li {
  border-top-color: var(--sk-border) !important;
}

.ccm-responsive-overlay ul li a,
.ccm-responsive-overlay ul li a:visited {
  color: var(--sk-text-muted) !important;
  background-color: transparent !important;
}

.ccm-responsive-overlay ul li a:hover {
  color: var(--sk-white) !important;
  background-color: var(--sk-bg-card) !important;
}

/* Desktop dropdown sub-menus */
.header-navi ul ul,
.header-navi .dropdown-menu {
  background-color: var(--sk-bg-elevated) !important;
  border-color: var(--sk-border) !important;
}

.header-navi ul ul li a,
.header-navi .dropdown-menu a {
  color: var(--sk-text-muted) !important;
  background-color: transparent !important;
}

.header-navi ul ul li a:hover,
.header-navi .dropdown-menu a:hover {
  color: var(--sk-white) !important;
  background-color: var(--sk-bg-card) !important;
}

/* Global nav bar */
.global-navi a,
.global-navi a:visited {
  color: var(--sk-text-muted) !important;
}

.global-navi a:hover {
  color: var(--sk-white) !important;
}

/* Home page feature section text (now on dark mid/elevated backgrounds) */
.home-content-inner,
.home-content-inner p,
.home-content-inner span,
.home-content-inner li {
  color: var(--sk-text-muted) !important;
}

.home-content-inner h2,
.home-content-inner h3,
.home-content-inner h4 {
  color: var(--sk-white) !important;
}

/* General catch-all: any text inheriting the theme's dark #595857 body color
   that lands on one of our dark container backgrounds */
.main-content-inner,
.main-content-inner p,
.main-content-inner li,
.main-content-inner span:not([class*="fa"]):not([class*="icon"]) {
  color: var(--sk-text-muted);
}

/* Override specifically dark heading values the theme bakes in */
.main-content-inner h1,
.main-content-inner h2,
.main-content-inner h3,
.main-content-inner h4,
.main-content-inner h5,
.main-content-inner h6 {
  color: var(--sk-white) !important;
}

/* Footer text (the theme sets @footer-text-color which can be dark) */
.footer-container,
.footer-container p,
.footer-container a,
.footer-container a:visited,
.footer-content-inner,
.footer-content-inner p {
  color: var(--sk-text-dim) !important;
}

.footer-container a:hover {
  color: var(--sk-text-muted) !important;
}

/* Page title on sub-pages (h1.page-title uses @page-title-type-color:#28282e) */
h1.page-title,
.content-primary h1.page-title {
  color: var(--sk-white) !important;
  border-left-color: var(--sk-accent) !important;
}

/* Misc inherited dark text that may appear in content blocks */
.ccm-block-html p,
.ccm-block-html li,
.ccm-block-html span {
  color: inherit;
}

/* Strong/em inside dark containers should stay readable */
.main-content-inner strong {
  color: var(--sk-text) !important;
}

.main-content-inner em {
  color: var(--sk-text-muted) !important;
}

/* ==========================================================================
   Animenu nav - fix grey-on-grey background and white-on-white hover
   The theme sets #2d2d2d bg on nav items and #f3f3f2 bg on hover.
   Our global a:hover:{ color:white !important } then produced white-on-white.
   ========================================================================== */

/* Strip grey item backgrounds and borders; let the global-navi bg show */
.animenu__nav > li > a,
.animenu a,
.animenu a:visited,
.animenu a:focus {
  background-color: transparent !important;
  color: var(--sk-text) !important;
}

/* Kill the light-grey border separators between top-level items */
.animenu__nav > li,
.animenu__nav > li:first-child,
.animenu__nav > li:last-child {
  border-color: var(--sk-border) !important;
}

/* Hover: purple tint background + accent text - no more white-on-white */
.animenu__nav > li > a:hover,
.animenu__nav > li > a:focus {
  color: var(--sk-accent-light) !important;
  background-color: var(--sk-accent-dim) !important;
  text-decoration: none !important;
}

/* Current / active page item */
.animenu__nav a.nav-path-selected {
  color: var(--sk-accent-light) !important;
  background-color: var(--sk-accent-dim) !important;
}

.animenu__nav a.nav-path-selected:hover {
  color: var(--sk-white) !important;
  background-color: rgba(108, 63, 255, 0.28) !important;
}

/* Dropdown sub-menu */
.animenu__nav__child {
  background-color: var(--sk-bg-elevated) !important;
  border-color: var(--sk-border) !important;
}

.animenu__nav__child > li {
  border-color: var(--sk-border) !important;
}

.animenu__nav__child a,
.animenu__nav__child a:visited {
  background-color: transparent !important;
  color: var(--sk-text-muted) !important;
}

.animenu__nav__child a:hover,
.animenu__nav__child a.nav-path-selected {
  color: var(--sk-accent-light) !important;
  background-color: var(--sk-accent-dim) !important;
}

/* Dropdown arrow pointer - update hardcoded grey colour */
.animenu__nav > li:first-child > a:after {
  border-bottom-color: var(--sk-bg-elevated) !important;
}

.animenu__nav > li:first-child > a:hover:after {
  border-bottom-color: var(--sk-accent) !important;
}

/* Mobile toggle button */
.ccm-page button.animenu__toggle,
.ccm-page button.animenu__toggle:hover {
  background-color: var(--sk-bg-elevated) !important;
}

/* ==========================================================================
   Footer - replace theme's mid-grey #2d2d2d with site dark palette
   ========================================================================== */

.footer-container {
  background-color: #070710 !important;
  border-top: 1px solid var(--sk-border) !important;
  color: var(--sk-text-dim) !important;
}

.footer-content-inner {
  background-color: #070710 !important;
}

.footer-container p,
.footer-container small,
.footer-container span:not([class*="fa"]):not([class*="icon"]) {
  color: var(--sk-text-dim) !important;
}

.footer-container a,
.footer-container a:visited {
  color: var(--sk-text-muted) !important;
}

.footer-container a:hover {
  color: var(--sk-accent-light) !important;
  text-decoration: none;
}

/* Footer nav links - remove the grey border boxes on dark bg */
footer .footer-nav li a,
footer .footer-nav p a {
  color: var(--sk-text-muted) !important;
  border-color: var(--sk-border) !important;
  background-color: transparent !important;
}

footer .footer-nav li a:hover,
footer .footer-nav p a:hover {
  color: var(--sk-accent-light) !important;
  border-color: var(--sk-accent) !important;
  background-color: var(--sk-accent-dim) !important;
  text-decoration: none;
}

/* Back-to-top button */
footer #scroll-page-top a {
  background-color: var(--sk-bg-elevated) !important;
  color: var(--sk-text-muted) !important;
}

footer #scroll-page-top a:hover {
  background-color: var(--sk-accent) !important;
  color: var(--sk-white) !important;
}

/* ==========================================================================
   Login and Registration pages
   Targets Concrete5 8.x (#ccm-login) and 9.x (.concrete-login) markup.
   The login page body carries the class "login"; registration uses "register".
   ========================================================================== */

/* -- Page chrome ----------------------------------------------------------- */
body.login,
body.register {
  background-color: var(--sk-bg) !important;
  background-image: radial-gradient(ellipse at 50% 30%, rgba(108,63,255,0.09) 0%, transparent 65%) !important;
}

/* Keep the main content area dark on auth pages */
body.login .main-container,
body.login .main-content-inner,
body.register .main-container,
body.register .main-content-inner {
  background-color: var(--sk-bg) !important;
}

/* -- Card wrapper (C5 8.x: #ccm-login, C5 9.x: .concrete-login) ----------- */
#ccm-login,
.concrete-login,
.ccm-login-page-inner,
.ccm-login-wrapper-outer {
  max-width: 480px;
  margin: 48px auto !important;
  background: var(--sk-bg-card) !important;
  border: 1px solid var(--sk-border) !important;
  border-radius: var(--sk-radius) !important;
  box-shadow: 0 8px 40px rgba(0,0,0,0.55);
  overflow: visible !important;
}

/* -- Header / logo area ---------------------------------------------------- */
.ccm-login-header,
.concrete-login__header,
#ccm-login .ccm-login-logo-wrapper {
  background: linear-gradient(135deg, #0d0920 0%, #1a1030 100%) !important;
  border-bottom: 1px solid var(--sk-border) !important;
  padding: 28px 32px 22px !important;
  text-align: center;
}

.ccm-login-header h1,
.ccm-login-header h2,
.concrete-login__site-name,
#ccm-login .ccm-login-logo-wrapper h1 {
  color: var(--sk-white) !important;
  font-size: 1.15rem !important;
  font-weight: 700 !important;
  margin: 8px 0 0 !important;
}

.ccm-login-header img,
.concrete-login__logo img,
#ccm-login .ccm-login-logo-wrapper img {
  max-height: 52px;
  width: auto;
}

/* -- Tabs (Sign In / Register) --------------------------------------------- */
#ccm-login .nav-tabs,
.concrete-login .nav-tabs,
.ccm-login-wrapper .nav-tabs {
  background: var(--sk-bg-elevated) !important;
  border-bottom: 1px solid var(--sk-border) !important;
  padding: 0 16px;
  margin: 0 !important;
}

#ccm-login .nav-tabs > li > a,
.concrete-login .nav-tabs > li > a,
.ccm-login-wrapper .nav-tabs .nav-link {
  color: var(--sk-text-muted) !important;
  background: transparent !important;
  border: none !important;
  border-bottom: 2px solid transparent !important;
  border-radius: 0 !important;
  padding: 12px 18px;
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: color var(--sk-transition), border-color var(--sk-transition);
}

#ccm-login .nav-tabs > li > a:hover,
.concrete-login .nav-tabs > li > a:hover,
.ccm-login-wrapper .nav-tabs .nav-link:hover {
  color: var(--sk-text) !important;
  background: transparent !important;
  border-bottom-color: var(--sk-border-light) !important;
}

#ccm-login .nav-tabs > li.active > a,
#ccm-login .nav-tabs > li.active > a:focus,
#ccm-login .nav-tabs > li.active > a:hover,
.concrete-login .nav-tabs .nav-item.active .nav-link,
.concrete-login .nav-tabs .nav-link.active,
.ccm-login-wrapper .nav-tabs .nav-link.active {
  color: var(--sk-accent-light) !important;
  background: transparent !important;
  border-bottom-color: var(--sk-accent) !important;
}

/* -- Tab content / form body ----------------------------------------------- */
#ccm-login .tab-content,
.concrete-login .tab-content,
.ccm-login-wrapper .tab-content {
  background: var(--sk-bg-card) !important;
  padding: 28px 32px !important;
}

/* -- Form groups and labels ------------------------------------------------ */
#ccm-login .form-group,
.concrete-login .form-group,
.ccm-login-wrapper .form-group,
body.login .form-group,
body.register .form-group {
  margin-bottom: 18px;
}

#ccm-login label,
.concrete-login label,
.ccm-login-wrapper label,
body.login label,
body.register label {
  color: var(--sk-text) !important;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-bottom: 6px;
  display: block;
}

/* -- Input fields ---------------------------------------------------------- */
#ccm-login input[type="text"],
#ccm-login input[type="email"],
#ccm-login input[type="password"],
#ccm-login input[type="search"],
#ccm-login select,
#ccm-login textarea,
.concrete-login input[type="text"],
.concrete-login input[type="email"],
.concrete-login input[type="password"],
.concrete-login select,
.concrete-login textarea,
body.login .form-control,
body.register .form-control {
  background-color: var(--sk-bg-elevated) !important;
  border: 1px solid var(--sk-border) !important;
  color: var(--sk-text) !important;
  border-radius: var(--sk-radius-sm) !important;
  padding: 10px 14px !important;
  width: 100% !important;
  box-sizing: border-box;
  font-size: 0.95rem;
  transition: border-color var(--sk-transition), box-shadow var(--sk-transition);
}

#ccm-login input[type="text"]:focus,
#ccm-login input[type="email"]:focus,
#ccm-login input[type="password"]:focus,
.concrete-login input[type="text"]:focus,
.concrete-login input[type="email"]:focus,
.concrete-login input[type="password"]:focus,
body.login .form-control:focus,
body.register .form-control:focus {
  border-color: var(--sk-accent) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px var(--sk-accent-dim) !important;
}

/* -- Submit / primary button ----------------------------------------------- */
#ccm-login-submit,
#ccm-users-register-button,
#ccm-login .btn-primary,
.concrete-login .btn-primary,
body.login .btn-primary,
body.register .btn-primary {
  background-color: var(--sk-accent) !important;
  border-color: var(--sk-accent) !important;
  color: var(--sk-white) !important;
  border-radius: var(--sk-radius-sm) !important;
  padding: 11px 24px !important;
  font-size: 0.9rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  width: 100%;
  cursor: pointer;
  transition: background-color var(--sk-transition), opacity var(--sk-transition);
}

#ccm-login-submit:hover,
#ccm-users-register-button:hover,
#ccm-login .btn-primary:hover,
.concrete-login .btn-primary:hover,
body.login .btn-primary:hover,
body.register .btn-primary:hover {
  background-color: var(--sk-accent-hover) !important;
  border-color: var(--sk-accent-hover) !important;
  opacity: 1 !important;
}

/* Block all Bootstrap default button styling bleeding in */
#ccm-login .btn,
.concrete-login .btn,
body.login .btn,
body.register .btn {
  border-radius: var(--sk-radius-sm) !important;
}

#ccm-login .btn-default,
.concrete-login .btn-default,
body.login .btn-default,
body.register .btn-default {
  background-color: var(--sk-bg-elevated) !important;
  border-color: var(--sk-border) !important;
  color: var(--sk-text-muted) !important;
}

#ccm-login .btn-default:hover,
.concrete-login .btn-default:hover,
body.login .btn-default:hover,
body.register .btn-default:hover {
  border-color: var(--sk-accent) !important;
  color: var(--sk-accent-light) !important;
}

/* -- Forgot password / links ---------------------------------------------- */
#ccm-login .ccm-login-forgot-password,
#ccm-login .ccm-login-forgot-password a,
#ccm-login p a,
.concrete-login p a,
body.login .tab-pane p a,
body.register .tab-pane p a {
  color: var(--sk-accent-light) !important;
  font-size: 0.82rem;
}

#ccm-login .ccm-login-forgot-password a:hover,
#ccm-login p a:hover,
.concrete-login p a:hover,
body.login .tab-pane p a:hover {
  color: var(--sk-white) !important;
}

/* -- Alert / validation messages ------------------------------------------ */
#ccm-login .alert,
.concrete-login .alert,
body.login .alert,
body.register .alert {
  border-radius: var(--sk-radius-sm) !important;
  font-size: 0.88rem;
  padding: 12px 16px;
  margin-bottom: 16px;
}

#ccm-login .alert-danger,
.concrete-login .alert-danger,
body.login .alert-danger,
body.register .alert-danger {
  background: rgba(231,76,60,0.12) !important;
  border: 1px solid rgba(231,76,60,0.45) !important;
  border-left: 3px solid var(--sk-red) !important;
  color: #f5a9a2 !important;
}

#ccm-login .alert-success,
.concrete-login .alert-success,
body.login .alert-success,
body.register .alert-success {
  background: rgba(46,204,113,0.1) !important;
  border: 1px solid rgba(46,204,113,0.35) !important;
  border-left: 3px solid var(--sk-green) !important;
  color: #a8f0c4 !important;
}

#ccm-login .alert-info,
.concrete-login .alert-info,
body.login .alert-info,
body.register .alert-info {
  background: var(--sk-accent-dim) !important;
  border: 1px solid rgba(108,63,255,0.4) !important;
  border-left: 3px solid var(--sk-accent) !important;
  color: var(--sk-accent-light) !important;
}

/* -- Help text / small captions ------------------------------------------- */
#ccm-login .help-block,
#ccm-login small,
.concrete-login .help-block,
.concrete-login small,
body.login .help-block,
body.register .help-block {
  color: var(--sk-text-dim) !important;
  font-size: 0.78rem;
}

/* -- Checkboxes (remember me, accept terms) -------------------------------- */
#ccm-login .checkbox label,
.concrete-login .checkbox label,
body.login .checkbox label,
body.register .checkbox label {
  color: var(--sk-text-muted) !important;
  font-size: 0.88rem;
  text-transform: none;
  letter-spacing: 0;
  font-weight: 400;
}

/* -- Divider between sections ("or sign in with") -------------------------- */
#ccm-login hr,
.concrete-login hr,
body.login hr,
body.register hr {
  border-color: var(--sk-border) !important;
  margin: 20px 0;
}

/* -- Required field star --------------------------------------------------- */
#ccm-login .ccm-required,
.concrete-login .ccm-required,
body.register .ccm-required {
  color: var(--sk-red) !important;
}

/* -- Footer note below card (e.g. "Powered by concrete5") ----------------- */
.ccm-login-footer,
.concrete-login__footer,
#ccm-login + p,
body.login .login-footer {
  text-align: center;
  color: var(--sk-text-dim) !important;
  font-size: 0.75rem;
  margin-top: 16px;
}

.ccm-login-footer a,
.concrete-login__footer a {
  color: var(--sk-text-dim) !important;
}

.ccm-login-footer a:hover,
.concrete-login__footer a:hover {
  color: var(--sk-text-muted) !important;
}
