@layer base, tokens, layout, components, content, themes, vendor;

@layer base {
  *,
  *::before,
  *::after {
    box-sizing: border-box;
  }

  body {
    margin: 0;
    font-family: var(--font-body);
    color: #fff;
  }

  .hidden { display: none; }

  .sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
  }

  body.composers-layout {
    min-height: 100vh;
    background: linear-gradient(
      160deg,
      rgba(0, 88, 168, 0.52) 0%,
      rgba(0, 114, 200, 0.75) 35%,
      rgba(0, 98, 184, 0.8) 65%,
      rgba(0, 78, 154, 0.85) 100%),
      url("/flag.jpg") no-repeat fixed bottom;
    background-size: cover;
  }

  body.admin-layout {
    min-height: 100vh;
    background: linear-gradient(
      160deg,
      rgba(0, 88, 168, 0.52) 0%,
      rgba(0, 114, 200, 0.75) 35%,
      rgba(0, 98, 184, 0.8) 65%,
      rgba(0, 78, 154, 0.85) 100%),
      url("/flag.jpg") no-repeat fixed bottom;
    background-size: cover;
  }
}

@layer components {
  /* ── PAGE WRAPPER ── */
  .composers-page {
    position: relative;
    z-index: 2;
    max-width: 1024px;
    margin: 0 auto;
    padding: 40px 40px 64px;
  }

  /* ── PUBLIC NAV ── */
  .composers-nav {
    position: sticky;
    top: 0;
    z-index: 100;
    background: var(--color-nav);
    backdrop-filter: blur(22px);
    -webkit-backdrop-filter: blur(22px);
    border-bottom: 1px solid rgba(255, 255, 255, 0.18);
    padding: 0 40px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 62px;

    .nav-brand {
      font-family: var(--font-heading);
      font-size: 19px;
      font-weight: 600;
      color: #fff;
      display: flex;
      align-items: center;
      gap: 10px;
      text-decoration: none;
    }

    .nav-sub {
      font-size: 11px;
      font-weight: 300;
      color: var(--color-muted);
      letter-spacing: 0.07em;
      border-left: 1px solid rgba(255, 255, 255, 0.25);
      padding-left: 10px;
      font-family: var(--font-body);
      text-decoration: none;
      transition: color 0.15s ease;

      &:hover {
        color: rgba(255, 255, 255, 0.95);
      }
    }

    .nav-count {
      font-size: 12px;
      color: var(--color-muted);
      font-weight: 300;
    }
  }

  .nav-logo {
    width: 40px;
    height: 40px;
    border-radius: 6px;
    object-fit: contain;
    background: rgba(255, 255, 255, 0.9);
    padding: 3px;
  }

  .nav-menu {
    display: flex;
    align-items: center;
    gap: 16px;
    font-size: 12px;
    font-weight: 500;
    color: #fff;
  }

  .nav-link {
    color: #fff;
    text-decoration: none;
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    opacity: 0.75;

    &:hover {
      opacity: 1;
    }

    &.active {
      opacity: 1;
      font-weight: 600;
    }
  }

  .nav-locale-toggle {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-left: 8px;
    border-left: 1px solid rgba(255, 255, 255, 0.2);
    padding-left: 12px;
  }

  .locale-toggle {
    color: #fff;
    text-decoration: none;
    font-size: 11px;
    letter-spacing: 0.1em;
    opacity: 0.45;

    &:hover { opacity: 0.85; }

    &.current {
      opacity: 1;
      font-weight: 700;
    }
  }

  .locale-sep {
    color: rgba(255, 255, 255, 0.3);
    font-size: 10px;
  }

  /* ── HERO ── */
  .list-hero {
    margin-bottom: 32px;

    h1 {
      font-family: var(--font-heading);
      font-size: 50px;
      font-weight: 300;
      font-style: italic;
      color: #fff;
      line-height: 1.05;
      margin-bottom: 6px;
      text-shadow: 0 2px 20px rgba(0, 30, 80, 0.3);
    }

    p {
      font-size: 13px;
      color: var(--color-muted);
      font-weight: 300;
      letter-spacing: 0.05em;
    }
  }

  /* ── RESULTS BAR ── */
  .results-bar {
    display: flex;
    align-items: center;
    margin-bottom: 14px;
  }

  .results-count {
    font-size: 13px;
    color: var(--color-muted);
    font-weight: 300;
    font-family: var(--font-body);

    strong {
      color: #fff;
      font-weight: 500;
    }
  }

  /* ── FILTERS ── */
  .filters {
    background: var(--prim-glass);
    border: 1px solid var(--color-outline);
    border-radius: 14px;
    padding: 18px 22px;
    margin-bottom: 22px;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: flex-end;
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);

    input[type="text"],
    select {
      border: 1px solid rgba(255, 255, 255, 0.25);
      border-radius: 8px;
      padding: 8px 12px;
      font-size: 13px;
      font-family: var(--font-body);
      color: #fff;
      background: rgba(255, 255, 255, 0.12);
      outline: none;
      transition: all 0.2s;
      width: 100%;

      &::placeholder {
        color: rgba(255, 255, 255, 0.40);
      }

      &:focus {
        background: var(--prim-glass-md);
        border-color: rgba(255, 255, 255, 0.55);
      }
    }

    select option {
      color: #1a2a4a;
      background: #fff;
    }
  }

  .filter-group {
    display: flex;
    flex-direction: column;
    gap: 5px;
    flex: 1;
    min-width: 130px;
  }

  .filter-label,
  .filter-group label {
    font-size: 10px;
    letter-spacing: 0.15em;
    color: var(--color-muted);
    text-transform: uppercase;
    font-family: var(--font-body);
  }

  .filter-toggles {
    display: flex;
    flex-direction: column;
    gap: 5px;
  }

  .toggles-row {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
  }

  .toggle-pill {
    padding: 7px 11px;
    border-radius: 20px;
    border: 1px solid rgba(255, 255, 255, 0.28);
    background: rgba(255, 255, 255, 0.12);
    font-size: 11px;
    color: rgba(255, 255, 255, 0.85);
    cursor: pointer;
    transition: all 0.18s;
    display: flex;
    align-items: center;
    gap: 4px;
    white-space: nowrap;
    user-select: none;
    font-family: var(--font-body);

    &:hover {
      background: rgba(255, 255, 255, 0.22);
    }

    &.active {
      background: rgba(255, 255, 255, 0.92);
      color: var(--prim-blue-dark);
      border-color: rgba(255, 255, 255, 0.9);
      font-weight: 500;
    }

    svg {
      width: 11px;
      height: 11px;
    }
  }

  /* ── COMPOSER CARDS ── */
  .cards-list {
    display: flex;
    flex-direction: column;
    gap: 14px;
  }

  .composer-card {
    background: var(--color-surface-container);
    border: 1px solid var(--prim-card-border);
    border-radius: 16px;
    padding: 22px 36px 18px;
    cursor: pointer;
    transition: transform 0.18s, box-shadow 0.18s, background 0.18s;
    box-shadow: 0 4px 24px rgba(0, 30, 100, 0.20);
    text-decoration: none;
    display: block;
    color: inherit;

    &:hover {
      box-shadow: 0 10px 40px rgba(0, 30, 100, 0.28);
      background: var(--color-surface);
      text-decoration: none;
      color: inherit;
    }
  }

  .card-grid {
    display: grid;
    grid-template-columns: 96px minmax(0, 1fr) max-content;
    gap: 24px;
    align-items: start;
  }

  .card-media {
    display: flex;
    align-items: flex-start;
    justify-content: center;
  }

  .card-avatar {
    width: 96px;
    height: 96px;
    border-radius: 50%;
    flex-shrink: 0;
    background: linear-gradient(135deg, #c8e4f8 0%, #e4f2fc 100%);
    border: 1.5px solid rgba(0, 100, 200, 0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-heading);
    font-size: 28px;
    font-weight: 700;
    color: var(--prim-blue-dark);
    overflow: hidden;
  }

  .card-photo {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .card-info {
    margin-bottom: 10px;
  }

  .card-name {
    font-family: var(--font-heading);
    font-size: 26px;
    font-weight: 700;
    color: var(--color-on-surface);
    margin-bottom: 2px;
    line-height: 1.2;
  }

  .card-birth {
    font-size: 14px;
    color: var(--color-on-surface-variant);
    font-weight: 300;
  }

  .card-teaser {
    font-size: 14px;
    color: #5a6880;
    line-height: 1.65;
    margin-bottom: 14px;
    box-sizing: border-box;
    width: 100%;

    strong {
      color: var(--prim-blue-dark);
      font-weight: 500;
    }
  }

  .card-divider {
    height: 1px;
    background: rgba(0, 80, 180, 0.08);
    margin: 0 0 14px;
    box-sizing: border-box;
    width: 100%;
  }

  .card-stats {
    display: grid;
    grid-template-columns: repeat(2, max-content);
    justify-content: end;
    gap: 12px 16px;
    box-sizing: border-box;
    width: 100%;
  }

  @media (max-width: 720px) {
    .card-grid {
      grid-template-columns: 1fr;
    }

    .card-stats {
      padding-left: 0;
    }

    .card-teaser,
    .card-divider {
      padding-left: 0;
      margin-left: 0;
      width: 100%;
    }
  }

  /* ── STAT PILLS ── */
  .stat-pill {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 6px 14px 6px 10px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 400;
    color: var(--color-on-surface);
    font-family: var(--font-body);
    justify-content: flex-start;
    white-space: nowrap;

    .sicon {
      width: 36px;
      height: 36px;
      border-radius: 6px;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;

      svg { width: 20px; height: 20px; }
    }

    &.obras        { background: #fff4ee; }
    &.obras .sicon { background: #ffe5d4; }

    &.videos        { background: #eef3ff; }
    &.videos .sicon { background: #dce8ff; }

    &.grabaciones        { background: #eef8f2; }
    &.grabaciones .sicon { background: #d6f0e0; }

    &.partituras        { background: #f2f0ff; }
    &.partituras .sicon { background: #e2dcff; }

    &.fotos        { background: #fffaee; }
    &.fotos .sicon { background: #ffefc8; }

    &.zero {
      opacity: 0.45;
      filter: grayscale(0.1);
    }
  }

  /* ── NO RESULTS ── */
  .no-results {
    padding: 48px 20px;
    text-align: center;
    color: var(--color-muted);
    font-size: 16px;
    font-weight: 300;
    font-style: italic;
    font-family: var(--font-heading);
    background: var(--prim-glass);
    border-radius: 14px;
    border: 1px solid var(--color-outline);
  }

  /* ── BACK BUTTON ── */
  .back-btn {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    font-size: 15px;
    color: #1a2a4a;
    letter-spacing: 0.02em;
    cursor: pointer;
    margin-bottom: 28px;
    transition: transform 0.18s, box-shadow 0.18s;
    background: #fffaf0;
    border: 1px solid rgba(0, 80, 180, 0.12);
    border-radius: 999px;
    font-family: var(--font-body);
    padding: 10px 18px;
    text-decoration: none;
    box-shadow: 0 6px 18px rgba(0, 30, 100, 0.12);

    &:hover {
      transform: translateY(-1px);
      box-shadow: 0 10px 22px rgba(0, 30, 100, 0.18);
    }

    svg { width: 16px; height: 16px; }
  }

  /* ── DETAIL CARD ── */
  .detail-card {
    background: var(--color-surface);
    border: 1px solid var(--prim-card-border);
    border-radius: 18px;
    box-shadow: 0 6px 48px rgba(0, 30, 100, 0.25);
    overflow: hidden;
    margin-top: 10px;
  }

  .detail-head {
    padding: 32px 36px 26px;
    display: flex;
    align-items: flex-start;
    gap: 24px;
  }

  .detail-name {
    font-family: var(--font-heading);
    font-size: 46px;
    font-weight: 300;
    font-style: italic;
    color: var(--color-heading);
    line-height: 1;
    margin-bottom: 10px;
  }

  .detail-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    font-size: 13px;
    color: var(--color-on-surface-variant);
    font-weight: 300;
    margin-bottom: 10px;
    font-family: var(--font-body);
  }

  .detail-meta-item {
    display: flex;
    align-items: center;
    gap: 6px;

    svg {
      width: 13px;
      height: 13px;
      opacity: 0.55;
    }
  }

  .detail-badge {
    display: inline-block;
    background: var(--color-primary);
    color: #d4eeff;
    font-size: 10px;
    letter-spacing: 0.15em;
    padding: 4px 12px;
    border-radius: 20px;
    font-family: var(--font-body);
  }

  /* ── DETAIL STATS ── */
  .detail-stats {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    border-top: 1px solid rgba(0, 80, 180, 0.10);
  }

  .dstat {
    padding: 22px 12px;
    text-align: center;
    border-right: 1px solid var(--color-outline-variant);

    &:last-child { border-right: none; }
    &.zero { opacity: 0.38; }
  }

  .dstat-icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    margin: 0 auto 10px;
    display: flex;
    align-items: center;
    justify-content: center;

    svg { width: 18px; height: 18px; }
  }

  .obras-icon       { background: #ffe5d4; }
  .videos-icon      { background: #dce8ff; }
  .grabaciones-icon { background: #d6f0e0; }
  .partituras-icon  { background: #e2dcff; }
  .fotos-icon       { background: #ffefc8; }

  .dstat-num {
    font-family: var(--font-heading);
    font-size: 34px;
    font-weight: 600;
    line-height: 1;
    margin-bottom: 4px;
  }

  .dstat.zero .dstat-num { color: #bbc4d0; }

  .obras .dstat-num,
  .dstat:nth-child(1):not(.zero) .dstat-num { color: #d05418; }
  .dstat:nth-child(2):not(.zero) .dstat-num { color: #1a4fcc; }
  .dstat:nth-child(3):not(.zero) .dstat-num { color: #1a8040; }
  .dstat:nth-child(4):not(.zero) .dstat-num { color: #4433bb; }
  .dstat:nth-child(5):not(.zero) .dstat-num { color: #b07a10; }

  .dstat-label {
    font-size: 10px;
    color: var(--color-on-surface-variant);
    letter-spacing: 0.1em;
    text-transform: uppercase;
    font-family: var(--font-body);
  }

  /* ── BIOGRAPHY ── */
  .detail-bio {
    padding: 30px 36px 36px;
    border-top: 1px solid var(--color-outline-variant);
  }

  .bio-label {
    font-size: 10px;
    letter-spacing: 0.2em;
    color: var(--color-on-surface-variant);
    text-transform: uppercase;
    margin-bottom: 18px;
    display: flex;
    align-items: center;
    gap: 12px;
    font-family: var(--font-body);

    &::after {
      content: '';
      flex: 1;
      height: 1px;
      background: rgba(0, 80, 180, 0.10);
    }
  }

  .bio-text {
    font-family: var(--font-heading);
    font-size: 18px;
    font-weight: 300;
    line-height: 1.85;
    color: var(--prim-blue-body);

    &::after {
      content: "";
      display: block;
      clear: both;
    }

    p {
      margin-bottom: 1.2em;

      &:last-child {
        margin-bottom: 0;
      }
    }
  }

  .bio-photo {
    float: right;
    width: 260px;
    margin: 6px 0 18px 24px;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 10px 24px rgba(0, 30, 100, 0.18);

    img {
      width: 100%;
      height: auto;
      display: block;
    }
  }

  @media (max-width: 720px) {
    .bio-photo {
      float: none;
      width: 100%;
      margin: 0 0 18px;
    }
  }

  /* ── TRANSLATION MISSING BANNER ── */
  .translation-missing-banner {
    background: var(--color-warning-container);
    border: 1px solid rgba(200, 150, 0, 0.3);
    color: var(--color-on-warning-container);
    font-size: 0.85rem;
    padding: 0.65rem 1rem;
    border-radius: 6px;
    margin-bottom: 1.5rem;
    font-family: var(--font-body);
  }

  /* ── ARTICLE CARD ── */
  .article-card {
    background: var(--color-surface-container);
    border: 1px solid var(--prim-card-border);
    border-radius: 16px;
    box-shadow: 0 4px 24px rgba(0, 30, 100, 0.20);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    color: var(--color-on-surface);
  }

  /* ── ARTICLE BODY ── */
  .article-body {
    padding: 32px 36px 40px;
  }

  .article-title {
    font-family: var(--font-heading);
    font-size: 2.6rem;
    font-weight: 300;
    font-style: italic;
    color: var(--color-heading);
    line-height: 1.1;
    margin: 0 0 1.5rem;
  }

  /* ── ADMIN NAV ── */
  .admin-nav {
    position: sticky;
    top: 0;
    z-index: 100;
    background: var(--color-nav);
    backdrop-filter: blur(22px);
    -webkit-backdrop-filter: blur(22px);
    border-bottom: 1px solid rgba(255, 255, 255, 0.18);
    padding: 0 40px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 72px;

    .nav-brand {
      font-family: var(--font-heading);
      font-size: 19px;
      font-weight: 600;
      color: #fff;
      display: flex;
      align-items: center;
      gap: 10px;
      text-decoration: none;
    }

    .nav-logo {
      width: 40px;
      height: 40px;
      border-radius: 6px;
      object-fit: contain;
      background: rgba(255, 255, 255, 0.9);
      padding: 3px;
    }

    .nav-sub {
      font-size: 11px;
      font-weight: 300;
      color: var(--color-muted);
      letter-spacing: 0.07em;
      border-left: 1px solid rgba(255, 255, 255, 0.25);
      padding-left: 10px;
      font-family: var(--font-body);
    }

    .nav-actions {
      display: flex;
      align-items: center;
      gap: 16px;

      form {
        display: flex;
        align-items: center;
        margin: 0;
        padding: 0;
      }
    }

    .nav-link {
      color: rgba(255, 255, 255, 0.75);
      text-decoration: none;
      font-size: 12px;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      transition: opacity 0.15s;
      background: none;
      border: none;
      padding: 0;
      cursor: pointer;

      &:hover {
        color: #fff;
      }
    }
  }

  .admin-nav-stats {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    align-items: center;
    gap: 4px;
  }

  .nav-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 0 18px;
    gap: 3px;
  }

  .nav-stat-num {
    font-family: var(--font-heading);
    font-size: 22px;
    font-weight: 600;
    color: #fff;
    line-height: 1;
  }

  .nav-stat-label {
    font-size: 9px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-muted);
    font-family: var(--font-body);
  }

  .nav-stat-sep {
    width: 1px;
    height: 30px;
    background: rgba(255, 255, 255, 0.18);
    flex-shrink: 0;
  }

  /* ── ADMIN WRAPPER ── */
  .admin-wrapper {
    display: flex;
    gap: 24px;
    max-width: 1300px;
    margin: 0 auto;
    padding: 32px 40px 64px;
    align-items: flex-start;
  }

  /* ── ADMIN SIDEBAR ── */
  .admin-sidebar {
    width: 188px;
    flex-shrink: 0;
    background: var(--prim-glass);
    border: 1px solid var(--color-outline);
    border-radius: 14px;
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    padding: 10px;
    position: sticky;
    top: 92px;
  }

  .sidebar-label {
    font-size: 10px;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--color-muted);
    padding: 10px 10px 4px;
    font-family: var(--font-body);
  }

  .sidebar-link {
    display: block;
    padding: 8px 10px;
    border-radius: 8px;
    font-size: 13px;
    color: rgba(255, 255, 255, 0.85);
    text-decoration: none;
    font-family: var(--font-body);
    transition: background 0.15s;

    &:hover {
      background: rgba(255, 255, 255, 0.12);
      color: #fff;
    }

    &.active {
      background: rgba(255, 255, 255, 0.18);
      color: #fff;
      font-weight: 500;
    }
  }

  /* ── ADMIN MAIN ── */
  .admin-main {
    flex: 1;
    min-width: 0;
  }

  .admin-card {
    background: var(--color-surface-container);
    border: 1px solid var(--prim-card-border);
    border-radius: 16px;
    padding: 32px 36px;
    box-shadow: 0 4px 24px rgba(0, 30, 100, 0.20);
    color: var(--color-on-surface);
  }

  /* ── FLASH MESSAGES ── */
  .admin-flash-notice {
    background: rgba(255, 255, 255, 0.88);
    border: 1px solid rgba(0, 100, 200, 0.2);
    border-radius: 10px;
    padding: 12px 18px;
    margin-bottom: 20px;
    font-size: 13px;
    color: var(--color-heading);
    font-family: var(--font-body);
  }

  .admin-flash-alert {
    background: var(--color-error-container);
    border: 1px solid rgba(200, 0, 0, 0.2);
    border-radius: 10px;
    padding: 12px 18px;
    margin-bottom: 20px;
    font-size: 13px;
    color: var(--color-on-error-container);
    font-family: var(--font-body);
  }

  /* ── ADMIN FORM INPUTS ── */
  .admin-card input[type="text"],
  .admin-card input[type="email"],
  .admin-card input[type="password"],
  .admin-card input[type="date"],
  .admin-card input[type="number"],
  .admin-card input[type="url"],
  .admin-card input[type="file"],
  .admin-card textarea,
  .admin-card select {
    background-color: var(--color-surface) !important;
    color: var(--color-on-surface) !important;
  }

  /* ── ADMIN CONTENT WRAPPER ── */
  .admin-content {
    width: 100%;
  }

  .admin-sections {
    display: flex;
    flex-direction: column;
    gap: var(--space-xl);
  }

  /* ── ADMIN PAGE HEADER ── */
  .admin-page-header {
    display: flex;
    flex-direction: column;
    gap: var(--space-m);
    margin-bottom: var(--space-m);

    h1 {
      font-weight: 700;
      font-size: 2.25rem;
      line-height: 1.2;
      color: #111827;
      margin: 0;
    }

    @media (min-width: 640px) {
      flex-direction: row;
      align-items: center;
      justify-content: space-between;
    }
  }

  .admin-page-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
  }

  /* ── BUTTONS ── */
  .btn-primary, .btn-secondary, .btn-danger,
  .btn-primary-sm, .btn-secondary-sm,
  .btn-primary-xs, .btn-secondary-xs, .btn-danger-xs {
    display: inline-block;
    border-radius: 6px;
    font-weight: 500;
    font-family: var(--font-body);
    text-decoration: none;
    cursor: pointer;
    border: none;
    transition: background-color 0.15s;
    line-height: 1.2;
    text-align: center;
  }

  .btn-primary, .btn-secondary, .btn-danger {
    padding: 0.625rem 0.875rem;
    font-size: 0.875rem;
  }

  .btn-primary-sm, .btn-secondary-sm { padding: 0.375rem 0.75rem; font-size: 0.875rem; }
  .btn-primary-xs, .btn-secondary-xs, .btn-danger-xs { padding: 0.375rem 0.75rem; font-size: 0.75rem; }

  .btn-primary, .btn-primary-sm, .btn-primary-xs {
    background-color: var(--btn-primary);
    color: var(--btn-primary-text);
    &:hover { background-color: var(--btn-primary-hover); color: var(--btn-primary-text); }
  }

  .btn-secondary, .btn-secondary-sm, .btn-secondary-xs {
    background-color: var(--btn-secondary);
    color: var(--btn-secondary-text);
    &:hover { background-color: var(--btn-secondary-hover); color: var(--btn-secondary-text); }
  }

  .btn-danger, .btn-danger-xs {
    background-color: var(--btn-danger);
    color: var(--btn-danger-text);
    &:hover { background-color: var(--btn-danger-hover); color: var(--btn-danger-text); }
  }

  .btn-block {
    width: 100%;
    @media (min-width: 640px) { width: auto; }
  }

  /* ── STATUS BADGES ── */
  .badge {
    display: inline-flex;
    align-items: center;
    border-radius: 9999px;
    padding: 0.125rem 0.5rem;
    font-size: 0.75rem;
    font-weight: 500;
    font-family: var(--font-body);
    line-height: 1rem;
  }

  .badge-published   { background: #dcfce7; color: #15803d; }
  .badge-draft       { background: #f3f4f6; color: #4b5563; }
  .badge-ready       { background: #dbeafe; color: #1d4ed8; }
  .badge-needs-review { background: #fef3c7; color: #b45309; }
  .badge-needs-update { background: #ffedd5; color: #c2410c; }

  /* ── ADMIN RESOURCE GRID ── */
  .admin-resource-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.75rem;
    margin-top: 0.75rem;

    @media (min-width: 640px) { grid-template-columns: repeat(2, 1fr); }
    @media (min-width: 1024px) { grid-template-columns: repeat(3, 1fr); }

    > p {
      grid-column: 1 / -1;
      text-align: center;
      padding: 2.5rem 0;
      color: #6b7280;
    }
  }

  /* ── ADMIN LIST CARD (index card grids + mobile card list) ── */
  .admin-list-card {
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    padding: 1rem;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  }

  /* ── ADMIN RESOURCE CARD (show page sub-section items) ── */
  .admin-resource-card {
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    padding: 1rem;
  }

  /* Card content elements */
  .admin-card-label {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.025em;
    color: #6b7280;
    font-family: var(--font-body);
  }

  .admin-card-title {
    margin-top: 0.5rem;
    font-size: 0.875rem;
    font-weight: 600;
    color: #111827;
    font-family: var(--font-body);
  }

  .admin-card-meta {
    margin-top: 0.25rem;
    font-size: 0.75rem;
    color: #4b5563;
    font-family: var(--font-body);
  }

  .admin-card-actions {
    margin-top: 0.75rem;
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
  }

  /* Mobile card list — card title is larger */
  .admin-card-list .admin-card-title { font-size: 1.125rem; }

  /* ── ADMIN DETAIL PANEL (show page main info block) ── */
  .admin-detail-panel {
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    padding: 1.5rem;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);

    h2 {
      font-size: 1.125rem;
      font-weight: 600;
      color: #111827;
      margin: 0 0 1rem;
    }
  }

  .admin-detail-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;

    @media (min-width: 640px) { grid-template-columns: repeat(2, 1fr); }

    dt {
      font-size: 0.75rem;
      text-transform: uppercase;
      letter-spacing: 0.025em;
      color: #6b7280;
      margin-bottom: 0.25rem;
    }

    dd { font-size: 0.875rem; color: #111827; }

    .admin-detail-full {
      @media (min-width: 640px) { grid-column: span 2; }
    }
  }

  /* ── ADMIN SECTION HEADER (show page sub-section titles) ── */
  .admin-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;

    h3 {
      font-size: 1rem;
      font-weight: 600;
      color: #111827;
      margin: 0;
    }

    p {
      font-size: 0.875rem;
      color: #6b7280;
    }
  }

  /* ── ADMIN TABLE (desktop only, hidden on mobile) ── */
  .admin-table-wrap {
    display: none;
    margin-top: 1.5rem;

    @media (min-width: 1024px) { display: block; }
  }

  .admin-table {
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  }

  .admin-table-head {
    display: grid;
    grid-template-columns: var(--table-cols, 1fr);
    gap: 1rem;
    padding: 0.75rem 1rem;
    background: #f9fafb;
    border-bottom: 1px solid #e5e7eb;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.025em;
    color: #6b7280;
    font-family: var(--font-body);
  }

  .admin-table-row {
    display: grid;
    grid-template-columns: var(--table-cols, 1fr);
    gap: 1rem;
    padding: 0.75rem 1rem;
    border-bottom: 1px solid #f3f4f6;
    font-size: 0.875rem;
    color: #1f2937;
    align-items: center;

    &:last-child { border-bottom: none; }
  }

  .admin-table-cell-primary { font-weight: 500; color: #111827; }

  .admin-table-cell-center { text-align: center; color: #4b5563; }

  .admin-table-actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.5rem;
  }

  /* ── ADMIN MOBILE CARD LIST (shown on mobile, hidden on desktop) ── */
  .admin-card-list {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
    margin-top: 1.5rem;

    @media (min-width: 1024px) { display: none; }
  }

  /* ── ADMIN FORM FIELD ── */
  .admin-field {
    margin-bottom: 1.25rem;

    label {
      display: block;
      font-size: 0.875rem;
      font-weight: 500;
      color: #374151;
      margin-bottom: 0.375rem;
      font-family: var(--font-body);
    }

    input[type="text"],
    input[type="email"],
    input[type="password"],
    input[type="date"],
    input[type="number"],
    input[type="url"],
    textarea,
    select {
      display: block;
      width: 100%;
      padding: 0.5rem 0.75rem;
      margin-top: 0.5rem;
      border: 1px solid #9ca3af;
      border-radius: 6px;
      font-size: 0.875rem;
      font-family: var(--font-body);
      color: #111827;
      box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
      outline: none;
      background-color: #fff;

      &:focus { outline: 2px solid var(--color-primary); outline-offset: 0; }
    }

    &.admin-field--error {
      input[type="text"], input[type="email"], input[type="password"],
      input[type="date"], input[type="number"], input[type="url"],
      textarea, select {
        border-color: #f87171;
        &:focus { outline-color: #dc2626; }
      }
    }
  }

  .admin-file-field {
    display: block;
    width: 100%;
    font-size: 0.875rem;
    color: #374151;
    font-family: var(--font-body);
    margin-top: 0.5rem;

    &::file-selector-button {
      margin-right: 1rem;
      padding: 0.375rem 0.75rem;
      border-radius: 6px;
      border: none;
      background: #f3f4f6;
      font-size: 0.875rem;
      font-weight: 500;
      color: #374151;
      cursor: pointer;

      &:hover { background: #f9fafb; }
    }
  }

  .admin-checkbox-group {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 1.25rem;

    input[type="checkbox"] {
      width: 1rem;
      height: 1rem;
      border-radius: 4px;
      border: 1px solid #9ca3af;
      flex-shrink: 0;
    }

    label {
      font-size: 0.875rem;
      color: #4b5563;
      font-family: var(--font-body);
    }
  }

  /* ── FORM ERRORS ── */
  .form-errors {
    background: #fef2f2;
    color: #ef4444;
    padding: 0.5rem 0.75rem;
    border-radius: 6px;
    margin-bottom: 0.75rem;
    font-size: 0.875rem;
    font-weight: 500;
    font-family: var(--font-body);

    ul { list-style: disc; padding-left: 1.5rem; margin-top: 0.25rem; }
  }

  /* ── ADMIN PHOTO SECTION (composer form) ── */
  .admin-photo-section {
    margin-bottom: 1.25rem;
  }

  .admin-photo-header {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;

    h3 { font-size: 0.875rem; font-weight: 600; color: #374151; margin: 0; }
    span { font-size: 0.75rem; color: #6b7280; }
  }

  .admin-photo-preview {
    margin-top: 0.75rem;

    img { width: 12rem; height: 12rem; object-fit: cover; border-radius: 6px; border: 1px solid #e5e7eb; }
  }

  .admin-field-hint {
    font-size: 0.75rem;
    color: #9ca3af;
    margin-top: 0.25rem;
    font-family: var(--font-body);
  }

  /* ── ADMIN TABS (articles edit) ── */
  .admin-tabs {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    border-bottom: 1px solid #e5e7eb;
    margin-bottom: 1.5rem;
  }

  .admin-tabs-list { display: flex; }

  .admin-tab {
    padding: 0.625rem 1.25rem;
    font-size: 0.875rem;
    font-weight: 500;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    transition: color 0.15s;
    text-decoration: none;
    color: #6b7280;
    font-family: var(--font-body);

    &:hover { color: #374151; }

    &.active {
      border-bottom-color: var(--color-primary);
      color: var(--color-primary);
    }

    .badge { margin-left: 0.375rem; }

    .tab-new {
      font-size: 0.75rem;
      color: #9ca3af;
      margin-left: 0.375rem;
    }
  }

  .admin-tabs-actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding-bottom: 0.25rem;
  }

  /* ── ADMIN SLUG FIELD ── */
  .admin-slug-field {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.25rem;

    input[type="text"] {
      font-family: monospace;
      font-size: 0.875rem;
      border: 1px solid #d1d5db;
      border-radius: 6px;
      padding: 0.375rem 0.625rem;
      flex: 1;
      outline: none;
      &:focus { outline: 2px solid var(--color-primary); }
    }
  }

  /* ── ADMIN DETAILS/SUMMARY (collapsible SEO section) ── */
  .admin-details {
    margin-bottom: 1rem;

    summary {
      font-size: 0.75rem;
      color: #6b7280;
      cursor: pointer;
      font-family: var(--font-body);
      &:hover { color: #374151; }
    }

    > div {
      margin-top: 0.75rem;
      display: flex;
      flex-direction: column;
      gap: 0.75rem;
    }
  }

  /* ── ADMIN BACK LINK ── */
  .admin-back-link {
    display: inline-block;
    font-size: 0.875rem;
    color: #6b7280;
    text-decoration: none;
    margin-bottom: 1.25rem;
    font-family: var(--font-body);

    &:hover { color: #374151; }
  }

  /* ── ADMIN FORM NARROW (articles edit, passwords) ── */
  .admin-form-narrow { max-width: 48rem; }

  .admin-form-constraint {
    max-width: 42rem;
    margin: 0 auto;
    width: 100%;
  }

  /* ── AUTH PAGE ── */
  .auth-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #111827;
    padding: 1rem;
    position: absolute;
    inset: 0;
    z-index: 50;
  }

  .auth-card {
    max-width: 28rem;
    width: 100%;
    background: #fff;
    padding: 2.5rem;
    border-radius: 12px;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
    border: 1px solid #f3f4f6;

    h2 {
      margin-top: 1.5rem;
      text-align: center;
      font-size: 1.875rem;
      font-weight: 800;
      color: #111827;
      letter-spacing: -0.025em;
      font-family: var(--font-body);
    }

    p {
      margin-top: 0.5rem;
      text-align: center;
      font-size: 0.875rem;
      color: #4b5563;
      font-family: var(--font-body);
    }
  }

  .auth-fields {
    margin-top: 2rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
  }

  .auth-input {
    appearance: none;
    display: block;
    width: 100%;
    padding: 0.75rem;
    border: 1px solid #d1d5db;
    border-radius: 6px;
    font-size: 0.875rem;
    color: #111827;
    font-family: var(--font-body);
    outline: none;

    &::placeholder { color: #6b7280; }
    &:focus { outline: 2px solid var(--color-primary); border-color: var(--color-primary); }
  }

  .auth-forgot {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    margin-top: 0.5rem;

    a {
      font-size: 0.875rem;
      font-weight: 500;
      color: var(--color-primary);
      text-decoration: none;
      &:hover { color: var(--prim-blue-mid); }
    }
  }

  .auth-submit {
    margin-top: 1.5rem;
    width: 100%;
    display: flex;
    justify-content: center;
    padding: 0.75rem 1rem;
    border: none;
    border-radius: 6px;
    font-size: 0.875rem;
    font-weight: 500;
    color: #fff;
    background: #111827;
    cursor: pointer;
    transition: background-color 0.15s;
    font-family: var(--font-body);

    &:hover { background: #1f2937; }
    &:focus { outline: 2px solid #111827; outline-offset: 2px; }
  }

  .auth-flash-alert {
    background: #fef2f2;
    color: #b91c1c;
    padding: 1rem;
    border-radius: 6px;
    font-size: 0.875rem;
    text-align: center;
    border: 1px solid #fecaca;
    font-family: var(--font-body);
    margin-bottom: 1rem;
  }

  .auth-flash-notice {
    background: #eff6ff;
    color: #1d4ed8;
    padding: 1rem;
    border-radius: 6px;
    font-size: 0.875rem;
    text-align: center;
    border: 1px solid #bfdbfe;
    font-family: var(--font-body);
    margin-bottom: 1rem;
  }
}

@layer content {
  .prose-article {
    color: var(--color-on-surface);
  }
}

@layer components {
  /* ── TIPTAP EDITOR ── */

  .admin-rte-container {
    border: 1px solid rgba(0, 98, 184, 0.2);
    border-radius: 8px;
    overflow: hidden;
  }

  .tiptap-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 4px;
    padding: 6px 8px;
    background: #f0f5ff;
    border-bottom: 1px solid rgba(0, 98, 184, 0.2);
  }

  .tiptap-group {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 1px;
    padding: 2px;
    border: 1px solid rgba(0, 98, 184, 0.2);
    border-radius: 4px;
  }

  .tiptap-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 28px;
    height: 28px;
    padding: 0 6px;
    border: none;
    border-radius: 3px;
    background: transparent;
    color: var(--prim-blue-muted);
    font-family: var(--font-body);
    font-size: 12px;
    cursor: pointer;
    transition: background 0.15s, color 0.15s;

    &:hover     { background: #dbeafe; color: var(--prim-blue-flag); }
    &.is-active { background: rgba(0, 98, 184, 0.12); color: var(--prim-blue-flag); }
  }

  .tiptap-content {
    min-height: 480px;
    padding: 24px 30px;
    outline: none;
    font-family: var(--font-body);
    font-size: 16px;
    color: var(--color-on-surface);
    line-height: 1.8;
    background: #ffffff;

    h1 { font-family: var(--font-heading); font-size: 1.7rem; color: var(--color-heading); font-weight: 600; margin: 1rem 0 0.5rem; }
    h2 { font-family: var(--font-heading); font-size: 1.4rem; color: var(--color-heading); font-weight: 600; margin: 1rem 0 0.5rem; }
    h3 { font-family: var(--font-heading); font-size: 1.2rem; color: var(--color-heading); margin: 1rem 0 0.5rem; }
    h4 { font-family: var(--font-heading); font-size: 1rem;   color: var(--color-heading); margin: 1rem 0 0.5rem; }
    p  { margin: 0 0 0.75rem; }
    a  { color: var(--color-primary); text-decoration: underline; }

    blockquote {
      border-left: 4px solid var(--color-primary);
      padding-left: 1.5em;
      font-style: italic;
      margin: 2em 0;
      color: var(--prim-blue-muted);
    }

    ul { list-style: disc;    padding-left: 1.5em; margin: 0.75rem 0; }
    ol { list-style: decimal; padding-left: 1.5em; margin: 0.75rem 0; }
    li { margin-bottom: 0.25rem; }

    hr { border: none; border-top: 1px solid rgba(0, 98, 184, 0.2); margin: 2rem 0; }

    figure {
      margin: 1.5rem 0;
      img { max-width: 100%; height: auto; display: block; }
    }

    &::after { content: ""; display: table; clear: both; }
  }

  /* Image NodeView */
  .image-resize-wrapper {
    position: relative;
    max-width: 100%;
    line-height: 0;
  }

  .image-resize-figure {
    position: relative;
    display: block;
    margin: 0;
    padding: 0;
  }

  .image-resize-handle {
    position: absolute;
    width: 8px;
    height: 8px;
    background: var(--prim-blue-flag);
    border: 1px solid #fff;
    display: none;
  }

  .image-resize-wrapper.ProseMirror-selectednode .image-resize-handle {
    display: block;
  }

  .image-resize-wrapper.ProseMirror-selectednode .image-resize-figure {
    outline: 1px dashed var(--prim-blue-muted);
  }

  .image-align-menu {
    background: #ffffff;
    border: 1px solid rgba(0, 98, 184, 0.2);
    border-radius: 4px;
    padding: 4px 0;
    min-width: 130px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  }

  .image-align-item {
    padding: 6px 14px;
    font-family: var(--font-body);
    font-size: 12px;
    color: var(--color-on-surface);
    cursor: pointer;

    &:hover { background: #dbeafe; color: var(--prim-blue-flag); }
  }

  .tiptap-dropdown-trigger {
    gap: 4px;
    padding: 0 6px;
    min-width: unset;
  }

  .tiptap-dropdown-panel {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    z-index: 200;
    background: #ffffff;
    border: 1px solid rgba(0, 98, 184, 0.2);
    border-radius: 4px;
    padding: 4px 0;
    min-width: 150px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
  }

  .tiptap-dropdown-item {
    display: flex;
    align-items: center;
    width: 100%;
    padding: 7px 12px;
    background: transparent;
    border: none;
    color: var(--color-on-surface);
    font-family: var(--font-body);
    font-size: 12px;
    text-align: left;
    cursor: pointer;
    white-space: nowrap;

    &:hover     { background: #dbeafe; color: var(--prim-blue-flag); }
    &.is-active { color: var(--prim-blue-flag); }
  }

  .tiptap-table-panel {
    min-width: unset;
    padding: 6px;
  }

  .tiptap-content ul[data-type="taskList"] {
    list-style: none;
    padding-left: 0;
  }

  .tiptap-content ul[data-type="taskList"] li {
    display: flex;
    align-items: flex-start;
    gap: 0.5em;
  }

  .tiptap-content ul[data-type="taskList"] li > label {
    margin-top: 3px;
    flex-shrink: 0;
  }

  .tiptap-content ul[data-type="taskList"] li > div {
    flex: 1;
  }

  .tiptap-content table {
    border-collapse: collapse;
    width: 100%;
    margin: 1rem 0;
    font-size: 14px;
  }

  .tiptap-content th,
  .tiptap-content td {
    border: 1px solid rgba(0, 98, 184, 0.2);
    padding: 6px 10px;
    vertical-align: top;
  }

  .tiptap-content th {
    background: rgba(0, 98, 184, 0.06);
    color: var(--prim-blue-text);
    font-weight: bold;
  }
}
