/* ── CiaoDott Brand Palette ──────────────────────────────────────────── */

:root,
[data-md-color-scheme="default"] {
  --md-primary-fg-color:        #027DCB;
  --md-primary-fg-color--light: #7BCFFF;
  --md-primary-fg-color--dark:  #055587;
  --md-accent-fg-color:         #20F6E1;
  --md-accent-fg-color--transparent: rgba(32, 246, 225, .1);

  --md-default-fg-color:               #072C4A;
  --md-default-fg-color--light:        #0B4670;
  --md-default-fg-color--lighter:      rgba(7, 44, 74, .54);
  --md-default-fg-color--lightest:     rgba(7, 44, 74, .32);
  --md-default-bg-color:               #ffffff;
  --md-default-bg-color--light:        #F1F8FF;
  --md-default-bg-color--lighter:      #E0F2FF;
  --md-default-bg-color--lightest:     #E0F2FF;

  --md-typeset-a-color:         #027DCB;

  --md-code-bg-color:           #F1F8FF;
  --md-code-fg-color:           #0B4670;

  --md-typeset-mark-color:      rgba(32, 246, 225, .3);

  --md-footer-bg-color:         #072C4A;
  --md-footer-bg-color--dark:   #051d32;
  --md-footer-fg-color:         #F1F8FF;
  --md-footer-fg-color--light:  #BAE3FE;
  --md-footer-fg-color--lighter: rgba(241, 248, 255, .4);
}

[data-md-color-scheme="slate"] {
  --md-primary-fg-color:        #027DCB;
  --md-primary-fg-color--light: #7BCFFF;
  --md-primary-fg-color--dark:  #055587;
  --md-accent-fg-color:         #20F6E1;
  --md-accent-fg-color--transparent: rgba(32, 246, 225, .1);

  --md-default-fg-color:               #F1F8FF;
  --md-default-fg-color--light:        #BAE3FE;
  --md-default-fg-color--lighter:      rgba(241, 248, 255, .54);
  --md-default-fg-color--lightest:     rgba(241, 248, 255, .32);
  --md-default-bg-color:               #0d1b2a;
  --md-default-bg-color--light:        #112233;
  --md-default-bg-color--lighter:      #1a2d42;
  --md-default-bg-color--lightest:     #1a2d42;

  --md-typeset-a-color:         #7BCFFF;

  --md-code-bg-color:           #112233;
  --md-code-fg-color:           #BAE3FE;
}

/* ── Typography ─────────────────────────────────────────────────────── */

.md-typeset h1,
.md-typeset h2 {
  font-family: "Playfair Display", serif;
  font-weight: 700;
  color: var(--md-default-fg-color);
}

.md-typeset h3,
.md-typeset h4,
.md-typeset h5,
.md-typeset h6 {
  font-family: "Manrope", sans-serif;
  font-weight: 700;
  color: var(--md-default-fg-color);
}

.md-typeset {
  color: var(--md-default-fg-color);
}

.md-typeset h1 { letter-spacing: -0.02em; }
.md-typeset h2 { letter-spacing: -0.015em; }
.md-typeset h3 { letter-spacing: -0.01em; }

.md-typeset p,
.md-typeset li {
  line-height: 1.72;
}

/* ── Header / Navigation ────────────────────────────────────────────── */

.md-header {
  background: linear-gradient(135deg, #055587 0%, #027DCB 100%);
  box-shadow: 0 2px 12px rgba(2, 125, 203, .15);
}

.md-header__title {
  font-family: "Manrope", sans-serif;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.md-header__topic .md-ellipsis {
  font-family: "Manrope", sans-serif;
  font-weight: 700;
}

.md-header__button.md-logo {
  display: inline-flex !important;
  align-items: center;
}

.md-header .md-logo img,
.md-header .md-logo svg {
  display: block;
  height: 1.18rem;
  width: auto;
}

.md-nav__button.md-logo img,
.md-nav__title .md-nav__button.md-logo svg {
  display: block;
  height: 1.6rem;
  width: auto;
}

.cd-language-switch {
  display: inline-flex;
  align-items: center;
  gap: 0.15rem;
  margin-inline-end: 0.35rem;
  padding: 0.15rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, .12);
  backdrop-filter: blur(10px);
}

.cd-language-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.8rem;
  height: 1.5rem;
  padding: 0 0.5rem;
  border: 1px solid transparent;
  border-radius: 999px;
  color: rgba(241, 248, 255, .82);
  font-family: "Manrope", sans-serif;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: transparent;
  transition: all 0.2s ease;
}

.cd-language-chip:hover {
  color: #fff;
  background: rgba(255, 255, 255, .12);
}

.cd-language-chip.is-active {
  color: #055587;
  border-color: #F1F8FF;
  background: #F1F8FF;
  box-shadow: 0 1px 6px rgba(0, 0, 0, .08);
}

/* ── Navigation sidebar ─────────────────────────────────────────────── */

.md-nav__link--active,
.md-nav__link:is(:focus, :hover) {
  color: var(--md-primary-fg-color);
}

.md-nav__item--active > .md-nav__link {
  font-weight: 600;
  color: var(--md-primary-fg-color);
}

/* ── Content ────────────────────────────────────────────────────────── */

.md-typeset a:hover {
  color: var(--md-primary-fg-color--dark);
}

.md-typeset code {
  border-radius: 4px;
  padding: 0.1em 0.4em;
}

.md-typeset pre > code {
  border-radius: 8px;
}

.md-typeset pre {
  border: 1px solid rgba(2, 125, 203, .08);
  box-shadow: 0 10px 24px rgba(7, 44, 74, .05);
}

.md-typeset .admonition,
.md-typeset details {
  border-radius: 8px;
  border-left-width: 4px;
}

/* ── Tables ─────────────────────────────────────────────────────────── */

.md-typeset table:not([class]) {
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 1px 4px rgba(7, 44, 74, .06);
}

.md-typeset table:not([class]) th {
  background: var(--md-primary-fg-color);
  color: #fff;
  font-weight: 600;
}

[data-md-color-scheme="slate"] .md-typeset table:not([class]) th {
  background: var(--md-primary-fg-color--dark);
}

.md-typeset table:not([class]) td {
  border-color: var(--md-default-bg-color--lighter);
}

/* ── Buttons ────────────────────────────────────────────────────────── */

.md-typeset .md-button--primary {
  background: var(--md-primary-fg-color);
  border-color: var(--md-primary-fg-color);
  color: #fff;
  border-radius: 8px;
  font-weight: 600;
  padding: 0.6em 1.6em;
  transition: all 0.2s ease;
}

.md-typeset .md-button--primary:hover {
  background: var(--md-primary-fg-color--dark);
  border-color: var(--md-primary-fg-color--dark);
  box-shadow: 0 4px 12px rgba(2, 125, 203, .25);
}

.md-typeset .md-button {
  border-radius: 8px;
  font-weight: 600;
  padding: 0.6em 1.6em;
  border-color: var(--md-primary-fg-color);
  color: var(--md-primary-fg-color);
  transition: all 0.2s ease;
}

.md-typeset .md-button:hover {
  background: var(--md-primary-fg-color);
  color: #fff;
}

/* ── Tabs ───────────────────────────────────────────────────────────── */

.md-typeset .tabbed-labels > label {
  border-radius: 8px 8px 0 0;
  font-weight: 600;
}

/* ── Encrypted-content login form ────────────────────────────────────
   Spacing on 8px grid. Min touch target 44px. Brand color #027DCB.
   ─────────────────────────────────────────────────────────────────── */

.cd-login-card {
  max-width: 360px;
  margin: 80px auto 40px !important;
  padding: 32px !important;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, .06);
  display: flex;
  flex-direction: column;
  gap: 0;
  float: none !important;
}

.cd-login-card h1 {
  margin: 0 0 8px;
  font-size: 18px;
  line-height: 24px;
  font-family: "Manrope", sans-serif;
  font-weight: 700;
  color: var(--md-default-fg-color);
}

.cd-login-card > p {
  margin: 0 0 24px;
  font-size: 13px;
  color: var(--md-default-fg-color--lighter);
  line-height: 20px;
}

.cd-login-input,
#mkdocs-decrypt-form .md-input,
#mkdocs-content-user,
#mkdocs-content-password {
  font-family: "Manrope", sans-serif;
  display: block;
  width: 100%;
  height: 44px;
  padding: 0 12px;
  margin-bottom: 16px;
  font-size: 14px;
  line-height: 44px;
  border: 1px solid #d0d5dd;
  border-radius: 6px;
  outline: none;
  box-sizing: border-box;
  background: var(--md-default-bg-color);
  color: var(--md-default-fg-color);
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.cd-login-input:focus,
#mkdocs-decrypt-form .md-input:focus,
#mkdocs-content-user:focus,
#mkdocs-content-password:focus {
  border-color: #027DCB;
  box-shadow: 0 0 0 3px rgba(2, 125, 203, .10);
}

.cd-login-button,
#mkdocs-decrypt-form button,
#mkdocs-decrypt-form input[type="submit"] {
  font-family: "Manrope", sans-serif;
  display: inline-flex !important;
  align-items: center;
  align-self: flex-start !important;
  height: 36px;
  padding: 0 16px;
  margin-top: 8px;
  font-size: 13px;
  font-weight: 600;
  color: #fff;
  background: #027DCB;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.15s ease;
  width: auto !important;
  max-width: fit-content;
}

.cd-login-button:hover,
#mkdocs-decrypt-form button:hover,
#mkdocs-decrypt-form input[type="submit"]:hover {
  background: #055587;
}

.cd-login-button::after {
  content: "\2192";
  margin-left: 6px;
}

#mkdocs-decrypt-msg {
  margin: 12px 0 0;
  min-height: 20px;
  font-size: 13px;
  line-height: 20px;
  color: #E73437;
  font-weight: 500;
}

.cd-locked-doc .md-sidebar--primary,
.cd-locked-doc .md-sidebar--secondary {
  display: none;
}

.cd-locked-doc .md-main__inner {
  display: flex !important;
  justify-content: center;
  max-width: 100%;
  padding: 0 16px;
}

.cd-locked-doc .md-content {
  max-width: 100%;
  flex: 0 1 auto;
}

.cd-locked-doc .md-content__inner {
  margin: 0;
  display: flex;
  justify-content: center;
}

[data-md-color-scheme="slate"] .cd-login-card {
  background: #162435;
  border-color: #2a3d52;
  box-shadow: 0 1px 3px rgba(0, 0, 0, .15);
}

[data-md-color-scheme="slate"] .cd-login-input,
[data-md-color-scheme="slate"] #mkdocs-decrypt-form .md-input {
  border-color: #2a3d52;
}

[data-md-color-scheme="slate"] .cd-login-card > p {
  color: var(--md-default-fg-color--light);
}

[data-md-color-scheme="slate"] #mkdocs-decrypt-msg {
  color: #ff9c9d;
}

@media screen and (max-width: 480px) {
  .cd-login-card {
    margin: 48px 16px 32px;
    padding: 24px !important;
  }
}

/* ── Announcement banner (hidden – empty wrapper from base template) ── */

.md-banner {
  display: none;
}

/* ── Footer ─────────────────────────────────────────────────────────── */

.md-footer {
  background: #072C4A;
}

/* ── Permalink anchors – show only on hover ─────────────────────────── */

.md-typeset .headerlink {
  opacity: 0;
  transition: opacity 0.2s ease;
}

.md-typeset h1:hover .headerlink,
.md-typeset h2:hover .headerlink,
.md-typeset h3:hover .headerlink,
.md-typeset h4:hover .headerlink {
  opacity: 1;
}

.cd-hero .headerlink,
.cd-feature .headerlink {
  display: none;
}

/* ── Smooth transitions ─────────────────────────────────────────────── */

.md-typeset a,
.md-nav__link,
.md-header,
.md-tabs__link {
  transition: color 0.2s ease, background 0.2s ease;
}

/* ── Scrollbar (webkit) ─────────────────────────────────────────────── */

::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: #BAE3FE;
  border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover { background: #7BCFFF; }

[data-md-color-scheme="slate"] ::-webkit-scrollbar-thumb { background: #1a2d42; }
[data-md-color-scheme="slate"] ::-webkit-scrollbar-thumb:hover { background: #27405a; }

