/* -------------------------------------------------------
   Modern Dark Theme (Bootstrap-friendly)
   ------------------------------------------------------- */

:root {
    /* Background layers */
    --bg-primary: #0b0f14;
    --bg-secondary: #111722;
    --surface-1: #141b26;
    --surface-2: #1a2333;

    /* Text colors */
    --text-primary: #e6e9ef;
    --text-secondary: #a3acb9;
    --text-muted: #6b7380;

    /* Accent */
    --accent-color: none;
    --accent-hover: #e6e9ef;
    --accent-contrast: #06121d;

    /* Borders / shadows */
    --border-color: rgba(255,255,255,0.08);
    --border-strong: rgba(255,255,255,0.15);

    /* Effects */
    --ring-color: rgba(90,168,255,0.35);
    --blur-bg: rgba(20, 27, 38, 0.6);

    /* Navbar */
    --navbar-bg: rgba(10, 14, 20, 0.75);
}

/* -------------------------------------------------------
   Base styles
   ------------------------------------------------------- */
html, body {
    height: 100%;
    background-color: var(--bg-primary) !important;
}

body {
    background-color: var(--bg-primary) !important;
    color: var(--text-primary) !important;
    font-smooth: always;
}

/* Remove Bootstrap's light theme bleed */
.bg-body-tertiary {
    background-color: var(--surface-1) !important;
}

/* -------------------------------------------------------
   Navbar
   ------------------------------------------------------- */
.navbar {
    background-color: var(--navbar-bg) !important;
    backdrop-filter: blur(10px) saturate(150%);
    border-bottom: 1px solid var(--border-color);
}

.navbar-brand {
    color: var(--text-primary) !important;
}

.navbar .nav-link {
    color: var(--text-secondary) !important;
    transition: color .2s ease;
    border-color: none;
}

.navbar .nav-link:hover {
    color: var(--accent-color) !important;
}

.nav-item-active .nav-link,
.nav-item.nav-item-active .nav-link {
    text-decoration: underline;
}

/* -------------------------------------------------------
   Content Areas
   ------------------------------------------------------- */
.content-window {
    color: var(--text-primary) !important;
    padding: 1.25rem;
}

p {
    color: var(--text-secondary);
    line-height: 1.6;
}

h1, h2, h3, h4, h5, h6 {
    color: var(--text-primary);
    margin-top: 1rem;
}

/* -------------------------------------------------------
   Links
   ------------------------------------------------------- */
a {
    color: var(--accent-color) !important;
    transition: color .2s ease;
    text-decoration: none;
}

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

/* -------------------------------------------------------
   Buttons (Bootstrap friendly)
   ------------------------------------------------------- */
.btn-primary {
    background-color: var(--accent-color) !important;
    color: var(--accent-contrast) !important;
    transition: background-color .2s ease;
}

.btn-primary:hover {
    background-color: var(--accent-hover) !important;
}

/* Nav items use btn-link — keep them transparent */
.btn-link, .nav-link.btn-link {
    background-color: transparent !important;
    border-color: transparent !important;
}

/* -------------------------------------------------------
   Code blocks
   ------------------------------------------------------- */
pre, code {
    background-color: var(--surface-2) !important;
    color: var(--text-primary) !important;
}

pre {
    padding: 1rem;
    border-radius: 10px;
    border: 1px solid var(--border-color);
}

/* -------------------------------------------------------
   Footer
   ------------------------------------------------------- */
footer {
    color: var(--text-secondary);
    border-top: 1px solid var(--border-color);
    padding-top: 2rem;
}

footer a {
    color: var(--text-secondary) !important;
}

footer a:hover {
    color: var(--accent-color) !important;
}


/* User-defined site colors (Typely) — :root vars power public site + injected plugins */
:root {
    --typely-user-bg1: #002b36;
    --typely-user-bg2: #073642;
    --typely-user-bg3: #073642;
    --typely-user-font1: #eee8d5;
    --typely-user-font1-secondary: #839496;
    --typely-user-font2: #eee8d5;
    --typely-user-font2-secondary: #839496;
    --typely-user-font3: #eee8d5;
    --typely-user-font3-secondary: #839496;
    --typely-user-accent1: #268bd2;
    --typely-user-accent2: #2aa198;
    /* Bridge user palette into base theme CSS vars so white/black base stylesheets inherit correctly */
    --bg-primary: #002b36;
    --bg-secondary: #073642;
    --surface-1: #002b36;
    --surface-2: #073642;
    --text-primary: #eee8d5;
    --text-secondary: #839496;
    --muted: #839496;
    --navbar-bg: #073642;
    --nav-link-color: #eee8d5;
    --accent-color: #268bd2;
    --accent-hover: #2aa198;
}
html, body {
    background-color: var(--typely-user-bg1) !important;
    color: var(--typely-user-font1) !important;
}
.content-window,
.typely-site-content,
main#main-content.typely-page-main,
main#main-content .typely-site-content,
main#main-content .content-window {
    background-color: var(--typely-user-bg1) !important;
    color: var(--typely-user-font1) !important;
}
main#main-content .text-muted,
main#main-content .content-window .text-muted {
    color: var(--typely-user-font1-secondary) !important;
}
/* Nav buttons (btn-link) — always transparent regardless of base theme */
.btn-link,
.nav-link.btn-link,
.navbar .btn-link,
#typely-site-nav .btn-link {
    background-color: transparent !important;
    border-color: transparent !important;
    box-shadow: none !important;
}
/* Nav: class + stable id (React ListGroup) */
.navbar,
#typely-site-nav {
    background-color: var(--typely-user-bg2) !important;
    color: var(--typely-user-font2) !important;
}
.navbar-brand,
#typely-site-nav .navbar-brand {
    color: var(--typely-user-font2) !important;
}
.navbar .nav-link,
.navbar .btn-link,
#typely-site-nav .nav-link,
#typely-site-nav .btn-link {
    color: var(--typely-user-font2) !important;
}
.navbar .text-muted,
#typely-site-nav .text-muted {
    color: var(--typely-user-font2-secondary) !important;
    opacity: 1 !important;
}
.navbar .nav-link:hover,
.navbar .btn-link:hover,
#typely-site-nav .nav-link:hover,
#typely-site-nav .btn-link:hover {
    color: var(--typely-user-accent2) !important;
}
.navbar .nav-link.active,
.navbar .btn-link.active,
#typely-site-nav .nav-link.active,
#typely-site-nav .btn-link.active {
    color: var(--typely-user-accent1) !important;
    border-bottom: 2px solid var(--typely-user-accent1) !important;
    border-radius: 0 !important;
}
.navbar .navbar-toggler,
#typely-site-nav .navbar-toggler {
    border-color: color-mix(in srgb, var(--typely-user-font2) 35%, transparent) !important;
}
/* Footer: role + stable id (user columns + Typely credit) */
footer[role="contentinfo"],
#typely-site-footer,
footer.typely-credit {
    background-color: var(--typely-user-bg3) !important;
    color: var(--typely-user-font3) !important;
}
footer[role="contentinfo"] h5,
footer[role="contentinfo"] .link-dark,
footer[role="contentinfo"] .nav-link:not(.text-muted),
footer[role="contentinfo"] a:not(.text-muted),
#typely-site-footer h5,
#typely-site-footer .link-dark,
#typely-site-footer .nav-link:not(.text-muted),
#typely-site-footer a:not(.text-muted),
footer.typely-credit,
footer.typely-credit a:not(.text-muted) {
    color: var(--typely-user-font3) !important;
}
footer[role="contentinfo"] .text-muted,
footer[role="contentinfo"] .nav-link.text-muted,
#typely-site-footer .text-muted,
#typely-site-footer .nav-link.text-muted {
    color: var(--typely-user-font3-secondary) !important;
    opacity: 1 !important;
}
footer[role="contentinfo"] .border-top,
#typely-site-footer.border-top {
    border-color: color-mix(in srgb, var(--typely-user-font3-secondary) 40%, transparent) !important;
}
/* Contact form plugin (injected HTML uses .typely-plugin-contact) */
#main-content .typely-plugin-contact .formbold-form-wrapper {
    background: transparent !important;
    color: var(--typely-user-font1) !important;
}
#main-content .typely-plugin-contact .formbold-form-input {
    color: var(--typely-user-font1) !important;
    background: transparent !important;
    border-bottom-color: color-mix(in srgb, var(--typely-user-font1-secondary) 55%, transparent) !important;
}
#main-content .typely-plugin-contact .formbold-form-input::placeholder {
    color: var(--typely-user-font1-secondary) !important;
    opacity: 0.85 !important;
}
#main-content .typely-plugin-contact .formbold-form-input:focus {
    border-bottom-color: var(--typely-user-accent1) !important;
}
#main-content .typely-plugin-contact .formbold-form-label {
    color: var(--typely-user-font1-secondary) !important;
}
#main-content .typely-plugin-contact .formbold-form-input:focus + .formbold-form-label {
    color: var(--typely-user-accent1) !important;
}
#main-content .typely-plugin-contact .formbold-btn {
    background-color: var(--typely-user-accent1) !important;
    color: #ffffff !important;
    border: none !important;
}
#main-content .typely-plugin-contact .formbold-btn:hover {
    background-color: var(--typely-user-accent2) !important;
}
#main-content .typely-form-feedback.typely-feedback-success {
    background: color-mix(in srgb, var(--typely-user-accent1) 18%, var(--typely-user-bg1)) !important;
    color: var(--typely-user-font1) !important;
    border: 1px solid color-mix(in srgb, var(--typely-user-accent1) 50%, transparent) !important;
}
#main-content .typely-form-feedback.typely-feedback-error {
    background: color-mix(in srgb, var(--typely-user-accent2) 15%, var(--typely-user-bg1)) !important;
    color: var(--typely-user-font1) !important;
    border: 1px solid color-mix(in srgb, var(--typely-user-accent2) 45%, transparent) !important;
}
/* Subscribe plugin */
#main-content .subscribe-wrapper {
    color: var(--typely-user-font1) !important;
}
#main-content .subscribe-input {
    color: var(--typely-user-font1) !important;
    background: var(--typely-user-bg1) !important;
    border-color: color-mix(in srgb, var(--typely-user-font1-secondary) 45%, transparent) !important;
}
#main-content .subscribe-input:focus {
    outline: 2px solid var(--typely-user-accent1) !important;
    outline-offset: 1px !important;
}
#main-content .subscribe-btn {
    background-color: var(--typely-user-accent1) !important;
    color: #ffffff !important;
    border-color: var(--typely-user-accent1) !important;
}
#main-content .subscribe-btn:hover {
    background-color: var(--typely-user-accent2) !important;
    border-color: var(--typely-user-accent2) !important;
}
#main-content .subscribe-status.text-success {
    color: var(--typely-user-accent1) !important;
}
#main-content .subscribe-status.text-danger {
    color: var(--typely-user-accent2) !important;
}
::selection {
    background-color: var(--typely-user-accent1) !important;
    color: #ffffff !important;
}
a:focus-visible,
button:focus-visible,
.nav-link:focus-visible {
    outline: 2px solid var(--typely-user-accent1) !important;
    outline-offset: 2px !important;
}

/* Typely runtime patch: nav btn-link must never inherit base theme button bg */
.btn-link,.nav-link.btn-link,.navbar .btn-link,#typely-site-nav .btn-link{background-color:transparent!important;border-color:transparent!important;box-shadow:none!important;}
