/* =========================================================================
   Konstelace — Hlavní CSS (Moderní & Vzdušný Redesign)
   Minimalistický, elegantní glassmorphism, striktně OSTRÉ rohy (0px radius)
   ========================================================================= */

/* -------------------------------------------------------------------------
   CSS proměnné (design tokens)
   ------------------------------------------------------------------------- */
:root {
    /* Vzdušné Astro barvy */
    --color-bg-start:     #f7f9fd;
    --color-bg-end:       #eef4ff;
    --color-bg-glass:     rgba(255, 255, 255, 0.82);
    --color-bg-dark:      #182033;
    --color-bg-dark-alt:  #2a3550;
    
    --color-text:         #182033;
    --color-text-muted:   #5f6b85;
    --color-text-inverse: #ffffff;
    
    --color-primary:      #4f8fe8;
    --color-primary-dark: #2e6fd0;
    --color-primary-light:rgba(79, 143, 232, 0.12);
    
    --color-accent:       #8b5cf6;
    --color-accent-light: rgba(139, 92, 246, 0.12);
    
    --color-success:      #059669;
    --color-success-bg:   #d1fae5;
    --color-error:        #dc2626;
    --color-error-bg:     #fee2e2;
    --color-warning:      #d97706;
    --color-warning-bg:   #fef3c7;
    
    --color-border:       rgba(72, 115, 196, 0.16);
    --color-border-dark:  rgba(255, 255, 255, 0.1);

    /* Typografie */
    --font-sans:    'Inter', 'Segoe UI', system-ui, -apple-system, sans-serif;
    --font-serif:   'Playfair Display', Georgia, 'Times New Roman', serif;
    --font-size-sm: 0.875rem;
    --font-size-md: 1rem;
    --font-size-lg: 1.125rem;
    --font-size-xl: 1.25rem;
    --font-size-2xl: 1.5rem;
    --font-size-3xl: 2rem;
    --font-size-4xl: 2.75rem;
    --line-height:  1.65;

    /* Mezery */
    --space-1:  0.25rem;
    --space-2:  0.5rem;
    --space-3:  0.75rem;
    --space-4:  1rem;
    --space-6:  1.5rem;
    --space-8:  2rem;
    --space-12: 3rem;
    --space-16: 4rem;
    --space-24: 6rem;

    /* Zaoblení - STRIKTNĚ HRANATÉ */
    --radius-sm:  0;
    --radius-md:  0;
    --radius-lg:  0;
    --radius-xl:  0;
    --radius-full: 0;

    /* Elegantní Astro stíny */
    --shadow-sm:  0 6px 16px rgba(37, 60, 120, 0.06);
    --shadow-md:  0 12px 32px rgba(37, 60, 120, 0.10);
    --shadow-lg:  0 20px 48px rgba(37, 60, 120, 0.15);

    /* Přechody */
    --transition: 0.25s cubic-bezier(0.25, 0.8, 0.25, 1);
    --transition-slow: 0.4s ease;

    /* Šířky */
    --max-width:        1200px;
    --max-width-narrow: 680px;
    --max-width-mid:    900px;
}

/* -------------------------------------------------------------------------
   Reset & Body
   ------------------------------------------------------------------------- */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    border-radius: 0 !important; /* Ultimátní pojistka proti oblým rohům */
}

html {
    font-size: 16px;
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
}

body {
    font-family: var(--font-sans);
    font-size: var(--font-size-md);
    line-height: var(--line-height);
    color: var(--color-text);
    background: linear-gradient(180deg, var(--color-bg-start) 0%, var(--color-bg-end) 100%);
    background-attachment: fixed;
    min-height: 100vh;
}

img, picture, video {
    max-width: 100%;
    display: block;
    /* Placeholder před načtením */
}

img[loading="lazy"] {
    background: var(--color-bg-alt, #f0f0f4);
    min-height: 4px;
}

img[loading="lazy"].loaded {
    background: none;
}

a {
    color: var(--color-primary);
    text-decoration: none;
    transition: color var(--transition);
}
a:hover {
    color: var(--color-primary-dark);
}

h1, h2, h3, h4, h5 {
    line-height: 1.15;
    font-weight: 800;
    letter-spacing: -0.02em;
    color: var(--color-text);
    margin-top: 1.5em;
}

h1 { font-size: var(--font-size-4xl); margin-bottom: var(--space-6); }
h2 { font-size: var(--font-size-3xl); margin-bottom: var(--space-4); }
h3 { font-size: var(--font-size-xl);  margin-bottom: var(--space-3); }

p {
    margin-bottom: var(--space-4);
    color: var(--color-text-muted);
}

ul, ol {
    padding-left: var(--space-6);
    margin-bottom: var(--space-4);
    color: var(--color-text-muted);
}

hr {margin: 1.5em 1em;}


/* -------------------------------------------------------------------------
   Layout
   ------------------------------------------------------------------------- */
.container {
    width: 100%;
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 var(--space-4);
}

.container--narrow { max-width: var(--max-width-narrow); }
.container--mid    { max-width: var(--max-width-mid); }
.container--wide   { max-width: 1100px; }

.main-content {
    padding: var(--space-12) 0;
    min-height: 60vh;
}

/* Fullwidth stránky (HP) — žádný padding navíc */
.main-content:has(> .benefits-strip:first-child),
.main-content--fullwidth {
    padding: 0;
    min-height: 0;
}

/* -------------------------------------------------------------------------
   Navigace (Světlý glassmorphism)
   ------------------------------------------------------------------------- */
.nav {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(255, 255, 255, 0.65);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom: 1px solid var(--color-border);
}

.nav__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 70px;
}

.nav__logo {
    display: flex;
    align-items: center;
    text-decoration: none !important;
    max-width: 215px;
}

.nav__logo-img {
    height: 48px;
    width: auto;
    display: block;
}

.nav__links {
    display: flex;
    list-style: none;
    gap: var(--space-6);
    padding: 0;
    margin: 0;
}

.nav__links a {
    color: var(--color-text);
    font-size: var(--font-size-sm);
    font-weight: 600;
    transition: color var(--transition);
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.nav__links a:hover {
    color: var(--color-primary);
}

.nav__burger {
    display: none;
    background: none;
    border: none;
    color: var(--color-text);
    font-size: var(--font-size-xl);
    cursor: pointer;
    padding: var(--space-2);
}

@media (max-width: 640px) {
    .nav__burger { display: block; }
    .nav__links {
        display: none;
        position: absolute;
        top: 70px;
        left: 0;
        right: 0;
        flex-direction: column;
        background: var(--color-bg-glass);
        backdrop-filter: blur(14px);
        padding: var(--space-4);
        gap: var(--space-3);
        border-bottom: 1px solid var(--color-border);
    }
    .nav__links.is-open { display: flex; }

    /* Dropdown v mobilu — inline, odsazený */
    .nav__item--has-dropdown .nav__dropdown {
        display: none;
        flex-direction: column;
        padding-left: var(--space-4);
        gap: var(--space-2);
    }
    .nav__item--has-dropdown.is-open .nav__dropdown { display: flex; }
    .nav__item--has-dropdown .nav__link--parent { width: 100%; }
}

/* Dropdown — desktop */
.nav__item { position: relative; }

.nav__dropdown {
    display: none;
    position: absolute;
    top: calc(100% + 0px);
    left: 0;
    min-width: 200px;
    background: var(--color-bg, #fff);
    border: 1px solid var(--color-border, #e5e7eb);
    border-radius: var(--radius-md, 8px);
    box-shadow: 0 8px 24px rgba(0,0,0,.10);
    list-style: none;
    padding: var(--space-2) 0;
    margin: 0;
    z-index: 100;
}

.nav__item--has-dropdown:hover .nav__dropdown,
.nav__item--has-dropdown:focus-within .nav__dropdown {
    display: block;
}

.nav__dropdown li a {
    display: block;
    padding: var(--space-2) var(--space-4);
    font-size: var(--font-size-sm);
    font-weight: 500;
    color: var(--color-text);
    text-decoration: none;
    text-transform: none;
    letter-spacing: 0;
    white-space: nowrap;
    transition: background var(--transition), color var(--transition);
}
.nav__dropdown li a:hover {
    background: var(--color-bg-muted, #f3f4f6);
    color: var(--color-primary);
}

.nav__arrow {
    font-size: .65em;
    opacity: .6;
    display: inline-block;
    transition: transform .2s;
}
.nav__item--has-dropdown:hover .nav__arrow { transform: rotate(180deg); }

/* -------------------------------------------------------------------------
   Hero sekce (Vzdušná a čistá)
   ------------------------------------------------------------------------- */
.hero {
    position: relative;
    width: 100%;
    height: 100vh;
    overflow: hidden;
    background: #1a1a2e; /* placeholder odpovídá tmavému Three.js pozadí */
}

/* Three.js canvas vloží JS do wrapperu jako první child */
.hero canvas {
    display: block;
    position: absolute;
    inset: 0;
}

/* Overlay: title nahoře, buttons dole, bez boxu */
.hero__overlay {
    position: absolute;
    inset: 0;
    z-index: 5;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 5rem 2rem 3.5rem;
    pointer-events: none;
    text-align: center;
}

.hero__top {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.hero__bottom {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}

.hero__title {
    font-size: clamp(2rem, 5vw, 3.6rem);
    font-weight: 800;
    margin: 0 0 .75rem;
    line-height: 1.15;
    color: #ffffff;
    text-shadow: 0 2px 6px rgba(0,0,0,.95), 0 0 30px rgba(0,0,0,.5);
}

.hero__subtitle {
    font-size: clamp(1rem, 2vw, 1.2rem);
    color: rgba(200, 185, 255, 0.9);
    margin: 0 0 .4rem;
}

/* Rotující nadpis */
.hero__title--rotating {
    position: relative;
    min-height: 1.2em;
    display: block;
}

.hero__title-item {
    display: block;
    opacity: 0;
    position: absolute;
    left: 0;
    right: 0;
    transition: opacity .6s ease;
    pointer-events: none;
}

.hero__title-item--active {
    opacity: 1;
    position: relative;
    pointer-events: auto;
}

/* Dvě tlačítka vedle sebe */
.hero__actions {
    display: flex;
    gap: var(--space-4);
    justify-content: center;
    flex-wrap: wrap;
    pointer-events: auto;
}

/* -------------------------------------------------------------------------
   Tlačítka (Ostrá, moderní)
   ------------------------------------------------------------------------- */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    padding: 0 var(--space-6);
    min-height: 44px;
    font-size: var(--font-size-sm);
    font-weight: 600;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    cursor: pointer;
    border: 1px solid transparent;
    transition: transform var(--transition), box-shadow var(--transition), background var(--transition);
}

.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }

.btn--primary {
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
    color: #fff;
    box-shadow: 0 8px 18px rgba(79, 143, 232, 0.22);
}
.btn--primary:hover {
    color: #fff;
    box-shadow: 0 12px 24px rgba(79, 143, 232, 0.3);
}

.btn--secondary {
    background: var(--color-bg-glass);
    color: var(--color-text);
    border-color: var(--color-border);
    backdrop-filter: blur(8px);
}
#hero-konstelace .btn--secondary {
    color: var(--color-text-inverse);
}
.btn--secondary:hover {
    background: #fff;
    box-shadow: var(--shadow-sm);
}

.btn--dark {
    background: var(--color-bg-dark);
    color: var(--color-text-inverse);
}
.btn--dark:hover {
    background: var(--color-bg-dark-alt);
    color: var(--color-text-inverse);
    box-shadow: 0 8px 18px rgba(24, 32, 51, 0.3);
}

.btn--sm {
    min-height: 36px;
    padding: 0 var(--space-4);
    font-size: 0.75rem;
}

.btn--danger {
    background: var(--color-error);
    color: #fff;
    box-shadow: 0 8px 18px rgba(220, 38, 38, 0.2);
}
.btn--danger:hover { background: #b91c1c; }

/* -------------------------------------------------------------------------
   Karty (Glassmorphism, hrany)
   ------------------------------------------------------------------------- */
.card {
    background: var(--color-bg-glass);
    border: 1px solid var(--color-border);
    padding: var(--space-6);
    box-shadow: var(--shadow-sm);
    backdrop-filter: blur(14px);
    transition: box-shadow var(--transition), transform var(--transition);
}
.card:hover { 
    box-shadow: var(--shadow-md); 
    transform: translateY(-2px);
}

/* -------------------------------------------------------------------------
   Flash zprávy
   ------------------------------------------------------------------------- */
.flash {
    padding: var(--space-3) var(--space-6);
    text-align: center;
    font-weight: 600;
    font-size: var(--font-size-sm);
    border: 1px solid currentColor;
    background: var(--color-bg-glass);
    backdrop-filter: blur(8px);
}

.flash--success { color: var(--color-success); border-color: rgba(5, 150, 105, 0.3); }
.flash--error   { color: var(--color-error); border-color: rgba(220, 38, 38, 0.3); }
.flash--info    { color: var(--color-primary-dark); border-color: var(--color-border); }

/* -------------------------------------------------------------------------
   Formuláře
   ------------------------------------------------------------------------- */
.form-group {
    margin-bottom: var(--space-4);
}

.form-group label {
    display: block;
    font-weight: 600;
    margin-bottom: var(--space-2);
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-text-muted);
}

.form-input {
    display: block;
    width: 100%;
    padding: var(--space-3) var(--space-4);
    border: 1px solid var(--color-border);
    font-size: var(--font-size-md);
    font-family: var(--font-sans);
    background: rgba(255, 255, 255, 0.9);
    transition: border-color var(--transition), box-shadow var(--transition), background var(--transition);
    color: var(--color-text);
}

.form-input:focus {
    outline: none;
    background: #fff;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 4px var(--color-primary-light);
}

textarea.form-input {
    resize: vertical;
    min-height: 150px;
    line-height: 1.6;
}

/* -------------------------------------------------------------------------
   Blog
   ------------------------------------------------------------------------- */
.post-list { display: grid; gap: var(--space-6); }

.post-card { display: grid; gap: var(--space-2); }

.post-card__date {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-primary);
    font-weight: 700;
}

.post-card__title a { color: var(--color-text); }
.post-card__title a:hover { color: var(--color-primary); text-decoration: none; }

.post-card__excerpt { margin: 0; }

/* -------------------------------------------------------------------------
   Post header (detail článku)
   ------------------------------------------------------------------------- */
.post-header {
    margin-bottom: var(--space-6);
}

.post-header__title {
    font-size: var(--font-size-3xl);
    font-weight: 800;
    line-height: 1.2;
    margin: 0 0 var(--space-3);
}

.post-header__date {
    display: block;
    font-size: var(--font-size-sm);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-primary);
    font-weight: 700;
    margin-bottom: var(--space-3);
}

.post-header__perex {
    font-size: var(--font-size-lg);
    color: var(--color-text-muted);
    line-height: 1.6;
    margin: 0;
}

.post-header__image {
    width: 100%;
    max-height: 480px;
    object-fit: cover;
    border-radius: var(--radius-lg);
    margin-bottom: var(--space-8);
    display: block;
}

.post-nav {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    margin-top: 3rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--color-border);
}
.post-nav__link {
    max-width: 48%;
    font-size: .9rem;
    color: var(--color-primary);
    text-decoration: none;
    line-height: 1.4;
}
.post-nav__link:hover { text-decoration: underline; }
.post-nav__link--next { text-align: right; margin-left: auto; }

/* -------------------------------------------------------------------------
   Akce (events)
   ------------------------------------------------------------------------- */
.event-list {
    display: grid;
    gap: var(--space-6);
}

@media (min-width: 640px) {
    .event-list { grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); }
}

.event-card__thumb {
    display: block;
    overflow: hidden;
    border-radius: var(--radius) var(--radius) 0 0;
    margin: calc(-1 * var(--space-5)) calc(-1 * var(--space-5)) var(--space-4);
    aspect-ratio: 16/7;
}

.event-card__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .35s ease;
    display: block;
    padding-bottom: 1em;
}

.event-card:hover .event-card__thumb img { transform: scale(1.03); }

.event-card__body { display: flex; flex-direction: column; }

.event-card__meta {
    display: flex;
    gap: var(--space-4);
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--color-text-muted);
    margin-bottom: var(--space-2);
    border-bottom: 1px solid var(--color-border);
    padding-bottom: var(--space-2);
}

.event-card__title a { color: var(--color-text); }
.event-card__title a:hover { color: var(--color-primary); }

.event-card__price {
    font-weight: 800;
    color: var(--color-primary);
    margin: var(--space-3) 0;
    font-size: var(--font-size-lg);
}

.event-disclaimer {
    margin: var(--space-6) auto;
    max-width: 640px;
    padding: .75rem 1rem;
    border-left: 3px solid var(--color-border);
    font-size: .85rem;
    color: var(--color-text-muted);
    background: var(--color-surface-2, #f9fafb);
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

.event-detail__meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-6);
    font-size: var(--font-size-sm);
    color: var(--color-text-dark);
    margin-bottom: var(--space-8);
    padding: var(--space-6);
    background: var(--color-bg-glass);
    border: 1px solid var(--color-border);
    backdrop-filter: blur(8px);
}

.event-detail__location-img {
    width: 100%;
    max-height: 280px;
    object-fit: cover;
    border-radius: var(--radius);
    margin-bottom: var(--space-8);
}

.event-register {
    margin-top: var(--space-8);
    width: 100%;
    background: var(--color-primary-light);
    border: 2px solid var(--color-primary);
    padding: 0;
    overflow: hidden;
}

.event-register__header {
    background: var(--color-primary);
    color: #fff;
    padding: var(--space-3) var(--space-6);
    display: flex;
    flex-direction: column;
    gap: .15rem;
}

.event-register__label {
    font-size: .75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .07em;
    opacity: .85;
}

.event-register__title {
    font-size: 1.1rem;
    font-weight: 700;
    line-height: 1.3;
}

.event-register form.register-form {
    padding: 1.5rem 1.75rem 2rem;
}

.event-register .form-group {
    margin-bottom: 1.25rem;
}

.event-register .form-group label {
    display: block;
    font-size: .95rem;
    font-weight: 600;
    margin-bottom: .5rem;
    color: var(--color-text);
}

.event-register .form-input {
    padding: .7rem 1rem;
    font-size: 1rem;
    margin-top: .1rem;
}

.form-hint {
    margin: .4rem 0 0;
    font-size: .85rem;
    color: #888;
    line-height: 1.5;
}

.event-register .btn--primary {
    display: block;
    width: 100%;
    margin-top: 1.75rem;
    padding: .85rem 1.5rem;
    font-size: 1rem;
}

/* -------------------------------------------------------------------------
   Hledání
   ------------------------------------------------------------------------- */
.search-box { margin-bottom: var(--space-8); }

.search-box__input {
    font-size: var(--font-size-lg);
    padding: var(--space-4);
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
}
.search-box__input:focus {
    background: #fff;
    box-shadow: 0 0 0 4px var(--color-primary-light);
}

.search-results { display: grid; gap: var(--space-4); }

.search-result {
    padding: var(--space-4);
    border: 1px solid var(--color-border);
    background: var(--color-bg-glass);
    transition: transform var(--transition), box-shadow var(--transition);
}
.search-result:hover {
    transform: translateX(4px);
    box-shadow: var(--shadow-sm);
    border-color: var(--color-primary);
}

.search-result__title {
    font-weight: 700;
    color: var(--color-text);
    display: block;
    margin-bottom: var(--space-1);
    font-size: var(--font-size-lg);
}
.search-result__title:hover { color: var(--color-primary); }

.search-result__excerpt { font-size: var(--font-size-sm); }

/* -------------------------------------------------------------------------
   Upozornění (notices)
   ------------------------------------------------------------------------- */
.notice {
    padding: var(--space-4) var(--space-6);
    margin: var(--space-6) 0;
    border-left: 4px solid;
    background: var(--color-bg-glass);
}

.notice--warning {
    border-left-color: var(--color-warning);
    color: var(--color-text);
}
.notice--warning::before {
    content: "Upozornění";
    display: block;
    font-size: 0.75rem;
    font-weight: 800;
    text-transform: uppercase;
    color: var(--color-warning);
    margin-bottom: var(--space-1);
}

/* -------------------------------------------------------------------------
   Footer
   ------------------------------------------------------------------------- */
.footer {
    background: var(--color-bg-dark);
    color: var(--color-text-inverse);
    padding: var(--space-12) 0;
    margin-top: var(--space-24);
    border-top: 4px solid var(--color-primary);
}

.footer__logo {
    margin-bottom: 0.3em;

}

.footer__logo-img {
    height: 150px;
    width: auto;
    display: block;
    margin: 0 auto;
}

.footer .container {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-6);
    text-align: center;
}

.footer p {
    font-size: var(--font-size-sm);
    color: rgba(255,255,255,0.5);
    margin: 0;
}

.footer nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-6);
}

.footer nav a {
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255,255,255,0.7);
}
.footer nav a:hover { color: #fff; }

/* -------------------------------------------------------------------------
   Admin styly (Ostré rozhraní)
   ------------------------------------------------------------------------- */
.admin-nav {
    background: var(--color-bg-dark);
    padding: var(--space-4) 0;
    margin-bottom: var(--space-8);
    border-bottom: 2px solid var(--color-primary);
}

.admin-nav .container {
    display: flex;
    align-items: center;
    gap: var(--space-6);
    flex-wrap: wrap;
}

.admin-nav a {
    color: rgba(255,255,255,0.6);
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.admin-nav a:hover, .admin-nav a.active { color: #fff; }

.admin-nav__title {
    color: var(--color-primary);
    font-weight: 800;
    font-size: var(--font-size-lg);
    margin-right: var(--space-4);
    text-transform: uppercase;
    letter-spacing: -0.02em;
}

.admin-login {
    max-width: 400px;
    margin: var(--space-16) auto;
    padding: var(--space-8);
    background: #fff;
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-lg);
}

.admin-login h1 {
    font-size: var(--font-size-2xl);
    margin-bottom: var(--space-6);
    text-align: center;
}

/* Admin tabulka */
.admin-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--font-size-sm);
    margin-top: var(--space-4);
    background: var(--color-bg-glass);
    box-shadow: var(--shadow-sm);
}

.admin-table th, .admin-table td {
    padding: var(--space-4);
    border-bottom: 1px solid var(--color-border);
    text-align: left;
}

.admin-table th {
    background: rgba(79, 143, 232, 0.05);
    font-weight: 700;
    color: var(--color-text);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.admin-table tr:hover td { background: rgba(255, 255, 255, 0.9); }

/* Admin dashboard karty */
.admin-stats {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: var(--space-6);
    margin-bottom: var(--space-8);
}

.admin-stat {
    background: var(--color-bg-glass);
    border: 1px solid var(--color-border);
    padding: var(--space-6);
    box-shadow: var(--shadow-sm);
    border-left: 4px solid var(--color-primary);
}

.admin-stat__value {
    font-size: var(--font-size-3xl);
    font-weight: 800;
    color: var(--color-text);
    line-height: 1;
    margin-bottom: var(--space-2);
}

.admin-stat__label {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-text-muted);
    font-weight: 600;
}

/* Statusy účastníků */
.status-badge {
    display: inline-block;
    padding: var(--space-1) var(--space-2);
    font-size: 0.65rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    border: 1px solid currentColor;
}

.status-badge--ceka_na_platbu { color: var(--color-warning); background: var(--color-warning-bg); }
.status-badge--zaplaceno      { color: var(--color-success); background: var(--color-success-bg); }
.status-badge--storno         { color: var(--color-error); background: var(--color-error-bg); }

/* -------------------------------------------------------------------------
   Utility
   ------------------------------------------------------------------------- */
.text-muted      { color: var(--color-text-muted); }
.text-sm         { font-size: var(--font-size-sm); }
.mt-4            { margin-top: var(--space-4); }
.mt-8            { margin-top: var(--space-8); }
.mb-4            { margin-bottom: var(--space-4); }
.mb-8            { margin-bottom: var(--space-8); }
.flex            { display: flex; }
.flex-wrap       { flex-wrap: wrap; }
.gap-4           { gap: var(--space-4); }
.items-center    { align-items: center; }
.justify-between { justify-content: space-between; }
.w-full          { width: 100%; }
/* -------------------------------------------------------------------------
   Blog — 3-sloupcový grid s náhledy
   ------------------------------------------------------------------------- */
.blog-container h1 { margin-bottom: 1.25rem; }

.blog-tag-filter {
    display: flex;
    flex-wrap: wrap;
    gap: .4rem;
    margin-bottom: 2rem;
}

.blog-tag-btn {
    background: var(--color-bg-alt);
    border: 1px solid var(--color-border);
    border-radius: 2rem;
    padding: .3rem .85rem;
    font-size: .8rem;
    font-weight: 600;
    cursor: pointer;
    color: var(--color-text-muted);
    transition: all .15s;
}
.blog-tag-btn:hover  { border-color: var(--color-primary); color: var(--color-primary); }
.blog-tag-btn.active { background: var(--color-primary); border-color: var(--color-primary); color: #fff; }

.post-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}

.post-card {
    background: var(--color-bg-glass);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: box-shadow .2s, transform .2s;
}
.post-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }

.post-card__thumb {
    display: block;
    width: 100%;
    aspect-ratio: 16/9;
    object-fit: cover;
}
.post-card__thumb-placeholder {
    display: block;
    width: 100%;
    aspect-ratio: 16/9;
    background: linear-gradient(135deg, var(--color-primary-light), var(--color-accent-light));
}

.post-card__body {
    padding: 1rem;
    display: flex;
    flex-direction: column;
    flex: 1;
}

.post-card__tag {
    display: inline-block;
    font-size: .7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--color-primary);
    background: var(--color-primary-light);
    border-radius: 2rem;
    padding: .1rem .55rem;
    margin: 0 .25rem .5rem 0;
    text-decoration: none;
}
.post-card__tag:hover { background: var(--color-primary); color: #fff; }

.post-card__title {
    margin: 0 0 .5rem;
    font-size: 1rem;
    line-height: 1.35;
}
.post-card__title a { color: var(--color-text); text-decoration: none; }
.post-card__title a:hover { color: var(--color-primary); }

.post-card__excerpt {
    font-size: .875rem;
    color: var(--color-text-muted);
    line-height: 1.6;
    margin: 0 0 auto;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.post-card__footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: .85rem;
    padding-top: .75rem;
    border-top: 1px solid var(--color-border);
}

.post-card__date { font-size: .75rem; color: var(--color-text-muted); }
.post-card__read { font-size: .8rem; font-weight: 600; color: var(--color-primary); text-decoration: none; }
.post-card__read:hover { text-decoration: underline; }

@media (max-width: 900px) {
    .post-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
    .post-grid { grid-template-columns: 1fr; }
}

.blog-pager {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .4rem;
    margin: 2rem 0 1rem;
    flex-wrap: wrap;
}
.blog-pager__link,
.blog-pager__num {
    display: inline-flex;
    align-items: center;
    padding: .4rem .75rem;
    border: 1px solid var(--color-border);
    border-radius: 6px;
    font-size: .9rem;
    color: var(--color-text);
    text-decoration: none;
    background: var(--color-bg-alt);
    transition: border-color .15s, background .15s;
}
.blog-pager__link:hover,
.blog-pager__num:hover { border-color: var(--color-primary); color: var(--color-primary); }
.blog-pager__num--active {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: #fff;
    pointer-events: none;
}

.blog-count {
    margin-top: 1.5rem;
    font-size: .85rem;
    color: var(--color-text-muted);
    text-align: center;
}

/* -------------------------------------------------------------------------
   Benefits strip — purple cards with lordicons
   ------------------------------------------------------------------------- */
.benefits-strip {
    background: #f3eeff;
    padding: var(--space-12) 0;
}

.benefits-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 1.25rem;
}

.benefit-item {
    background: #5a24b1;
    border-radius: var(--radius);
    padding: 2.5rem 1.25rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: .75rem;
    box-shadow: 0 0 20px 0 #f2f2f7;
    transition: transform .3s ease, box-shadow .3s ease;
}
.benefit-item:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 32px rgba(90,36,177,.25);
}
.benefit-item a { display: contents; }

.benefit-item h3 {
    color: #fff;
    font-size: 1rem;
    margin: 0;
    font-weight: 600;
}
.benefit-item p {
    color: rgba(255,255,255,.8);
    font-size: .85rem;
    margin: 0;
    font-weight: 500;
}

@media (max-width: 900px) {
    .benefits-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 560px) {
    .benefits-grid { grid-template-columns: repeat(2, 1fr); }
    .benefit-item { padding: 1.5rem .75rem; }
}

/* -------------------------------------------------------------------------
   Testimonials carousel
   ------------------------------------------------------------------------- */
.testimonials-section {
    padding: var(--space-16) 0;
    background: var(--color-bg);
}

.section-title {
    text-align: center;
    margin-bottom: var(--space-12);
    font-size: 1.75rem;
    color: var(--color-bg-dark);
}

.testimonials-carousel {
    position: relative;
    max-width: 860px;
    margin: 0 auto;
}
.testimonials-viewport {
    overflow: hidden;
}

.testimonials-track {
    display: flex;
    transition: transform .5s cubic-bezier(.4,0,.2,1);
    will-change: transform;
}

.testimonial-card {
    min-width: 100%;
    background: #fff;
    padding: 2rem 2.5rem;
    border-radius: var(--radius-lg, 12px);
    border: 1px solid var(--color-border);
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.testimonial-body::before {
    content: "\201C";
    font-family: serif;
    font-size: 4rem;
    color: var(--color-primary-light);
    line-height: 1;
    display: block;
    margin-bottom: -2rem;
}

.testimonial-body p {
    font-size: .95rem;
    line-height: 1.7;
    color: var(--color-text-muted);
    font-style: italic;
    margin: 0;
}

.testimonial-header {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.testimonial-avatar {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid var(--color-primary-light);
    filter: grayscale(15%);
    flex-shrink: 0;
}


.testimonial-name {
    font-weight: 700;
    color: var(--color-bg-dark);
    font-size: .95rem;
}

.testimonial-source {
    font-size: .78rem;
    color: var(--color-text-muted);
    margin-left: .4rem;
}

.testimonials-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: 50%;
    width: 40px;
    height: 40px;
    font-size: 1.4rem;
    line-height: 1;
    cursor: pointer;
    color: var(--color-text);
    box-shadow: 0 2px 8px rgba(0,0,0,.1);
    transition: background .15s, border-color .15s;
    display: flex;
    align-items: center;
    justify-content: center;
}
.testimonials-btn:hover { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }
.testimonials-btn--prev { left: -20px; }
.testimonials-btn--next { right: -20px; }

.testimonials-dots {
    display: flex;
    justify-content: center;
    gap: .5rem;
    margin-top: 1.25rem;
}

.testimonials-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    border: none;
    background: var(--color-border);
    cursor: pointer;
    padding: 0;
    transition: background .2s, transform .2s;
}
.testimonials-dot.active {
    background: var(--color-primary);
    transform: scale(1.3);
}

@media (max-width: 640px) {
    .testimonials-btn--prev { left: 0; }
    .testimonials-btn--next { right: 0; }
    .testimonial-card { padding: 1.5rem 1rem; }
}

/* -------------------------------------------------------------------------
   Upcoming events — HP compact cards
   ------------------------------------------------------------------------- */
.upcoming-events {
    padding: var(--space-12) 0;
    background: var(--color-bg);
}

.upcoming-events__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    margin-bottom: var(--space-8);
}

/* Karta */
.ev-card {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: box-shadow .2s, border-color .2s, transform .2s;
}
.ev-card:hover {
    box-shadow: 0 6px 20px rgba(24,32,51,.08);
    border-color: var(--color-primary);
    transform: translateY(-2px);
}

/* Náhledový obrázek */
.ev-card__thumb {
    display: block;
    aspect-ratio: 16/7;
    overflow: hidden;
    background: var(--color-primary-light);
}
.ev-card__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .35s ease;
}
.ev-card:hover .ev-card__thumb img { transform: scale(1.03); }

/* Tělo karty */
.ev-card__body {
    padding: .85rem 1rem .5rem;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: .35rem;
}

.ev-card__top {
    display: flex;
    align-items: center;
    gap: .5rem;
    flex-wrap: wrap;
}

.ev-card__date {
    font-size: .75rem;
    font-weight: 700;
    color: var(--color-primary);
    text-transform: capitalize;
}

.ev-badge {
    font-size: .65rem;
    font-weight: 700;
    border-radius: 2rem;
    padding: .1rem .5rem;
    white-space: nowrap;
}
.ev-badge--full { background: var(--color-error-bg);   color: var(--color-error); }
.ev-badge--few  { background: var(--color-warning-bg); color: var(--color-warning); }

.ev-card__title {
    font-size: .9rem;
    line-height: 1.35;
    margin: 0;
    font-weight: 700;
}
.ev-card__title a {
    color: var(--color-text);
    text-decoration: none;
}
.ev-card__title a:hover { color: var(--color-primary); }

.ev-card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem .75rem;
    margin-top: .1rem;
}
.ev-card__meta-item {
    display: flex;
    align-items: center;
    gap: 3px;
    font-size: .75rem;
    color: var(--color-text-muted);
}

/* Akční lišta */
.ev-card__action {
    padding: .6rem 1rem;
    border-top: 1px solid var(--color-border);
    background: var(--color-bg-start);
    display: flex;
    justify-content: flex-end;
}

.upcoming-events__more { text-align: center; }

.btn--secondary-outline {
    background: transparent;
    border: 2px solid var(--color-primary);
    color: var(--color-primary);
    padding: .55rem 1.5rem;
    border-radius: var(--radius);
    font-weight: 600;
    font-size: .9rem;
    text-decoration: none;
    transition: background .2s, color .2s;
    display: inline-block;
}
.btn--secondary-outline:hover { background: var(--color-primary); color: #fff; }
.hero__bottom .btn--secondary-outline {color: var(--color-text-inverse); }

@media (max-width: 860px) {
    .upcoming-events__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 540px) {
    .upcoming-events__grid { grid-template-columns: 1fr; }
}

/* Galerie sekce */
.gallery-section {
    padding: var(--space-16) 0;
    background: var(--color-bg-alt);
    overflow: hidden;
}

.gallery-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(250px, 100%), 1fr));
    gap: var(--space-4);
}

.gallery-item {
    position: relative;
    height: 300px;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--color-bg-dark);
}

.gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.gallery-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(141, 109, 196, 0.95), rgba(141, 109, 196, 0.4));
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: var(--space-6);
    color: white;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.gallery-item:hover .gallery-overlay {
    opacity: 1;
}

.gallery-item:hover img {
    transform: scale(1.1);
}

.gallery-overlay h3 {
    color: white;
    margin-bottom: var(--space-1);
    font-size: var(--font-size-lg);
}

.gallery-overlay p {
    font-size: var(--font-size-sm);
    margin: 0;
    line-height: 1.4;
    opacity: 0.9;
}

@media (max-width: 768px) {
    .gallery-overlay {
        opacity: 1;
        background: linear-gradient(to top, rgba(0,0,0,0.8), transparent);
    }
}

/* =========================================================
   Latest Posts (homepage)
   ========================================================= */
.latest-posts {
    padding: var(--space-12) 0;
    background: var(--color-bg-alt, #f9f8f6);
}

.latest-posts__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
    margin-bottom: var(--space-8);
}

.latest-posts__more {
    text-align: center;
}

.post-card {
    background: #fff;
    border-radius: var(--radius-lg, 12px);
    border: 1px solid var(--color-border);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: box-shadow .15s;
}

.post-card:hover {
    box-shadow: 0 4px 16px rgba(0,0,0,.08);
}

.post-card__thumb img {
    width: 100%;
    aspect-ratio: 16/9;
    object-fit: cover;
    display: block;
}

.post-card__body {
    padding: 1.25rem;
    display: flex;
    flex-direction: column;
    flex: 1;
}

.post-card__date {
    font-size: .78rem;
    color: var(--color-text-muted);
    margin: 0 0 .4rem;
}

.post-card__title {
    font-size: 1rem;
    font-weight: 700;
    margin: 0 0 .6rem;
    line-height: 1.35;
}

.post-card__title a {
    color: inherit;
    text-decoration: none;
}

.post-card__title a:hover {
    color: var(--color-primary);
}

.post-card__excerpt {
    font-size: .875rem;
    color: var(--color-text-muted);
    line-height: 1.6;
    margin: 0 0 1rem;
    flex: 1;
}

.post-card__link {
    font-size: .875rem;
    font-weight: 600;
    color: var(--color-primary);
    text-decoration: none;
}

.post-card__link:hover {
    text-decoration: underline;
}

@media (max-width: 768px) {
    .latest-posts__grid {
        grid-template-columns: 1fr;
    }
}

/* =========================================================
   404 stránka
   ========================================================= */
.error-404 {
    padding: var(--space-16) 0;
    min-height: 60vh;
    display: flex;
    align-items: center;
}

.error-404__content {
    text-align: center;
    max-width: 520px;
    margin: 0 auto;
}

.error-404__icon-wrapper {
    margin-bottom: var(--space-6);
}

.error-404__title {
    font-size: clamp(5rem, 15vw, 9rem);
    font-weight: 800;
    line-height: 1;
    margin: 0 0 .25rem;
    background: linear-gradient(135deg, var(--color-primary) 0%, #76a9f8 50%, var(--color-accent) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.error-404__subtitle {
    font-size: 1.5rem;
    font-weight: 700;
    margin: 0 0 var(--space-4);
}

.error-404__text {
    color: var(--color-text-muted);
    line-height: 1.7;
    margin-bottom: var(--space-8);
}

.error-404__actions {
    display: flex;
    gap: var(--space-3);
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: var(--space-10);
}

.error-404__footer p {
    font-size: .875rem;
    color: var(--color-text-muted);
    margin-bottom: var(--space-3);
}

.error-404__grid {
    display: flex;
    gap: var(--space-4);
    justify-content: center;
    flex-wrap: wrap;
    font-size: .875rem;
}

.error-404__grid a {
    color: var(--color-primary);
    text-decoration: none;
}

.error-404__grid a:hover {
    text-decoration: underline;
}

/* =========================================================
   Intro sekce (HP)
   ========================================================= */
.intro-section {
    padding: var(--space-16) 0;
    background: var(--color-bg);
}

.intro-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-10);
    margin-bottom: var(--space-10);
}

.intro-col h2 {
    font-size: 1.35rem;
    font-weight: 700;
    margin-bottom: var(--space-4);
    color: var(--color-primary);
}

.intro-col p {
    color: var(--color-text-muted);
    line-height: 1.75;
    margin-bottom: var(--space-3);
}

.intro-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.intro-list li {
    color: var(--color-text-muted);
    line-height: 1.7;
    padding: .4rem 0 .4rem 1.5rem;
    position: relative;
}

.intro-list li::before {
    content: '✦';
    position: absolute;
    left: 0;
    color: var(--color-primary);
    font-size: .7rem;
    top: .6rem;
}

.intro-how {
    border-top: 1px solid var(--color-border);
    padding-top: var(--space-8);
    display: grid;
    grid-template-columns: auto 1fr;
    gap: var(--space-6);
    align-items: start;
}

.intro-how h2 {
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--color-primary);
    white-space: nowrap;
    margin: 0;
}

.intro-how p {
    color: var(--color-text-muted);
    line-height: 1.75;
    margin: 0;
}

@media (max-width: 768px) {
    .intro-grid {
        grid-template-columns: 1fr;
        gap: var(--space-6);
    }
    .intro-how {
        grid-template-columns: 1fr;
        gap: var(--space-3);
    }
}

/* Admin edit bar (zobrazuje se adminovi na článcích) */
.admin-edit-bar {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .5rem 1rem;
    background: #1e1b4b;
    border-radius: var(--radius);
    margin-bottom: 1.5rem;
    font-size: .8rem;
}

.admin-edit-bar__label {
    color: rgba(255,255,255,.5);
    font-weight: 600;
    letter-spacing: .05em;
    text-transform: uppercase;
}

.admin-edit-bar__link {
    color: #a5b4fc;
    text-decoration: none;
    font-weight: 600;
}

.admin-edit-bar__link:hover {
    color: #fff;
    text-decoration: underline;
}


/* Galerie sekce */
.gallery-section {
    padding: var(--space-16) 0;
    background: var(--color-bg-alt);
    overflow: hidden;
}

.gallery-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(250px, 100%), 1fr));
    gap: var(--space-4);
}

.gallery-item {
    position: relative;
    height: 300px;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--color-bg-dark);
}

.gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.gallery-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(141, 109, 196, 0.95), rgba(141, 109, 196, 0.4));
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: var(--space-6);
    color: white;
    opacity: 0; /* Skryté v základu */
    transition: opacity 0.3s ease;
}

/* Zobrazení textu při najetí nebo na mobilu */
.gallery-item:hover .gallery-overlay {
    opacity: 1;
}

.gallery-item:hover img {
    transform: scale(1.1);
}

.gallery-overlay h3 {
    color: white;
    margin-bottom: var(--space-1);
    font-size: var(--font-size-lg);
}

.gallery-overlay p {
    font-size: var(--font-size-sm);
    margin: 0;
    line-height: 1.4;
    opacity: 0.9;
}

/* Na mobilu text zobrazíme částečně pořád, aby lidé věděli, o co jde */
@media (max-width: 768px) {
    .gallery-overlay {
        opacity: 1;
        background: linear-gradient(to top, rgba(0,0,0,0.8), transparent);
    }
}

/* Hero bio řádek */
.hero__bio {
    font-size: .8rem;
    color: rgba(180, 165, 240, 0.75);
    margin: 0;
    letter-spacing: .02em;
}

/* =========================================================
   Platební QR kódy
   ========================================================= */
.payment-qr {
    display: flex;
    gap: 2rem;
    flex-wrap: wrap;
}
.payment-qr__item {
    flex: 1 1 220px;
    text-align: center;
}
.payment-qr__item h3 {
    margin: 0 0 .4rem;
    font-size: 1rem;
}
.payment-qr__note {
    font-size: .8rem;
    color: #666;
    margin: 0 0 .75rem;
}
.payment-qr__item svg {
    width: 100%;
    max-width: 240px;
    height: auto;
    border-radius: 8px;
    border: 1px solid #e5e7eb;
}

/* =========================================================
   Section About (HP)
   ========================================================= */
.section-about {
    padding: var(--space-16) 0;
    background: var(--color-bg-alt, #f9f8f6);
}

.text-accent {
    color: var(--color-primary);
}

.content-text p {
    color: var(--color-text-muted);
    line-height: 1.8;
    max-width: 72ch;
    margin-bottom: var(--space-6);
}

.link-list {
    list-style: none;
    padding: 0;
    margin: 0 0 var(--space-6);
    display: flex;
    flex-direction: column;
    gap: .6rem;
}

.link-list li {
    padding-left: 1.25rem;
    position: relative;
    color: var(--color-text-muted);
    line-height: 1.65;
    font-size: .95rem;
}

.link-list li::before {
    content: '→';
    position: absolute;
    left: 0;
    color: var(--color-primary);
    font-weight: 700;
}

.link-list a {
    color: var(--color-primary);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.link-list a:hover {
    text-decoration-thickness: 2px;
}

.section-about__footer {
    font-size: .9rem;
    color: var(--color-text-muted);
    border-top: 1px solid var(--color-border);
    padding-top: var(--space-5);
    margin-top: var(--space-4);
}

.section-about__footer a {
    color: var(--color-primary);
}

/* Gallery (HP) */
.gallery-section {
    padding: var(--space-12) 0;
    background: var(--color-bg);
}

.gallery-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: .75rem;
}

.gallery-item {
    position: relative;
    border-radius: var(--radius);
    overflow: hidden;
    aspect-ratio: 4/3;
}

.gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .4s ease;
    loading: lazy;
}

.gallery-item:hover img {
    transform: scale(1.04);
}

.gallery-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,.65) 0%, transparent 60%);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 1rem;
    opacity: 0;
    transition: opacity .3s;
}

.gallery-item:hover .gallery-overlay {
    opacity: 1;
}

.gallery-overlay h3 {
    color: #fff;
    font-size: .9rem;
    margin: 0 0 .2rem;
}

.gallery-overlay p {
    color: rgba(255,255,255,.8);
    font-size: .75rem;
    margin: 0;
}

@media (max-width: 768px) {
    .gallery-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
    .gallery-grid { grid-template-columns: 1fr; }
}

/* ── Accordion (details/summary) ──────────────────────────────────────────── */

details.accordion,
details.accordion-exclusive {
  border: 1px solid var(--color-border, #e5e7eb);
  border-radius: 0;
  margin-bottom: .5rem;
  overflow: hidden;
}
details.accordion + details.accordion { margin-top: -.5rem; border-top-left-radius: 0; border-top-right-radius: 0; }
details.accordion:has(+ details.accordion) { border-bottom-left-radius: 0; border-bottom-right-radius: 0; margin-bottom: 0; }
details.accordion summary {
  padding: .75rem 1rem;
  font-weight: 400;
  cursor: pointer;
  background: var(--color-surface-2, #f9fafb);
  list-style: none;
  display: flex;
  align-items: center;
  gap: .5rem;
  transition: background .15s;
}
details.accordion summary:hover { background: var(--color-surface-3, #f3f4f6); }
details.accordion summary::before {
  content: '▸';
  display: inline-block;
  transition: transform .2s;
  font-size: .85em;
  color: var(--color-text-3, #9ca3af);
}
details.accordion[open] summary::before { transform: rotate(90deg); }
details.accordion summary::-webkit-details-marker { display: none; }
details.accordion > :not(summary) { padding: .75rem 1rem 1rem 2rem; }

/* Exclusive accordion — only one open at a time (needs data-accordion-group or JS) */
details.accordion-exclusive {
  border: 1px solid var(--color-border, #e5e7eb);
  border-radius: 0;
  margin-bottom: .5rem;
  overflow: hidden;
}
details.accordion-exclusive + details.accordion-exclusive { margin-top: -.5rem; border-top-left-radius: 0; border-top-right-radius: 0; }
details.accordion-exclusive:has(+ details.accordion-exclusive) { border-bottom-left-radius: 0; border-bottom-right-radius: 0; margin-bottom: 0; }
details.accordion-exclusive summary {
  padding: .75rem 1rem;
  font-weight: 400;
  cursor: pointer;
  background: var(--color-surface-2, #f9fafb);
  list-style: none;
  display: flex;
  align-items: center;
  gap: .5rem;
  transition: background .15s;
}
details.accordion-exclusive summary:hover { background: var(--color-surface-3, #f3f4f6); }
details.accordion-exclusive summary::before {
  content: '▸';
  display: inline-block;
  transition: transform .2s;
  font-size: .85em;
  color: var(--color-text-3, #9ca3af);
}
details.accordion-exclusive[open] summary::before { transform: rotate(90deg); }
details.accordion-exclusive summary::-webkit-details-marker { display: none; }

/* =========================================================================
   Lightbox
   ========================================================================= */
.lb-overlay {
  display: none;
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,.88);
  align-items: center; justify-content: center;
}
.lb-overlay.lb-visible { display: flex; }

.lb-inner {
  display: flex; flex-direction: column; align-items: center;
  max-width: 90vw; max-height: 90vh;
  position: relative;
}

.lb-img {
  max-width: 90vw; max-height: 82vh;
  object-fit: contain;
  opacity: 0; transition: opacity .22s;
  display: block;
  box-shadow: 0 8px 40px rgba(0,0,0,.5);
}
.lb-img.lb-loaded { opacity: 1; }

.lb-caption {
  color: rgba(255,255,255,.75); font-size: .85rem;
  margin-top: .6rem; text-align: center; max-width: 70ch;
}

.lb-close {
  position: fixed; top: 1rem; right: 1.25rem;
  background: none; border: none; color: #fff;
  font-size: 1.75rem; cursor: pointer; line-height: 1;
  opacity: .7; transition: opacity .15s;
}
.lb-close:hover { opacity: 1; }

.lb-nav {
  position: fixed; top: 50%; transform: translateY(-50%);
  background: rgba(255,255,255,.12); border: none; color: #fff;
  font-size: 2.5rem; line-height: 1; cursor: pointer;
  padding: .5rem .75rem;
  opacity: .7; transition: opacity .15s, background .15s;
}
.lb-nav:hover { opacity: 1; background: rgba(255,255,255,.22); }
.lb-prev { left: .75rem; }
.lb-next { right: .75rem; }
details.accordion-exclusive > :not(summary) { padding: .75rem 1rem 1rem 2rem; }


/* =========================================================================
   Stylování pro článek: Průvodce konstelacemi
   Navazuje na hlavní CSS (Astro barvy, glassmorphism, ostré rohy)
   ========================================================================= */

.constellation-guide {
    max-width: 840px;
    margin: 0 auto;
    color: var(--color-text);
    line-height: 1.7;
    font-size: 1.05rem;
}

/* Hlavní panely s obsahem - Glassmorphism efekt */
.constellation-guide .glass-panel {
    background: var(--color-bg-glass);
    border: 1px solid rgba(255, 255, 255, 0.4);
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.04);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    padding: 2.5rem 3rem;
    margin-bottom: 2rem;
    border-radius: 0; /* Striktně ostré rohy */
}

/* Předěly fází (Před seminářem, Na semináři...) */
.constellation-guide .phase-divider {
    background: var(--color-primary);
    color: var(--color-text-inverse);
    padding: 1.5rem 3rem;
    margin: 4rem 0 2rem 0;
    border-radius: 0; /* Ostré rohy */
    position: relative;
}

.constellation-guide .phase-divider h2 {
    margin: 0;
    font-size: 1.4rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-weight: 700;
}

/* Nadpisy v textu */
.constellation-guide .section-title {
    color: var(--color-bg-dark);
    font-size: 1.75rem;
    text-align: left;
    margin-top: 0;
    margin-bottom: 1.5rem;
    padding-bottom: 0.5rem;
    border-bottom: 2px solid var(--color-primary-light);
}

.constellation-guide .subsection-title {
    color: var(--color-primary-dark);
    font-size: 1.25rem;
    margin-top: 2rem;
    margin-bottom: 1rem;
}

.constellation-guide .mt-large {
    margin-top: 3.5rem;
}

/* Ostré odrážkové seznamy */
.constellation-guide .sharp-list {
    list-style: none;
    padding-left: 0;
    margin: 1.5rem 0;
}

.constellation-guide .sharp-list li {
    position: relative;
    padding-left: 1.8rem;
    margin-bottom: 0.8rem;
}

.constellation-guide .sharp-list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.55rem;
    width: 8px;
    height: 8px;
    background-color: var(--color-accent);
    border-radius: 0; /* Čtverečky, žádná kolečka */
}

/* Informační boxy a tipy */
.constellation-guide .info-box {
    background: var(--color-primary-light);
    padding: 1.5rem;
    margin: 2rem 0;
    border-radius: 0;
}

.constellation-guide .border-primary {
    border-left: 4px solid var(--color-primary);
}

.constellation-guide .border-accent {
    border-left: 4px solid var(--color-accent);
}

.constellation-guide .info-box p:last-child {
    margin-bottom: 0;
}

/* Citace a Tip bloky */
.constellation-guide .tip-quote {
    font-style: italic;
    background: var(--color-bg-start);
    padding: 1.5rem 2rem;
    margin: 2rem 0;
    color: var(--color-text-muted);
}

.constellation-guide .philosophical-quote {
    font-size: 1.15rem;
    line-height: 1.8;
    text-align: center;
    color: var(--color-text);
    padding: 2rem 1rem;
    border-top: 1px solid var(--color-primary-light);
    border-bottom: 1px solid var(--color-primary-light);
    margin: 3rem 0 1rem;
    font-style: italic;
}

/* Zvýrazněný text a odkazy */
.constellation-guide .highlight-text {
    font-size: 1.15rem;
    font-weight: 500;
    color: var(--color-primary-dark);
}

.constellation-guide .action-link {
    color: var(--color-primary);
    text-decoration: none;
    border-bottom: 1px solid var(--color-primary-light);
    transition: all 0.2s ease;
}

.constellation-guide .action-link:hover {
    color: var(--color-accent);
    border-bottom-color: var(--color-accent);
}

/* Zvýrazněná sekce pro podmínky (č. 8) */
.constellation-guide .highlight-section {
    background: var(--color-bg-start);
    border-top: 4px solid var(--color-bg-dark);
}

/* Responzivita pro mobilní zařízení */
@media (max-width: 768px) {
    .constellation-guide .glass-panel {
        padding: 1.5rem;
    }
    .constellation-guide .phase-divider {
        padding: 1.2rem 1.5rem;
        margin: 3rem 0 1.5rem 0;
    }
}
/* Kontejner formuláře */
.form {
  max-width: 600px;
  margin: 2rem 0;
  font-family: sans-serif;
  color: #333;
}

/* Skupiny polí */
.form .form__group {
  margin-bottom: 1.5rem;
  display: flex;
  flex-direction: column;
}

/* Popisky (Labely) */
.form .form__label {
  display: block;
  font-weight: bold;
  margin-bottom: 0.5rem;
  font-size: 0.95rem;
}

.form .form__label span {
  color: #d9534f; /* Červená pro povinné hvězdičky */
}

/* Společný styl pro inputy a textarea */
.form__input {
  width: 100%;
  padding: 12px 15px;
  border: 1px solid #ccc;
  border-radius: 4px;
  font-size: 1rem;
  box-sizing: border-box; /* Důležité pro správnou šířku */
  transition: border-color 0.2s, box-shadow 0.2s;
}

/* Efekt při kliknutí do pole */
.form .form__input:focus {
  outline: none;
  border-color: #2c3e50;
  box-shadow: 0 0 0 3px rgba(44, 62, 80, 0.1);
}

/* Specifické nastavení pro textovou oblast */
.form textarea.form__input {
  resize: vertical; /* Umožní měnit výšku, ale ne šířku */
  min-height: 120px;
}

/* Tlačítko */
.form.btn--primary {
  background-color: #2c3e50;
  color: white;
  padding: 12px 24px;
  border: none;
  border-radius: 4px;
  font-size: 1rem;
  font-weight: bold;
  cursor: pointer;
  transition: background-color 0.2s;
  display: inline-block;
}

.form .btn--primary:hover {
  background-color: #1a252f;
}

.form .btn--primary:active {
  transform: translateY(1px);
}
/* Accordion — Před seminářem / FAQ */
.pred-sem-faq-wrap {
    margin-top: 2.5rem;
    padding-top: 2rem;
    border-top: 1px solid var(--color-border, #e5e7eb);
}

.pred-sem-faq__title {
    font-size: var(--font-size-lg);
    font-weight: 600;
    margin-bottom: 1rem;
    color: var(--color-text);
}

.pred-sem-faq details {
    border-bottom: 1px solid var(--color-border, #e5e7eb);
}

.pred-sem-faq details:first-of-type {
    border-top: 1px solid var(--color-border, #e5e7eb);
}

.pred-sem-faq summary {
    list-style: none;
    cursor: pointer;
    padding: .9rem 0;
    font-weight: 500;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    user-select: none;
    color: var(--color-text);
}

.pred-sem-faq summary::-webkit-details-marker { display: none; }

.pred-sem-faq summary::after {
    content: '+';
    font-size: 1.3rem;
    line-height: 1;
    color: var(--color-primary, #8d6dc4);
    flex-shrink: 0;
    transition: transform .2s ease;
}

.pred-sem-faq details[open] summary::after {
    transform: rotate(45deg);
}

.pred-sem-faq__body {
    padding: 0 0 1rem;
    color: var(--color-text-muted, #555);
    line-height: 1.7;
    font-size: .95rem;
}
.faq-content {
    padding: 1.5rem 2rem !important;
    line-height: 1.6;
}
.faq-content p {
    margin-bottom: 1rem;
}
.styled-list {
    list-style: none;
    padding-left: 0;
}
.styled-list li {
    position: relative;
    padding-left: 1.5rem;
    margin-bottom: 0.5rem;
}
.styled-list li::before {
    content: "•";
    color: var(--color-primary);
    font-weight: bold;
    position: absolute;
    left: 0;
}
.btn-link {
    color: var(--color-primary);
    text-decoration: none;
    font-weight: 600;
    transition: opacity 0.2s;
}
.btn-link:hover {
    opacity: 0.7;
}

/* ── WhatsApp float button ──────────────────────────────────────────── */
.wa-float {
    position: fixed;
    bottom: 1.5rem;
    bottom: calc(1.5rem + env(safe-area-inset-bottom, 0px));
    right: 1.5rem;
    z-index: 9999;
    z-index: 9999;
    width: 52px;
    height: 52px;
    background: #25d366;
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 16px rgba(0,0,0,.22);
    transition: transform .15s, box-shadow .15s;
    text-decoration: none;
    isolation: isolate;
}
.wa-float:hover {
    transform: scale(1.08);
    box-shadow: 0 6px 22px rgba(0,0,0,.3);
    color: #fff;
}

/* ── Event share buttons ──────────────────────────────────────────── */
.event-share {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin: .75rem 0 1.25rem;
}

.event-share__btn {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .38rem .85rem;
    border-radius: 0;
    font-size: .82rem;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    border: none;
    font-family: inherit;
    transition: opacity .15s;
}
.event-share__btn:hover { opacity: .82; }

.event-share__fb {
    background: #1877f2;
    color: #fff;
}
.event-share__wa {
    background: #25d366;
    color: #fff;
}
.event-share__copy {
    background: var(--color-surface-2, #f0f0f5);
    color: var(--color-text, #222);
    border: 1px solid var(--color-border, #ddd);
}

 .books-wrap{
    max-width:1100px;
    margin:0 auto;
    padding:30px 20px 50px;
  }

  .books-intro{
    text-align:center;
    max-width:760px;
    margin:0 auto 36px;
  }

  .books-intro h2{
    margin:0 0 12px;
    font-size:2rem;
    line-height:1.2;
  }

  .books-intro p{
    margin:0;
    color:#666;
    line-height:1.7;
  }

  .book-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(420px,1fr));
    gap:22px;
  }

  .book-card{
    display:flex;
    gap:18px;
    align-items:flex-start;
    background:#fff;
    border:1px solid #e8e8e8;
    border-radius:16px;
    padding:18px;
    box-shadow:0 6px 20px rgba(0,0,0,0.04);
  }

  .book-card img{
    width:120px;
    min-width:120px;
    height:auto;
    display:block;
    border-radius:10px;
  }

  .book-card h3{
    margin:5px 0 8px;
    font-size:1.35rem;
    line-height:1.25;
  }

  .book-meta{
    margin:0 0 10px;
    color:#7a6a7b;
    font-weight:600;
    font-size:0.95rem;
  }

  .book-card p{
    margin:0;
    color:#555;
    line-height:1.7;
  }

  @media (max-width:700px){
    .book-grid{
      grid-template-columns:1fr;
    }

    .book-card{
      flex-direction:column;
    }

    .book-card img{
      width:150px;
      min-width:150px;
    }
  }

  /* --- Úpravy v main.css --- */

/* Větší mezery mezi kartami pro vzdušnější dojem */
.history-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 32px; /* Větší mezera mezi položkami */
    margin-top: 40px;
}

/* Vertikální karta s více prostorem */
.history-card {
    display: flex;
    flex-direction: column; /* Text pod obrázkem */
    gap: 0; 
    background: #fff;
    border: 1px solid #eee;
    border-radius: 12px;
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    box-shadow: 0 4px 12px rgba(0,0,0,0.03);
}

.history-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 12px 24px rgba(0,0,0,0.08);
}

/* Fixní velikost obrázku (Lightbox trigger) */
.history-card a {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9; /* Všechny fotky budou stejně velké */
    overflow: hidden;
    cursor: zoom-in;
}

.history-card img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Ořízne fotku tak, aby vyplnila prostor */
    transition: scale 0.5s ease;
}

.history-card:hover img {
    scale: 1.05;
}

/* Obsah pod fotkou */
.history-card .card-content {
    padding: 20px;
}

/* Styl pro Lightbox (jednoduchý CSS/JS overlay) */
#lightbox-overlay {
    position: fixed;
    z-index: 9999;
    top: 0; left: 0; width: 100%; height: 100%;
    background: rgba(24, 32, 51, 0.95); /* Tmavá barva z vaší palety */
    display: none;
    align-items: center;
    justify-content: center;
    cursor: zoom-out;
}

#lightbox-overlay img {
    max-width: 90%;
    max-height: 90%;
    box-shadow: 0 0 30px rgba(0,0,0,0.5);
    border-radius: 4px;
}

/* =========================================================================
   Ref-file panel — propojené texty, sliding right panel
   ========================================================================= */
#ref-panel {
    position: fixed; right: 0; top: 70px; height: calc(100vh - 70px); width: 340px;
    z-index: 1090; background: var(--color-bg-start, #fff);
    border-left: 1px solid var(--color-border, #e5e7eb);
    box-shadow: none; display: flex; flex-direction: column;
    transform: translateX(100%);
    transition: transform .28s cubic-bezier(.4,0,.2,1), box-shadow .28s;
    overflow: hidden;
}
#ref-panel.open {
    transform: translateX(0);
    box-shadow: -4px 0 24px rgba(0,0,0,.12);
}
.ref-panel__header {
    display: flex; align-items: center; gap: .5rem;
    padding: .75rem 1rem; border-bottom: 1px solid var(--color-border, #e5e7eb);
    flex-shrink: 0; background: var(--color-bg-start, #fff);
}
.ref-panel__title {
    flex: 1; font-size: .9rem; font-weight: 600;
    color: var(--color-text, #1f2937);
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ref-panel__close {
    background: none; border: none;
    color: var(--color-text-muted, #888); font-size: 1rem;
    cursor: pointer; padding: .2rem .4rem;
}
.ref-panel__close:hover { color: var(--color-primary, #7c3aed); }
.ref-panel__nav { display: flex; gap: .25rem; padding: .4rem .75rem; border-bottom: 1px solid var(--color-border, #e5e7eb); flex-wrap: wrap; }
.ref-panel__nav:empty { display: none; }
.ref-panel__nav-btn { background: none; border: 1px solid var(--color-border, #e5e7eb); color: var(--color-text-muted, #888); font-size: .7rem; padding: .15rem .5rem; border-radius: 3px; cursor: pointer; transition: all .12s; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 140px; }
.ref-panel__nav-btn:hover { color: var(--color-primary, #7c3aed); border-color: var(--color-primary, #7c3aed); }
.ref-panel__nav-btn.active { background: var(--color-primary, #7c3aed); color: #fff; border-color: var(--color-primary, #7c3aed); }
.ref-panel-tab__count { position: absolute; top: -4px; right: -4px; background: var(--color-primary, #7c3aed); color: #fff; font-size: .6rem; width: 16px; height: 16px; border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.ref-panel-tab { position: relative; }
.ref-panel__content {
    flex: 1; overflow-y: auto; padding: 1rem;
    font-size: .875rem; line-height: 1.7; color: var(--color-text, #1f2937);
}
.ref-panel__content a { color: var(--color-primary, #7c3aed); }
.ref-panel__open {
    display: block; margin-bottom: .75rem; font-size: .8rem;
    color: var(--color-primary, #7c3aed); text-decoration: none;
}
.ref-panel__open:hover { text-decoration: underline; }
.ref-panel__loading, .ref-panel__error {
    padding: 1.5rem; text-align: center; color: var(--color-text-muted, #888); font-size: .85rem;
}
.ref-panel__error { color: var(--color-error, #dc2626); }
.ref-panel__content h1, .ref-panel__content h2, .ref-panel__content h3, .ref-panel__content h4 { margin-top: 1.2em; margin-bottom: .4em; font-weight: 600; color: var(--color-text, #1f2937); }
.ref-panel__content h1 { font-size: 1.15rem; }
.ref-panel__content h2 { font-size: 1.05rem; }
.ref-panel__content h3 { font-size: .95rem; }
.ref-panel__content p { margin: .6em 0; }
.ref-panel__content ul, .ref-panel__content ol { margin: .5em 0; padding-left: 1.4em; }
.ref-panel__content li { margin: .2em 0; }
.ref-panel__content blockquote { border-left: 3px solid var(--color-primary, #7c3aed); padding: .3em .8em; margin: .6em 0; color: var(--color-text-muted, #666); font-style: italic; }
.ref-panel__content code { background: var(--color-bg-alt, #f3f4f6); padding: .1em .3em; border-radius: 3px; font-size: .85em; }
.ref-panel__content pre { background: var(--color-bg-alt, #f3f4f6); padding: .75em; border-radius: 4px; overflow-x: auto; margin: .6em 0; }
.ref-panel__content pre code { background: none; padding: 0; }
.ref-panel__content img { max-width: 100%; height: auto; border-radius: 4px; margin: .5em 0; }
.ref-panel__content hr { border: none; border-top: 1px solid var(--color-border, #e5e7eb); margin: 1em 0; }
.ref-panel__content strong { font-weight: 600; }
.ref-panel__content em { font-style: italic; }
.ref-panel__content details { margin: .5em 0; }
.ref-panel__content summary { cursor: pointer; font-weight: 600; }
.ref-panel__content table { border-collapse: collapse; width: 100%; margin: .6em 0; font-size: .82rem; }
.ref-panel__content th, .ref-panel__content td { border: 1px solid var(--color-border, #e5e7eb); padding: .35em .6em; text-align: left; }
.ref-panel__content th { background: var(--color-bg-alt, #f3f4f6); font-weight: 600; }

/* Arc-ref links in text */
a.arc-ref {
    color: var(--color-primary, #7c3aed); text-decoration: none;
    border-bottom: 1px dashed var(--color-primary, #7c3aed);
    cursor: pointer; transition: color .15s, border-color .15s;
}
a.arc-ref:hover { color: var(--color-primary-dark, #6d28d9); border-bottom-color: var(--color-primary-dark, #6d28d9); }
a.arc-ref--active {
    color: var(--color-primary-dark, #6d28d9);
    background: rgba(124,58,237,0.08); border-radius: 2px; padding: 0 2px;
}

/* Sync anchors */
.sync-anchor { display: inline-block; width: 0; height: 0; scroll-margin-top: 30vh; }
.sync-highlight { outline: 2px solid var(--color-primary, #7c3aed); outline-offset: 4px; }

/* Admin sync labels — viditelné číslo kotvy */
.sync-label { display: none; }
body.is-admin .sync-label {
    display: inline-block; font-size: .6rem; background: rgba(124,58,237,.15);
    color: #7c3aed; padding: .05rem .3rem; border-radius: 3px; vertical-align: super;
    margin: 0 2px; font-family: monospace; opacity: .7;
}
body.is-admin .sync-label.sync-label--active { opacity: 1; background: rgba(124,58,237,.35); font-weight: 700; }

/* Sync sekce — podbarvení propojených sekcí */
.sync-section { transition: background .3s; border-radius: 4px; padding: 2px 0; border-left: 3px solid transparent; }
.sync-section:hover { border-left-color: rgba(124,58,237,.2); cursor: default; }
.sync-section--active { background: rgba(124,58,237,.06); }
.sync-section--hover { background: rgba(124,58,237,.13) !important; }

/* Ouško — plovoucí tlačítko vpravo */
.ref-panel-tab {
    position: fixed; right: 0; top: 50%; transform: translateY(-50%);
    z-index: 1088; background: var(--color-bg-start, #fff);
    border: 1px solid var(--color-border, #e5e7eb); border-right: none;
    border-radius: 8px 0 0 8px;
    padding: .6rem .5rem .6rem .65rem; cursor: pointer;
    box-shadow: -2px 0 12px rgba(0,0,0,.08);
    transition: opacity .2s, transform .2s;
}
.ref-panel-tab:hover { box-shadow: -2px 0 16px rgba(0,0,0,.15); }
.ref-panel-tab.hidden { opacity: 0; pointer-events: none; transform: translateY(-50%) translateX(100%); }
.ref-panel-tab__icon { font-size: 1.1rem; }

/* Banner v hlavičce článku */
.ref-banner {
    display: flex; align-items: center; gap: .75rem; flex-wrap: wrap;
    padding: .6rem 1rem; margin: .75rem 0 1rem;
    background: var(--color-primary-light, rgba(124,58,237,.06));
    border: 1px solid var(--color-primary, rgba(124,58,237,.2));
    border-radius: var(--radius, 4px); font-size: .85rem;
}
.ref-banner__text { color: var(--color-text-muted, #666); flex: 1; }
.ref-banner__btn {
    background: var(--color-primary, #7c3aed); color: #fff; border: none;
    padding: .3rem .8rem; border-radius: var(--radius, 4px); cursor: pointer;
    font-size: .8rem; font-weight: 600; transition: opacity .15s;
}
.ref-banner__btn:hover { opacity: .85; }

@media (max-width: 768px) {
    #ref-panel { width: 100%; }
    .ref-panel-tab { top: auto; bottom: 5rem; transform: none; }
    .ref-panel-tab.hidden { transform: translateX(100%); }
}