/* ============================================================
   DATA CATALOG — Component Styles
   Tokens imported from tokens.css
   ============================================================ */
@import url('tokens.css');

/* === 1. RESET & BASE === */
*, *::before, *::after { box-sizing: border-box; }

html {
    word-spacing: var(--word-spacing);
    -webkit-text-size-adjust: 100%;
}

body {
    margin: 0;
    font-family: var(--font-family);
    font-size: var(--text-base);
    line-height: var(--line-height-body);
    color: var(--color-body);
    background: var(--color-bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

a { text-decoration: none; color: inherit; cursor: pointer; }
u { text-underline-offset: 2px; }
del, strike { text-decoration: line-through; }
mark { background: var(--color-primary-200); padding: 0.125em 0.25rem; }
[id] { scroll-margin-top: var(--space-8); }
.hidden { display: none !important; }

.material-symbols-rounded {
    font-size: var(--text-xl);
    vertical-align: middle;
    user-select: none;
}

/* === 2. SKIP TO CONTENT === */
.skip-to-content {
    position: absolute;
    top: -100%;
    left: var(--space-4);
    background: var(--color-secondary-900);
    color: white;
    padding: var(--space-3) var(--space-5);
    border: 2px solid white;
    border-radius: var(--radius);
    box-shadow: var(--shadow-md);
    font-size: var(--text-sm);
    z-index: 9999;
    text-decoration: none;
}
.skip-to-content:focus { top: var(--space-2); }

/* === 3. FOCUS RING === */
:focus-visible {
    outline: 2px solid var(--color-focus-ring);
    outline-offset: 2px;
}

/* === 4. LAYOUT === */
.container {
    max-width: var(--container-max);
    margin: 0 auto;
    padding-left: var(--container-px);
    padding-right: var(--container-px);
    width: 100%;
}

.main-wrapper { flex: 1; }

/* === 5. HEADER & BRANDING === */
header { width: 100%; }

.top-header {
    border-bottom: 1px solid var(--color-border);
}

.top-header__inner {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    padding-top: var(--space-3);
    padding-bottom: var(--space-3);
}

.logo {
    display: flex;
    align-items: flex-start;
    flex-wrap: nowrap;
}

.logo__flag {
    flex-shrink: 0;
    width: 30px;
    height: 33px;
}

.logo__name {
    flex-shrink: 0;
    display: none;
    width: 174px;
    height: 50px;
    overflow: visible;
}

.logo__separator {
    width: 1px;
    height: 2.5rem;       /* 40px */
    margin: 0 var(--space-2);
    background: #D1D5DB;
    flex-shrink: 0;
    overflow: visible;
}

.logo__title {
    font-size: var(--text-sm);
    font-weight: var(--font-weight-bold);
    line-height: var(--line-height-snug);
    color: var(--color-heading);
    position: relative;
    top: -0.16rem;
}
.logo__title strong { display: block; }
.logo__subtitle {
    display: block;
    font-weight: var(--font-weight-normal);
}

.meta-navigation {
    font-size: var(--text-sm);
    display: flex;
    gap: var(--space-6);
    color: var(--color-heading);
    align-items: center;
}
.meta-navigation a:hover { color: var(--color-link); }

/* Language Selector */
.language-switcher { display: flex; align-items: center; gap: 2px; }
.language-switcher__btn {
    background: none;
    border: none;
    font-family: inherit;
    font-size: var(--text-sm);
    color: var(--color-text-600);
    padding: var(--space-1) var(--space-2);
    cursor: pointer;
    border-radius: var(--radius);
    font-weight: var(--font-weight-normal);
    transition: color var(--transition-fast), background-color var(--transition-fast);
}
.language-switcher__btn:hover { color: var(--color-link); background: var(--color-bg-hover); }
.language-switcher__btn.active { color: var(--color-heading); font-weight: var(--font-weight-bold); }

/* === 6. NAVIGATION === */
.main-navigation {
    border-bottom: 1px solid var(--color-border);
    height: var(--nav-height);
    display: flex;
    align-items: stretch;
}

.nav-tabs {
    display: flex;
    height: 100%;
    align-items: stretch;
}
.nav-tabs .nav-link:first-child {
    margin-left: calc(-1 * var(--space-4));
}
.nav-link {
    padding: 0 var(--space-4);
    font-size: var(--text-base);
    color: var(--color-body);
    background: none;
    border: none;
    font-family: inherit;
    cursor: pointer;
    display: flex;
    align-items: center;
    position: relative;
    white-space: nowrap;
    transition: color var(--transition-fast);
}
.nav-link:hover { color: var(--color-link); }
.nav-link.active { font-weight: var(--font-weight-normal); color: var(--color-accent); }
.nav-link.active::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: var(--space-4);
    right: var(--space-4);
    height: 3px;
    background: var(--color-accent);
}

/* === 7. BREADCRUMB === */
.breadcrumb {
    display: none;
    padding: var(--space-2) 0;
    font-size: var(--text-sm);
    color: var(--color-muted);
}
.breadcrumb span { margin: 0 var(--space-2); color: var(--color-text-400); }
.breadcrumb a:hover { color: var(--color-link); }

/* === 7b. SHARE BAR === */
.share-bar {
    display: flex;
    flex-direction: row-reverse;
    align-items: center;
    gap: var(--space-3);
    margin-top: var(--space-5);
    margin-right: calc(-1 * var(--space-3));
    color: var(--color-muted);
}
.btn--bare {
    cursor: pointer;
    padding: var(--space-2);
    border: none;
    background: none;
    color: inherit;
    font-family: inherit;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color var(--transition-fast), color var(--transition-fast);
}
.btn--bare:hover { background-color: var(--color-text-100); color: var(--color-accent); }
.btn--bare .material-symbols-rounded { font-size: 1.5rem; }

/* === 8. PAGE TITLE & TOOLBAR === */
h1.page-title {
    font-size: var(--text-3xl);
    font-weight: var(--font-weight-bold);
    margin: var(--space-4) 0 var(--space-10) 0;
    color: var(--color-heading);
    line-height: var(--line-height-heading);
}

.page-title-h2 {
    font-size: var(--text-3xl) !important;
    font-weight: var(--font-weight-bold) !important;
    margin: var(--space-4) 0 var(--space-10) 0 !important;
    color: var(--color-heading) !important;
    line-height: var(--line-height-heading);
}

.toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-10);
}
.search__group { display: flex; gap: var(--space-3); width: 100%; max-width: 500px; }
.form__group { width: 280px; flex-shrink: 0; position: relative; }

.form__group input {
    width: 100%;
    padding: var(--space-3) var(--space-4) var(--space-3) var(--space-12);
    border: 1px solid var(--color-border-input);
    border-radius: var(--radius-sm);
    font-size: var(--text-base);
    font-family: inherit;
    height: var(--input-height);
    color: var(--color-body);
    background: var(--color-bg);
    box-shadow: var(--shadow);
    transition: border-color var(--transition-fast);
}
.form__group input::placeholder { color: var(--color-secondary-400); }
.form__group input:focus { outline: none; border-color: var(--color-secondary-600); box-shadow: 0 0 0 1px var(--color-secondary-600); }

.search__icon {
    position: absolute;
    left: var(--space-4);
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-muted);
    pointer-events: none;
    font-size: 1.375rem;
}

/* === 9. BUTTON SYSTEM === */

/* Outline button — DS: .btn--outline */
.btn--outline {
    height: var(--input-height);
    padding: 0 var(--space-4);
    background: var(--color-bg);
    border: 1px solid var(--color-primary-600);
    border-radius: var(--radius-sm);
    font-size: var(--text-base);
    font-family: inherit;
    color: var(--color-primary-600);
    line-height: 1.25;
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    cursor: pointer;
    transition: all var(--transition-fast);
}
.btn--outline:hover {
    background: var(--color-primary-50);
    border-color: var(--color-primary-700);
    color: var(--color-primary-700);
}

/* Filled button — DS: .btn--filled */
.btn--filled {
    height: var(--input-height);
    padding: 0 var(--space-4);
    background: var(--color-secondary-500);
    border: 1px solid var(--color-secondary-500);
    border-radius: var(--radius-sm);
    font-size: var(--text-base);
    font-weight: var(--font-weight-bold);
    font-family: inherit;
    color: white;
    line-height: 1.25;
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    cursor: pointer;
    transition: all var(--transition-fast);
}
.btn--filled:hover {
    background: var(--color-secondary-600);
    border-color: var(--color-secondary-600);
}

/* Filter button */
.btn-filter {
    height: var(--input-height);
    padding: 0 var(--space-4);
    background: var(--color-bg);
    border: 1px solid var(--color-border-input);
    border-radius: var(--radius-sm);
    font-size: var(--text-sm);
    font-weight: var(--font-weight-bold);
    font-family: inherit;
    display: flex;
    align-items: center;
    gap: var(--space-2);
    cursor: pointer;
    position: relative;
    transition: all var(--transition-fast);
    color: var(--color-body);
}
.btn-filter:hover { background: var(--color-bg-hover); border-color: var(--color-text-600); }

.filter-count {
    position: absolute;
    top: -10px;
    right: -10px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-text-600);
    color: white;
    font-size: var(--text-xs);
    font-weight: var(--font-weight-bold);
    min-width: 22px;
    height: 22px;
    padding: 0 6px;
    border-radius: var(--radius-full);
}
.filter-count.hidden { display: none; }

.btn-filter.active { background: var(--color-secondary-600); color: white; border-color: var(--color-secondary-600); }
.btn-filter.active:hover { background: var(--color-secondary-700); }

/* Reset button */
.btn-reset {
    height: var(--input-height);
    padding: 0 var(--space-4);
    background: var(--color-bg);
    border: 1px solid var(--color-border-input);
    border-radius: var(--radius-sm);
    font-size: var(--text-sm);
    font-family: inherit;
    display: flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
    color: var(--color-body);
    transition: all var(--transition-fast);
}
.btn-reset:hover { background: var(--color-bg-hover); border-color: var(--color-secondary-600); }
.btn-reset.hidden { display: none; }

/* View toggles */
.view-toggles { display: flex; gap: var(--space-3); }
.toggle-icon {
    width: var(--input-height);
    height: var(--input-height);
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    padding: 0;
    font-family: inherit;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: background-color var(--transition-fast);
}
.toggle-icon.active { background: var(--color-secondary-600); color: white; pointer-events: none; }
.toggle-icon.inactive { background: var(--color-bg); color: var(--color-secondary-600); border: 1px solid var(--color-border-input); }
.toggle-icon.inactive:hover { background: var(--color-bg-hover); }

/* === 10. CATALOG LAYOUT === */
.catalog-layout {
    display: flex;
    gap: var(--space-8);
    margin-bottom: var(--space-14);
}

.filter-panel {
    width: var(--filter-panel-width);
    flex-shrink: 0;
    overflow: hidden;
    transition: width 0.25s ease, opacity 0.25s ease, margin-right 0.25s ease;
    opacity: 1;
}
.filter-panel.hidden { width: 0; opacity: 0; margin-right: calc(-1 * var(--space-8)); }

.catalog-content { flex: 1; min-width: 0; }

/* === 11. FILTER PANEL === */
.filter-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-5);
    padding-bottom: var(--space-3);
    border-bottom: 1px solid var(--color-border);
}

.filter-title {
    font-size: var(--text-lg);
    font-weight: var(--font-weight-bold);
    line-height: var(--line-height-heading);
    color: var(--color-heading);
}

.filter-reset {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    background: none;
    border: none;
    color: var(--color-muted);
    font-size: var(--text-sm);
    font-family: inherit;
    cursor: pointer;
    padding: var(--space-1) var(--space-2);
    border-radius: var(--radius);
    transition: all var(--transition-fast);
}
.filter-reset:hover { background: var(--color-text-100); color: var(--color-text-700); }

.filter-section { margin-bottom: var(--space-5); }

.filter-label {
    display: block;
    font-size: var(--text-xs);
    color: var(--color-muted);
    margin-bottom: 6px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-weight: var(--font-weight-bold);
}

.filter-select {
    width: 100%;
    padding: var(--space-3) var(--space-3);
    border: 1px solid var(--color-border-input);
    border-radius: var(--radius-xs);
    background: var(--color-bg);
    font-size: var(--text-sm);
    font-family: inherit;
    color: var(--color-body);
    cursor: pointer;
    appearance: none;
    box-shadow: var(--shadow);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right var(--space-3) center;
    transition: border-color var(--transition-fast);
}
.filter-select:focus { outline: none; border-color: var(--color-secondary-600); box-shadow: 0 0 0 1px var(--color-secondary-600); }
.filter-select:hover { border-color: var(--color-text-600); }

/* Tag Input */
.tag-form__group { position: relative; }

.tag-input-field {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    padding: var(--space-2) var(--space-3);
    border: 1px solid var(--color-border-input);
    border-radius: var(--radius-xs);
    background: var(--color-bg);
    cursor: text;
    min-height: var(--input-height);
    box-shadow: var(--shadow);
    transition: border-color var(--transition-fast);
}
.tag-input-field:focus-within { border-color: var(--color-secondary-600); box-shadow: 0 0 0 1px var(--color-secondary-600); }

.badge-filter--active {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    background: var(--color-secondary-600);
    color: white;
    padding: var(--space-1) var(--space-2) var(--space-1) var(--space-3);
    border-radius: var(--radius-full);
    font-size: var(--text-sm);
    white-space: nowrap;
}
.badge-filter--active .remove {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    cursor: pointer;
    font-size: var(--text-lg);
    line-height: 1;
    opacity: 0.7;
}
.badge-filter--active .remove:hover { opacity: 1; background: rgba(255,255,255,0.2); }

.tag-search-input {
    border: none;
    outline: none;
    flex: 1;
    min-width: 100px;
    font-size: var(--text-sm);
    font-family: inherit;
    background: transparent;
    color: var(--color-body);
}
.tag-search-input::placeholder { color: var(--color-secondary-400); }

.tag-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-top: none;
    border-radius: 0 0 var(--radius) var(--radius);
    max-height: 200px;
    overflow-y: auto;
    z-index: 100;
    box-shadow: var(--shadow-lg);
}
.tag-dropdown.hidden { display: none; }

.tag-option {
    padding: var(--space-3);
    cursor: pointer;
    font-size: var(--text-sm);
    color: var(--color-text-700);
}
.tag-option:hover { background: var(--color-bg-hover); }

.tag-option-empty {
    padding: var(--space-3);
    font-size: var(--text-sm);
    color: var(--color-muted);
    font-style: italic;
}

/* === 12. CARDS & GRID === */
.grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: var(--space-7);
}

.card {
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    box-shadow: var(--shadow-lg);
    transition: box-shadow var(--transition-slow) ease-in-out;
    cursor: pointer;
    width: 100%;
    position: relative;
}
.card:hover,
.card:focus-within { box-shadow: var(--shadow-2xl); }
.card:hover .card__title,
.card:focus-within .card__title { color: var(--color-primary-700); }

.card__image {
    position: relative;
    background: var(--color-secondary-50);
    padding-bottom: 56.25%; /* 16:9 */
    height: 0;
    overflow: hidden;
}
.card__img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; }
.card__badges { position: absolute; top: var(--space-4); left: var(--space-4); display: flex; gap: var(--space-2); }

.card__body { padding: var(--space-10) var(--space-6) var(--space-6); display: flex; flex-direction: column; flex-grow: 1; }
.card__title {
    font-size: var(--text-lg);
    font-weight: var(--font-weight-bold);
    margin: 0 0 var(--space-4) 0;
    color: var(--color-heading);
    line-height: var(--line-height-snug);
    transition: color var(--transition-base);
}
.card__description {
    font-size: var(--text-base);
    line-height: var(--line-height-body);
    color: var(--color-text-700);
    margin: 0 0 var(--space-6) 0;
    flex-grow: 1;
    display: -webkit-box;
    -webkit-line-clamp: 6;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.card__footer { display: flex; justify-content: space-between; align-items: flex-end; gap: var(--space-4); }
.card__tags { display: flex; flex-wrap: wrap; gap: var(--space-2); }

.card__action {
    width: var(--space-10);
    height: var(--space-10);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-accent);
    flex-shrink: 0;
    transition: all var(--transition-fast);
}
.card__action:hover { border-color: var(--color-accent); background: var(--color-accent); color: white; }

/* === 13. TAG / BADGE SYSTEM === */
.badge {
    padding: 0.219em 1em;
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    font-weight: var(--font-weight-normal);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    white-space: nowrap;
    transition: all var(--transition-fast) ease;
    background: var(--color-gray-200);
    color: var(--color-body);
    border: none;
}
.badge:hover { background: var(--color-gray-300); color: var(--color-heading); }

.badge.badge--active { background: var(--color-gray-800); color: white; }
.badge.badge--active:hover { background: var(--color-text-900); }

/* Colored badge variants */
.badge--blue   { background: var(--color-blue-100);   color: var(--color-blue-800); }
.badge--blue:hover { background: var(--color-blue-200); }
.badge--green  { background: var(--color-green-100);  color: var(--color-green-800); }
.badge--green:hover { background: var(--color-green-200); }
.badge--red    { background: var(--color-red-100);    color: var(--color-red-800); }
.badge--red:hover { background: var(--color-primary-200); }
.badge--orange { background: var(--color-orange-100); color: var(--color-orange-800); }
.badge--orange:hover { background: var(--color-orange-200); }
.badge--yellow { background: var(--color-yellow-100); color: var(--color-yellow-800); }
.badge--yellow:hover { background: var(--color-yellow-200); }
.badge--indigo { background: var(--color-indigo-100); color: var(--color-indigo-800); }
.badge--indigo:hover { background: var(--color-indigo-200); }
.badge--purple { background: var(--color-purple-100); color: var(--color-purple-800); }
.badge--purple:hover { background: var(--color-purple-200); }
.badge--pink   { background: var(--color-pink-100);   color: var(--color-pink-800); }
.badge--pink:hover { background: var(--color-pink-200); }

/* Tag Label (non-clickable overlay) */
.badge--overlay {
    background: rgba(0, 0, 0, 0.55);
    border: none;
    padding: 0.219em 1em;
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    color: white;
    font-weight: 500;
    display: inline-block;
    white-space: nowrap;
    cursor: default;
    pointer-events: none;
}

/* === 14. LIST VIEW === */
.table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--text-base);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-md);
}
.table th {
    text-align: left;
    background: var(--color-secondary-50);
    padding: var(--space-4) var(--space-6);
    color: var(--color-text-700);
    font-size: var(--text-sm);
    font-weight: var(--font-weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.025em;
}
.table td {
    padding: var(--space-4) var(--space-6);
    border-top: 1px solid var(--color-border-strong);
    vertical-align: top;
}
.table tbody tr { cursor: pointer; transition: background-color 0.1s; }
.table tbody tr:hover { background-color: var(--color-bg-hover); }

.col-title { font-weight: var(--font-weight-bold); font-size: var(--text-base); color: var(--color-heading); width: 25%; }
.col-desc { color: var(--color-text-600); line-height: var(--line-height-body); }
.col-tags { width: 30%; text-align: right; }
.col-tags .badge { margin-left: var(--space-1); margin-bottom: var(--space-1); }
.table th:last-child { text-align: right; }

/* === 15. DETAIL VIEW === */
.hero { display: flex; gap: var(--space-12); margin-bottom: var(--space-14); margin-top: var(--space-3); }
.hero__content { flex: 1; }
.hero__image { flex: 1; max-width: 600px; }
.hero__image img { width: 100%; height: auto; border-radius: var(--radius-sm); }
.hero__tags { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-bottom: var(--space-6); }
.hero__description { font-size: var(--text-lg); line-height: var(--line-height-snug); margin-bottom: var(--space-8); color: var(--color-text-700); }

.box {
    background: var(--color-bg-light);
    padding: var(--space-4);
    margin: var(--space-12) 0;
}
.box__title { font-weight: var(--font-weight-bold); margin-bottom: var(--space-2); font-size: var(--text-lg); line-height: var(--line-height-heading); color: var(--color-heading); }
.box__text { font-size: var(--text-base); font-style: italic; color: var(--color-muted); }

.box-section { margin: var(--space-12) 0; }
.box-section .section-title { margin-top: 0; }
.box-section__list { border-top: 1px solid var(--color-border); }
.link { color: var(--color-link); text-decoration: underline; text-underline-offset: 2px; }
.link:hover { text-decoration: none; color: var(--color-link-hover); }

.section-title {
    font-size: var(--text-xl);
    font-weight: var(--font-weight-bold);
    line-height: var(--line-height-heading);
    margin: var(--space-12) 0 var(--space-6) 0;
    color: var(--color-heading);
}

/* === 16. DATA ROWS === */
.data-row {
    display: flex;
    padding: var(--space-4);
    border-bottom: 1px solid var(--color-border);
    font-size: var(--text-base);
    align-items: center;
    transition: background-color 0.1s;
}
.data-row:hover { background-color: var(--color-bg-hover); }
.data-row__key { width: 280px; font-weight: var(--font-weight-normal); flex-shrink: 0; color: var(--color-text-700); }
.data-row__value { color: var(--color-heading); display: flex; align-items: center; flex-wrap: wrap; gap: var(--space-2); }

.meta-list, .distributions-list, .publications-list { border-top: 1px solid var(--color-border); }

/* === 17. ACCORDION (Distributions) === */
.accordion__item { border-top: 1px solid var(--color-secondary-200); }
.accordion__item:last-of-type { border-bottom: 1px solid var(--color-secondary-200); }

.accordion__button {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-3) var(--space-2);
    font-size: var(--text-base);
    font-weight: var(--font-weight-bold);
    cursor: pointer;
    transition: color var(--transition-base);
}
.accordion__button:hover { color: var(--color-accent); }

.accordion__title { color: var(--color-heading); flex-grow: 1; }
.accordion__meta {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    color: var(--color-muted);
}
.accordion__meta .accordion__arrow {
    font-size: 1.5rem;
    transition: transform var(--transition-base) ease;
}
.accordion__item.expanded .accordion__arrow { transform: rotate(180deg); }
.accordion__format { font-size: var(--text-sm); font-weight: 500; }

.accordion__drawer {
    max-height: 0;
    overflow: hidden;
    transition: max-height var(--transition-slow) ease-out;
    padding: 0 var(--space-2);
}
.accordion__item.expanded .accordion__drawer {
    max-height: 800px;
    padding: 0 var(--space-2) var(--space-10) var(--space-2);
}

.accordion__detail-row {
    display: flex;
    padding: var(--space-3) 0;
    border-bottom: 1px solid var(--color-border);
    font-size: var(--text-base);
}
.accordion__detail-row:last-child { border-bottom: none; }
.accordion__detail-key { width: 200px; flex-shrink: 0; color: var(--color-muted); }
.accordion__detail-val { color: var(--color-heading); word-break: break-all; }

/* === 18. ATTRIBUTES TABLE === */
.table.table--attributes {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--text-base);
    margin-top: var(--space-5);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-md);
}
.table.table--attributes th {
    text-align: left;
    background: var(--color-secondary-50);
    padding: var(--space-4) var(--space-6);
    color: var(--color-text-700);
    font-size: var(--text-sm);
    font-weight: var(--font-weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.025em;
}
.table.table--attributes td {
    padding: var(--space-4) var(--space-6);
    border-top: 1px solid var(--color-border-strong);
    vertical-align: top;
    line-height: var(--line-height-body);
}
.table.table--attributes tbody tr:hover { background-color: var(--color-bg-hover); }
.attr-col-name { width: 20%; }
.attr-col-format { width: 15%; }
.attr-col-key { width: 10%; }
.attr-col-list { width: 15%; }

.section-spacer { height: var(--space-14); }

/* === 19. CONTENT PAGES === */
.content-page { padding-bottom: var(--space-14); }
.content-page h2 { font-size: var(--text-2xl); font-weight: var(--font-weight-bold); line-height: var(--line-height-heading); margin-top: var(--space-12); margin-bottom: var(--space-5); color: var(--color-heading); }
.content-page h3 { font-size: var(--text-xl); font-weight: var(--font-weight-bold); line-height: var(--line-height-heading); margin-top: var(--space-10); margin-bottom: var(--space-4); color: var(--color-heading); }
.content-page p { font-size: var(--text-base); line-height: var(--line-height-relaxed); margin-bottom: var(--space-5); color: var(--color-text-700); }
.content-page ul { list-style-type: disc; padding-left: var(--space-6); margin-bottom: var(--space-5); }
.content-page li { font-size: var(--text-base); line-height: var(--line-height-relaxed); margin-bottom: var(--space-2); color: var(--color-text-700); }
.content-page strong { font-weight: var(--font-weight-bold); }
.content-page .info-link { margin-top: var(--space-8); }
.content-page a:not(.footer-link) { color: var(--color-link); text-decoration: underline; text-underline-offset: 2px; }
.content-page a:not(.footer-link):hover { text-decoration: none; color: var(--color-link-hover); }

.manual-img {
    display: block;
    max-width: 100%;
    height: auto;
    margin: var(--space-8) 0;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
}

/* === 20. FOOTER === */
footer { background-color: var(--color-secondary-700); color: white; margin-top: auto; }

.footer-information {
    background-color: var(--color-secondary-600);
    padding: var(--space-14) 0;
    border-bottom: 1px solid var(--color-secondary-500);
}

.footer-information__columns { display: flex; gap: var(--space-16); }

.footer-information__entry h4 {
    font-size: var(--text-xl);
    font-weight: var(--font-weight-bold);
    margin: 0 0 var(--space-6) 0;
    color: white;
    line-height: var(--line-height-heading);
}
.footer-information__entry { margin-bottom: var(--space-16); }
.footer-information__entry ul { list-style: none; padding: 0; margin: 0; }
.footer-information__entry li { margin-bottom: 0; }
.footer-information__entry a {
    font-size: var(--text-sm);
    color: white;
    transition: color var(--transition-fast);
    display: flex;
    justify-content: space-between;
    padding: var(--space-4) var(--space-2);
    border-bottom: 1px solid var(--color-secondary-400);
}
.footer-information__entry a:hover { color: var(--color-text-300); }

.footer-navigation { padding: var(--space-3) 0; }
.footer-navigation__inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: var(--text-xs);
}
.footer-navigation__left { display: flex; gap: var(--space-2); }
.footer-link {
    color: var(--color-text-300);
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: var(--text-xs);
    transition: color var(--transition-fast);
}
.footer-link:hover { color: white; text-decoration: underline; }
.footer-link .material-symbols-rounded { font-size: var(--text-sm); }
.footer-navigation__right { color: var(--color-text-400); }

/* === 21. DETAIL VIEW LINKS === */
#view-concept-detail a:not(.footer-link),
#view-dataset-detail a:not(.footer-link) {
    color: var(--color-link);
    text-decoration: underline;
    text-underline-offset: 2px;
}
#view-concept-detail a:not(.footer-link):hover,
#view-dataset-detail a:not(.footer-link):hover {
    text-decoration: none;
    color: var(--color-link-hover);
}

/* === 22. NO RESULTS === */
.no-results { text-align: center; padding: var(--space-16) var(--space-5); color: var(--color-muted); }
.no-results__icon { font-size: var(--text-6xl); margin-bottom: var(--space-4); opacity: 0.5; }
.no-results__text { font-size: var(--text-base); }

/* === 23. SHARE MODAL === */
.modal__backdrop {
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(17, 24, 39, 0.7);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1000;
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--transition-base), visibility var(--transition-base);
}
.modal__backdrop.visible { opacity: 1; visibility: visible; }

.modal__content {
    background: var(--color-bg);
    width: 100%;
    max-width: 420px;
    max-height: 80vh;
    overflow-y: auto;
    border-radius: var(--radius);
    box-shadow: var(--shadow-2xl);
    transform: translateY(-20px);
    transition: transform var(--transition-base);
}
.modal__backdrop.visible .modal__content { transform: translateY(0); }

.modal__header {
    background: var(--color-secondary-800);
    color: white;
    padding: var(--space-4) var(--space-5);
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: var(--text-lg);
    font-weight: var(--font-weight-bold);
}
.modal__close {
    background: none;
    border: none;
    color: white;
    cursor: pointer;
    padding: var(--space-1);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0.8;
    transition: opacity var(--transition-fast);
}
.modal__close:hover { opacity: 1; }
.modal__close .material-symbols-rounded { font-size: 1.5rem; }

.modal__body { padding: var(--space-8) var(--space-5); }

.share-icons {
    display: flex;
    justify-content: center;
    gap: var(--space-5);
    margin-bottom: var(--space-8);
}
.share-icon-link {
    width: var(--space-10);
    height: var(--space-10);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-700);
    transition: color var(--transition-fast);
}
.share-icon-link:hover { color: var(--color-accent); }
.share-icon-link svg { width: 1.5rem; height: 1.5rem; fill: currentColor; }

.share-url-group { margin-bottom: var(--space-4); }
.share-url-input {
    width: 100%;
    padding: var(--space-3) var(--space-4);
    border: 1px solid var(--color-border-strong);
    border-radius: var(--radius-xs);
    font-size: var(--text-sm);
    font-family: inherit;
    color: var(--color-text-700);
    background: var(--color-bg);
}
.share-url-input:focus { outline: none; border-color: var(--color-secondary-600); }

.btn-copy-url {
    display: inline-flex;
    align-items: center;
    height: var(--input-height);
    padding: 0 var(--space-5);
    border: 1px solid var(--color-primary-600);
    border-radius: var(--radius-sm);
    background: var(--color-bg);
    color: var(--color-primary-600);
    font-size: var(--text-sm);
    font-family: inherit;
    cursor: pointer;
    transition: all var(--transition-fast);
}
.btn-copy-url:hover { background: var(--color-primary-600); color: white; }
.btn-copy-url.copied { background: var(--color-secondary-600); border-color: var(--color-secondary-600); color: white; }

/* === 24. RESPONSIVE === */

/* xs: 480px */
@media (min-width: 480px) {
    :root { --container-px: var(--space-7); }
    .logo__title { font-size: var(--text-xs); }
    .top-header__inner { padding-top: var(--space-3); padding-bottom: var(--space-3); }
    .box { padding: var(--space-5); }
}

/* sm: 640px */
@media (min-width: 640px) {
    :root { --container-px: var(--space-9); }
    .logo__separator { margin: 0 var(--space-4); }
    .logo__title { font-size: var(--text-sm); }
    .footer-navigation__left { gap: var(--space-4); }
}

/* md: 768px (min) */
@media (min-width: 768px) {
    .top-header__inner { padding-top: var(--space-4); padding-bottom: var(--space-4); }
    .logo__separator { height: var(--space-14); }
    .logo__title { white-space: nowrap; }
    .badge, .badge--overlay { font-size: var(--text-xs); }
}

/* md: 768px (max — mobile overrides) */
@media (max-width: 768px) {
    .hero { flex-direction: column; gap: var(--space-8); }
    .hero__image { max-width: 100%; }
    .footer-information__columns { flex-direction: column; gap: var(--space-8); }
    .toolbar { flex-direction: column; gap: var(--space-4); align-items: stretch; }
    .search__group { max-width: 100%; }
    .form__group { width: 100%; }
    .view-toggles { justify-content: flex-end; }
}

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

/* lg: 1024px */
@media (min-width: 1024px) {
    :root { --container-px: var(--space-10); }
    .breadcrumb { display: block; }
    .top-header__inner { padding-top: var(--space-6); padding-bottom: var(--space-6); }
    .share-bar { margin-top: var(--space-4); }
    .catalog-layout { margin-bottom: var(--space-20); }
    .section-spacer { height: var(--space-20); }
    .content-page { padding-bottom: var(--space-20); }
    .box { padding: var(--space-6); }
    .footer-information { padding: var(--space-20) 0; }
    .footer-information__entry { margin-bottom: 0; }
    .footer-information__entry h4 { margin-bottom: var(--space-10); }
    h1.page-title { font-size: var(--text-4xl); }
    .page-title-h2 { font-size: var(--text-4xl) !important; }
    .section-title { font-size: var(--text-3xl); }
    .content-page h2 { font-size: var(--text-3xl); }
    .content-page h3 { font-size: var(--text-2xl); }
    .logo__flag { width: 32px; height: 34px; }
    .logo__separator { margin: 0 var(--space-6); }
    .badge, .badge--overlay { font-size: var(--text-sm); }
}

/* xl: 1280px */
@media (min-width: 1280px) {
    :root {
        --container-px: var(--space-12);
        --input-height: var(--input-height-xl);
        --nav-height: var(--nav-height-xl);
    }
    .top-header__inner { padding-top: var(--space-8); padding-bottom: var(--space-8); }
    .logo__name { display: block; }
    .logo__title { font-size: var(--text-base); }
    .breadcrumb { padding: var(--space-3) 0; }
    .footer-information__entry h4 { font-size: var(--text-2xl); }
    h1.page-title { font-size: var(--text-5xl); }
    .page-title-h2 { font-size: var(--text-5xl) !important; }
    .section-title { font-size: var(--text-4xl); }
    .content-page h2 { font-size: var(--text-4xl); }
    .content-page h3 { font-size: var(--text-3xl); }
    .card__title { font-size: var(--text-xl); }
}

/* 2xl: 1544px */
@media (min-width: 1544px) {
    :root { --container-px: var(--space-14); }
    .accordion__button { padding: var(--space-5) var(--space-3); }
    .accordion__drawer { padding-left: var(--space-3); padding-right: var(--space-3); }
    .accordion__item.expanded .accordion__drawer { padding: 0 var(--space-3) var(--space-10) var(--space-3); }
}

/* 3xl: 1920px */
@media (min-width: 1920px) {
    :root {
        --container-px: var(--space-16);
        --container-max: var(--container-max-3xl);
        --input-height: var(--input-height-3xl);
        --nav-height: var(--nav-height-3xl);
    }
    .top-header__inner { padding-top: var(--space-10); padding-bottom: var(--space-10); }
    .catalog-layout { margin-bottom: 8rem; }
    .section-spacer { height: 8rem; }
    .content-page { padding-bottom: 8rem; }
    .box { padding: var(--space-8); }
    .footer-information { padding: 8rem 0; }
    .logo__flag { width: 40px; height: 44px; }
    .logo__name { width: 244px; height: 70px; }
    .logo__separator { height: 70px; margin: 0 var(--space-8); }
    .logo__title { font-size: var(--text-lg); }
    .card__title { font-size: var(--text-2xl); }
    .footer-information__entry h4 { font-size: var(--text-3xl); }
}

/* === 25. PRINT === */
@media print {
    html { font-size: 13px; max-width: 80%; margin: 2rem auto; }
    header, footer, .toolbar, .share-bar, .filter-panel, .breadcrumb,
    .modal__backdrop, .skip-to-content { display: none !important; }
    body { color: black; }
    .grid { display: block; }
    .card { box-shadow: none; border: 1px solid #ccc; break-inside: avoid; margin-bottom: 2em; }
    .container { max-width: 100%; padding: 0; }
    a { color: black; text-decoration: underline; }
    p, img, ul, .card { break-inside: avoid; }
}
