/**
 * ShareSphere - Components & Pages Stylesheet
 * Supplements app.css with all missing component styles.
 * Generated: 2026-03-01
 */


/* ============================================================
   HEADER EXTENSIONS
   ============================================================ */

.header__actions { display: flex; align-items: center; gap: var(--space-3); }
.header__menu { display: flex; align-items: center; gap: var(--space-5); }
.header__user-btn {
    display: flex; align-items: center; gap: var(--space-2);
    cursor: pointer; padding: var(--space-2); border-radius: var(--radius); border: none; background: none;
    font-family: var(--font-family); font-size: var(--font-size-sm); transition: background var(--transition);
}
.header__user-btn:hover { background: var(--color-gray-100); }
.header__user-name { font-weight: 500; color: var(--color-gray-700); }
.header__avatar { width: 32px; height: 32px; border-radius: var(--radius-full); object-fit: cover; }
.header__badge {
    position: absolute; top: -4px; right: -4px; min-width: 18px; height: 18px;
    background: var(--color-danger); color: var(--color-white); font-size: 0.65rem;
    border-radius: var(--radius-full); display: flex; align-items: center; justify-content: center; font-weight: 700;
}
.header__icon-btn {
    position: relative; background: none; border: none; cursor: pointer;
    font-size: 1.25rem; color: var(--color-gray-500); padding: var(--space-2);
    border-radius: var(--radius); transition: all var(--transition);
}
.header__icon-btn:hover { background: var(--color-gray-100); color: var(--color-gray-700); }
.header__dropdown { position: relative; }
.header__dropdown-menu {
    position: absolute; top: calc(100% + var(--space-2)); right: 0; min-width: 200px;
    background: var(--color-white); border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); z-index: var(--z-dropdown);
    padding: var(--space-2) 0; display: none;
}
.header__dropdown-menu.is-open { display: block; }
.header__dropdown-item {
    display: flex; align-items: center; gap: var(--space-2);
    padding: var(--space-2) var(--space-4); font-size: var(--font-size-sm); color: var(--color-gray-700);
    transition: background var(--transition); text-decoration: none;
}
.header__dropdown-item:hover { background: var(--color-gray-50); text-decoration: none; }
.header__dropdown-item--admin { color: var(--color-primary); }
.header__dropdown-item--logout { color: var(--color-danger); }
.header__dropdown-divider { height: 1px; background: var(--color-gray-100); margin: var(--space-2) 0; }
.header__lang { display: flex; align-items: center; gap: var(--space-1); }
.header__lang-item {
    padding: var(--space-1) var(--space-2); font-size: var(--font-size-xs); border-radius: var(--radius-sm);
    color: var(--color-gray-500); text-decoration: none; font-weight: 500;
}
.header__lang-item.is-active { background: var(--color-primary-bg); color: var(--color-primary); }
.header__hamburger {
    display: none; background: none; border: none; cursor: pointer; padding: var(--space-2);
    width: 40px; height: 40px; flex-direction: column; justify-content: center;
    align-items: center; gap: 5px;
}
.header__hamburger span {
    display: block; width: 22px; height: 2px;
    background: var(--color-gray-700); border-radius: 2px;
    transition: transform 0.25s ease, opacity 0.25s ease;
}
.header__hamburger.is-open span:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
}
.header__hamburger.is-open span:nth-child(2) {
    opacity: 0;
    transform: scaleX(0);
}
.header__hamburger.is-open span:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
}
.header__mobile-menu {
    display: none; position: fixed; top: var(--header-height); left: 0; right: 0; bottom: 0;
    background: var(--color-white); z-index: var(--z-dropdown); padding: var(--space-4); overflow-y: auto;
    list-style: none;
}
.header__mobile-menu.is-open { display: block; }
.header__mobile-menu li a {
    display: block;
    padding: var(--space-3) var(--space-2);
    font-size: var(--font-size-base);
    font-weight: 500;
    color: var(--color-gray-700);
    text-decoration: none;
    border-radius: var(--radius);
    transition: background var(--transition), color var(--transition);
}
.header__mobile-menu li a:hover {
    background: var(--color-gray-50);
    color: var(--color-primary);
}
.header__mobile-nav { display: none; }
.header__mobile-divider { height: 1px; background: var(--color-gray-100); margin: var(--space-3) 0; }

@media (max-width: 768px) {
    .header__menu { display: none; }
    .header__hamburger { display: flex; }
    .header__mobile-nav { display: block; }
}


/* ============================================================
   MAIN NAV (alternative navigation component)
   ============================================================ */

.main-nav { display: flex; align-items: center; gap: var(--space-4); }
.main-nav__list { display: flex; align-items: center; gap: var(--space-1); list-style: none; }
.main-nav__item { position: relative; }
.main-nav__link {
    display: flex; align-items: center; gap: var(--space-1);
    padding: var(--space-2) var(--space-3); font-size: var(--font-size-sm); font-weight: 500;
    color: var(--color-gray-600); border-radius: var(--radius); transition: all var(--transition); text-decoration: none;
}
.main-nav__link:hover, .main-nav__link.is-active { color: var(--color-primary); background: var(--color-primary-bg); text-decoration: none; }
.main-nav__caret { font-size: 0.6em; margin-left: var(--space-1); }
.main-nav__actions { display: flex; align-items: center; gap: var(--space-2); margin-left: var(--space-4); }
.main-nav__dropdown { position: relative; }
.main-nav__dropdown-toggle { cursor: pointer; }
.main-nav__dropdown-menu {
    position: absolute; top: calc(100% + var(--space-1)); right: 0; min-width: 200px;
    background: var(--color-white); border: 1px solid var(--color-gray-200); border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg); z-index: var(--z-dropdown); padding: var(--space-2) 0; display: none;
}
.main-nav__dropdown-menu.is-open { display: block; }
.main-nav__dropdown-link {
    display: flex; align-items: center; gap: var(--space-2);
    padding: var(--space-2) var(--space-4); font-size: var(--font-size-sm); color: var(--color-gray-700);
    transition: background var(--transition); text-decoration: none;
}
.main-nav__dropdown-link:hover { background: var(--color-gray-50); text-decoration: none; }
.main-nav__dropdown-link--admin { color: var(--color-primary); }
.main-nav__dropdown-link--logout { color: var(--color-danger); }
.main-nav__dropdown-divider { height: 1px; background: var(--color-gray-100); margin: var(--space-2) 0; }
.main-nav__avatar { width: 28px; height: 28px; border-radius: var(--radius-full); object-fit: cover; }
.main-nav__username { font-size: var(--font-size-sm); font-weight: 500; color: var(--color-gray-700); }
.main-nav__logout-form { display: contents; }
.main-nav__hamburger {
    display: none; background: none; border: none; cursor: pointer;
    width: 32px; height: 32px; position: relative; padding: 0;
}
.main-nav__hamburger-line {
    display: block; width: 22px; height: 2px; background: var(--color-gray-700);
    position: absolute; left: 5px; transition: all var(--transition);
}
.main-nav__hamburger-line:nth-child(1) { top: 8px; }
.main-nav__hamburger-line:nth-child(2) { top: 15px; }
.main-nav__hamburger-line:nth-child(3) { top: 22px; }

@media (max-width: 768px) {
    .main-nav__list { display: none; }
    .main-nav__actions { display: none; }
    .main-nav__hamburger { display: flex; align-items: center; justify-content: center; }
}


/* ============================================================
   FOOTER
   ============================================================ */

.footer {
    background: var(--color-gray-900); color: var(--color-gray-400);
    padding: var(--space-12) 0 var(--space-6); margin-top: auto;
}
.footer__grid {
    display: grid; grid-template-columns: 2fr repeat(3, 1fr);
    gap: var(--space-8); margin-bottom: var(--space-8);
}
.footer__col { }
.footer__logo { margin-bottom: var(--space-3); }
.footer__logo img { height: 28px; filter: brightness(0) invert(1); }
.footer__desc { font-size: var(--font-size-sm); line-height: 1.7; color: var(--color-gray-400); }
.footer__heading {
    color: var(--color-white); font-size: var(--font-size-sm); font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: var(--space-4);
}
.footer__links { display: flex; flex-direction: column; gap: var(--space-2); }
.footer__links a {
    font-size: var(--font-size-sm); color: var(--color-gray-400);
    transition: color var(--transition); text-decoration: none;
}
.footer__links a:hover { color: var(--color-white); text-decoration: none; }
.footer__social { display: flex; gap: var(--space-3); margin-top: var(--space-4); }
.footer__social-link {
    width: 36px; height: 36px; border-radius: var(--radius-full);
    background: var(--color-gray-800); color: var(--color-gray-400);
    display: flex; align-items: center; justify-content: center;
    font-size: 1rem; transition: all var(--transition); text-decoration: none;
}
.footer__social-link:hover { background: var(--color-primary); color: var(--color-white); text-decoration: none; }
.footer__bottom {
    border-top: 1px solid var(--color-gray-800); padding-top: var(--space-6);
    display: flex; justify-content: space-between; align-items: center;
    font-size: var(--font-size-xs);
}
.footer__copyright { color: var(--color-gray-500); }

@media (max-width: 768px) {
    .footer__grid { grid-template-columns: 1fr 1fr; }
    .footer__bottom { flex-direction: column; gap: var(--space-2); text-align: center; }
}
@media (max-width: 480px) {
    .footer__grid { grid-template-columns: 1fr; }
}


/* ============================================================
   BREADCRUMB
   ============================================================ */

.breadcrumb { padding: var(--space-3) 0; }
.breadcrumb__list { display: flex; align-items: center; flex-wrap: wrap; gap: var(--space-1); }
.breadcrumb__item { display: flex; align-items: center; gap: var(--space-1); font-size: var(--font-size-sm); }
.breadcrumb__link { color: var(--color-gray-500); text-decoration: none; }
.breadcrumb__link:hover { color: var(--color-primary); text-decoration: underline; }
.breadcrumb__sep, .breadcrumb__separator { color: var(--color-gray-300); font-size: var(--font-size-xs); }
.breadcrumb__current { color: var(--color-gray-700); font-weight: 500; }


/* ============================================================
   HERO EXTENSIONS
   ============================================================ */

.hero__content { max-width: 700px; margin: 0 auto; }
.hero__search {
    display: flex; max-width: 700px; margin: 0 auto;
    background: var(--color-white); border-radius: var(--radius-xl);
    box-shadow: var(--shadow-lg); overflow: visible;
}
.hero__search-fields { display: flex; flex: 1; }
.hero__search-field { flex: 1; position: relative; }
.hero__search-field + .hero__search-field { border-left: 1px solid var(--color-gray-200); }
.hero__search .input { border: none; border-radius: 0; box-shadow: none; }
.hero__search .hero__search-field:first-child .input { border-radius: var(--radius-xl) 0 0 var(--radius-xl); }
.hero__search-btn {
    background: var(--color-primary); color: var(--color-white); border: none;
    padding: var(--space-3) var(--space-6); font-weight: 600; font-size: var(--font-size-base);
    cursor: pointer; transition: background var(--transition); font-family: var(--font-family);
    border-radius: 0 var(--radius-xl) var(--radius-xl) 0;
}
.hero__search-btn:hover { background: var(--color-primary-dark); }
.hero__autocomplete {
    position: absolute; top: 100%; left: 0; right: 0;
    background: var(--color-white); border: 1px solid var(--color-gray-200);
    border-radius: var(--radius); box-shadow: var(--shadow-md); z-index: var(--z-dropdown); display: none;
}
.hero__popular { margin-top: var(--space-6); }
.hero__popular-label { font-size: var(--font-size-sm); color: var(--color-gray-500); margin-bottom: var(--space-2); }
.hero__popular-tag {
    display: inline-block; padding: var(--space-1) var(--space-3);
    background: rgba(255,255,255,0.7); border-radius: var(--radius-full);
    font-size: var(--font-size-sm); color: var(--color-gray-700);
    text-decoration: none; margin: var(--space-1); transition: all var(--transition);
}
.hero__popular-tag:hover { background: var(--color-white); color: var(--color-primary); text-decoration: none; }

@media (max-width: 768px) {
    .hero__search { flex-direction: column; border-radius: var(--radius-lg); }
    .hero__search-fields { flex-direction: column; }
    .hero__search-field + .hero__search-field { border-left: none; border-top: 1px solid var(--color-gray-200); }
    .hero__search .hero__search-field:first-child .input { border-radius: var(--radius-lg) var(--radius-lg) 0 0; }
    .hero__search-btn { border-radius: 0 0 var(--radius-lg) var(--radius-lg); }
}


/* ============================================================
   SECTION & CTA
   ============================================================ */

.section { padding: var(--space-12) 0; }
.section--bg { background: var(--color-gray-50); }
.section--primary-bg { background: var(--color-primary-bg); }
.section__header { text-align: center; margin-bottom: var(--space-8); }
.section__title { font-size: var(--font-size-2xl); margin-bottom: var(--space-2); }
.section__subtitle { color: var(--color-gray-500); font-size: var(--font-size-lg); max-width: 600px; margin: 0 auto; }
.section__footer { text-align: center; margin-top: var(--space-8); }

.cta-section {
    padding: var(--space-16) 0;
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
    color: var(--color-white);
}
.cta-section__inner { max-width: 800px; margin: 0 auto; }
.cta-section__inner--center { text-align: center; }
.cta-section__content { }
.cta-section__title { font-size: var(--font-size-3xl); color: var(--color-white); margin-bottom: var(--space-3); }
.cta-section__desc { font-size: var(--font-size-lg); opacity: 0.9; margin-bottom: var(--space-6); }
.cta-section__price { font-size: var(--font-size-sm); opacity: 0.8; margin-top: var(--space-3); }
.cta-section__benefits { display: flex; flex-wrap: wrap; gap: var(--space-3); margin-bottom: var(--space-6); }
.cta-section__benefits li {
    display: flex; align-items: center; gap: var(--space-2);
    font-size: var(--font-size-sm); list-style: none;
}
.cta-section__actions { display: flex; gap: var(--space-3); flex-wrap: wrap; }

.cta-section .btn--white {
    background: var(--color-white); color: var(--color-primary); border-color: var(--color-white);
}
.cta-section .btn--white:hover { background: var(--color-gray-100); }


/* ============================================================
   STEPS (how it works)
   ============================================================ */

.steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--space-8); }
.steps--horizontal { text-align: center; }
.steps__item { position: relative; }
.steps__number {
    width: 48px; height: 48px; border-radius: var(--radius-full);
    background: var(--color-primary-bg); color: var(--color-primary);
    display: flex; align-items: center; justify-content: center;
    font-size: var(--font-size-xl); font-weight: 700; margin-bottom: var(--space-3);
}
.steps--horizontal .steps__number { margin: 0 auto var(--space-3); }
.steps__title { font-size: var(--font-size-lg); font-weight: 600; margin-bottom: var(--space-2); }
.steps__desc { font-size: var(--font-size-sm); color: var(--color-gray-500); line-height: 1.6; }


/* ============================================================
   NEWSLETTER
   ============================================================ */

.newsletter { padding: var(--space-12) 0; background: var(--color-gray-50); text-align: center; }
.newsletter__title { font-size: var(--font-size-2xl); margin-bottom: var(--space-2); }
.newsletter__desc { color: var(--color-gray-500); margin-bottom: var(--space-6); }
.newsletter__form {
    display: flex; max-width: 480px; margin: 0 auto; gap: var(--space-2);
}
.newsletter__form input {
    flex: 1; padding: var(--space-3); border: 1px solid var(--color-gray-300);
    border-radius: var(--radius); font-size: var(--font-size-base); font-family: var(--font-family);
}
.newsletter__gdpr { font-size: var(--font-size-xs); color: var(--color-gray-400); margin-top: var(--space-3); max-width: 480px; margin-left: auto; margin-right: auto; }


/* ============================================================
   LANGUAGE SWITCHER
   ============================================================ */

.lang-switcher { display: flex; align-items: center; gap: var(--space-1); }
.lang-switcher__option {
    display: flex; align-items: center; gap: var(--space-1);
    padding: var(--space-1) var(--space-2); font-size: var(--font-size-xs); font-weight: 500;
    border-radius: var(--radius-sm); color: var(--color-gray-500); text-decoration: none;
    transition: all var(--transition);
}
.lang-switcher__option:hover, .lang-switcher__option.is-active { background: var(--color-primary-bg); color: var(--color-primary); text-decoration: none; }
.lang-switcher__flag { width: 16px; height: 12px; border-radius: 2px; }
.lang-switcher__label { }
.lang-switcher__divider { color: var(--color-gray-300); font-size: var(--font-size-xs); }


/* ============================================================
   SEARCH BAR
   ============================================================ */

.search-bar {
    background: var(--color-white); border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-lg); padding: var(--space-4);
    box-shadow: var(--shadow-sm);
}
.search-bar__form { display: flex; gap: var(--space-3); align-items: flex-end; }
.search-bar__field { flex: 1; }
.search-bar__field--query { flex: 2; }
.search-bar__field--location { flex: 1.5; position: relative; }
.search-bar__field--category { flex: 1; }
.search-bar__field--sm { flex: 0.8; }
.search-bar__icon { position: absolute; left: var(--space-3); top: 50%; transform: translateY(-50%); color: var(--color-gray-400); }
.search-bar__input {
    width: 100%; padding: var(--space-3); border: 1px solid var(--color-gray-300);
    border-radius: var(--radius); font-size: var(--font-size-base); font-family: var(--font-family);
}
.search-bar__input:focus { outline: none; border-color: var(--color-primary); box-shadow: 0 0 0 3px var(--color-primary-bg); }
.search-bar__select {
    width: 100%; padding: var(--space-3); border: 1px solid var(--color-gray-300);
    border-radius: var(--radius); font-size: var(--font-size-base); font-family: var(--font-family);
    background: var(--color-white); appearance: none;
}
.search-bar__submit {
    padding: var(--space-3) var(--space-6); white-space: nowrap;
}
.search-bar__geolocate {
    position: absolute; right: var(--space-2); top: 50%; transform: translateY(-50%);
    background: none; border: none; cursor: pointer; color: var(--color-gray-400);
    padding: var(--space-1); font-size: 1.1rem; transition: color var(--transition);
}
.search-bar__geolocate:hover { color: var(--color-primary); }
.search-bar__suggestions {
    position: absolute; top: 100%; left: 0; right: 0;
    background: var(--color-white); border: 1px solid var(--color-gray-200);
    border-radius: var(--radius); box-shadow: var(--shadow-md); z-index: var(--z-dropdown);
    max-height: 200px; overflow-y: auto; display: none;
}

@media (max-width: 768px) {
    .search-bar__form { flex-direction: column; }
}


/* ============================================================
   SEARCH RESULTS & LAYOUT
   ============================================================ */

.search-page { }
.search-layout { display: grid; grid-template-columns: 280px 1fr; gap: var(--space-6); align-items: start; }
.search-sidebar { }
.search-sidebar .card { position: sticky; top: calc(var(--header-height) + var(--space-4)); }
.search-results { }
.search-results__header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-4); flex-wrap: wrap; gap: var(--space-3); }
.search-results__count { font-size: var(--font-size-sm); color: var(--color-gray-500); }
.search-results__sort { display: flex; align-items: center; gap: var(--space-2); }
.search-results__view { display: flex; gap: var(--space-1); }
.search-results__view-btn {
    padding: var(--space-2); border: 1px solid var(--color-gray-200); border-radius: var(--radius);
    background: var(--color-white); cursor: pointer; color: var(--color-gray-400); transition: all var(--transition);
}
.search-results__view-btn.is-active, .search-results__view-btn:hover { background: var(--color-primary-bg); color: var(--color-primary); border-color: var(--color-primary); }
.search-results__grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--space-4); }

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


/* ============================================================
   FILTERS
   ============================================================ */

.filter-group { margin-bottom: var(--space-5); }
.filter-group__title { font-size: var(--font-size-sm); font-weight: 600; margin-bottom: var(--space-2); color: var(--color-gray-700); }
.filter-group__list { display: flex; flex-direction: column; gap: var(--space-1); }
.filter-group__row { display: flex; gap: var(--space-2); align-items: center; }
.filter-group__sublist { padding-left: var(--space-4); }
.filter-group__count { font-size: var(--font-size-xs); color: var(--color-gray-400); margin-left: auto; }

.filter-pills { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-bottom: var(--space-4); }
.filter-pill {
    display: inline-flex; align-items: center; gap: var(--space-1);
    padding: var(--space-1) var(--space-3); background: var(--color-primary-bg);
    color: var(--color-primary); border-radius: var(--radius-full); font-size: var(--font-size-xs); font-weight: 500;
}
.filter-fab {
    display: none; position: fixed; bottom: var(--space-4); right: var(--space-4);
    z-index: var(--z-sticky); background: var(--color-primary); color: var(--color-white);
    padding: var(--space-3) var(--space-5); border-radius: var(--radius-full);
    box-shadow: var(--shadow-lg); border: none; cursor: pointer; font-weight: 600;
    font-family: var(--font-family); font-size: var(--font-size-sm);
}
@media (max-width: 1024px) { .filter-fab { display: flex; align-items: center; gap: var(--space-2); } }


/* ============================================================
   CATEGORY COMPONENTS
   ============================================================ */

.category-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: var(--space-4); }

.category-card {
    display: flex; flex-direction: column; align-items: center;
    padding: var(--space-6) var(--space-4); background: var(--color-white);
    border: 1px solid var(--color-gray-200); border-radius: var(--radius-lg);
    text-align: center; transition: all var(--transition); text-decoration: none; color: inherit;
}
.category-card:hover { border-color: var(--color-primary); box-shadow: var(--shadow-md); text-decoration: none; transform: translateY(-2px); }
.category-card--lg { padding: var(--space-8) var(--space-6); }
.category-card__icon { font-size: 2rem; margin-bottom: var(--space-3); color: var(--color-primary); }
.category-card__icon--lg { font-size: 2.5rem; }
.category-card__name { font-weight: 600; font-size: var(--font-size-base); color: var(--color-gray-800); margin-bottom: var(--space-1); }
.category-card__count { font-size: var(--font-size-xs); color: var(--color-gray-400); }
.category-card__subs { font-size: var(--font-size-xs); color: var(--color-gray-500); margin-top: var(--space-2); }
.category-card__more { font-size: var(--font-size-xs); color: var(--color-primary); margin-top: var(--space-2); }

.category-filter { }
.category-filter__title { font-size: var(--font-size-sm); font-weight: 700; margin-bottom: var(--space-3); color: var(--color-gray-700); }
.category-filter__list { display: flex; flex-direction: column; }
.category-filter__item { }
.category-filter__link {
    display: flex; align-items: center; gap: var(--space-2);
    padding: var(--space-2) var(--space-3); font-size: var(--font-size-sm);
    color: var(--color-gray-600); border-radius: var(--radius); transition: all var(--transition); text-decoration: none;
}
.category-filter__link:hover, .category-filter__link.is-active { background: var(--color-primary-bg); color: var(--color-primary); text-decoration: none; }
.category-filter__link--sub { padding-left: var(--space-8); font-size: var(--font-size-xs); }
.category-filter__icon { width: 1.2em; text-align: center; }
.category-filter__count { margin-left: auto; font-size: var(--font-size-xs); color: var(--color-gray-400); }
.category-filter__sublist { }
.category-filter__subitem { }

.subcategory-bar { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-bottom: var(--space-6); }
.subcategory-tag {
    display: inline-flex; align-items: center; padding: var(--space-2) var(--space-3);
    background: var(--color-gray-100); border-radius: var(--radius-full);
    font-size: var(--font-size-sm); color: var(--color-gray-600); text-decoration: none;
    transition: all var(--transition);
}
.subcategory-tag:hover, .subcategory-tag.is-active { background: var(--color-primary-bg); color: var(--color-primary); text-decoration: none; }


/* ============================================================
   SERVICE CARD EXTENSIONS
   ============================================================ */

.service-card--sm .service-card__image { height: 140px; }
.service-card--sm .service-card__body { padding: var(--space-3); }
.service-card--fav { position: relative; }
.service-card__image-link { display: block; height: 100%; }
.service-card__placeholder {
    width: 100%; height: 100%; display: flex; align-items: center; justify-content: center;
    background: var(--color-gray-100); color: var(--color-gray-300); font-size: 3rem;
}
.service-card__badge--rental { background: var(--color-secondary); color: var(--color-white); }
.service-card__type-badge {
    position: absolute; top: var(--space-3); right: var(--space-3);
    padding: 0.15em 0.5em; font-size: var(--font-size-xs); font-weight: 600;
    border-radius: var(--radius-sm); background: var(--color-info-bg); color: var(--color-info);
}
.service-card__favorite-icon { font-size: 1rem; }
.service-card__fav-remove {
    position: absolute; top: var(--space-2); right: var(--space-2);
    background: rgba(255,255,255,0.9); border: none; border-radius: var(--radius-full);
    width: 28px; height: 28px; cursor: pointer; display: flex; align-items: center; justify-content: center;
    color: var(--color-danger); font-size: 0.9rem;
}
.service-card__provider-name { font-size: var(--font-size-xs); color: var(--color-gray-500); }
.service-card__rating-count { font-size: var(--font-size-xs); color: var(--color-gray-400); font-weight: 400; }
.service-card__distance { font-size: var(--font-size-xs); color: var(--color-gray-400); }
.service-card__price--agreement { font-size: var(--font-size-sm); color: var(--color-gray-500); font-weight: 500; }
.service-card__price-type { font-size: var(--font-size-xs); color: var(--color-gray-400); font-weight: 400; }
.service-card__footer {
    padding: var(--space-3) var(--space-4); border-top: 1px solid var(--color-gray-100);
    display: flex; justify-content: space-between; align-items: center;
}


/* ============================================================
   SERVICE LIST ITEM (list view)
   ============================================================ */

.service-list { display: flex; flex-direction: column; gap: var(--space-4); }
.service-list-item {
    display: flex; gap: var(--space-4); padding: var(--space-4);
    background: var(--color-white); border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-lg); transition: box-shadow var(--transition);
}
.service-list-item:hover { box-shadow: var(--shadow-md); }
.service-list-item__image {
    flex-shrink: 0; width: 200px; height: 150px; border-radius: var(--radius);
    overflow: hidden; background: var(--color-gray-100);
}
.service-list-item__image img { width: 100%; height: 100%; object-fit: cover; }
.service-list-item__body { flex: 1; display: flex; flex-direction: column; }
.service-list-item__header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: var(--space-2); }
.service-list-item__title { font-size: var(--font-size-lg); font-weight: 600; margin-bottom: 0; }
.service-list-item__title a { color: inherit; text-decoration: none; }
.service-list-item__title a:hover { color: var(--color-primary); }
.service-list-item__meta { display: flex; flex-wrap: wrap; gap: var(--space-3); font-size: var(--font-size-sm); color: var(--color-gray-500); margin-bottom: var(--space-2); }
.service-list-item__provider { display: flex; align-items: center; gap: var(--space-1); }
.service-list-item__rating { display: flex; align-items: center; gap: var(--space-1); color: var(--color-accent); }
.service-list-item__location { display: flex; align-items: center; gap: var(--space-1); }
.service-list-item__distance { font-size: var(--font-size-xs); color: var(--color-gray-400); }
.service-list-item__aside { display: flex; flex-direction: column; align-items: flex-end; justify-content: space-between; flex-shrink: 0; min-width: 120px; }
.service-list-item__price { font-size: var(--font-size-xl); font-weight: 700; color: var(--color-gray-900); }
.service-list-item__price-type { font-size: var(--font-size-xs); color: var(--color-gray-400); }

@media (max-width: 768px) {
    .service-list-item { flex-direction: column; }
    .service-list-item__image { width: 100%; height: 180px; }
    .service-list-item__aside { flex-direction: row; min-width: unset; width: 100%; }
}


/* ============================================================
   SERVICE DETAIL
   ============================================================ */

.service-detail { }
.service-detail__layout { display: grid; grid-template-columns: 1fr 340px; gap: var(--space-6); align-items: start; }
.service-detail__main { }
.service-detail__sidebar { position: sticky; top: calc(var(--header-height) + var(--space-4)); }
.service-detail__section { margin-bottom: var(--space-6); }
.service-detail__section-title { font-size: var(--font-size-lg); font-weight: 600; margin-bottom: var(--space-3); padding-bottom: var(--space-2); border-bottom: 1px solid var(--color-gray-100); }
.service-detail__map { height: 300px; border-radius: var(--radius-lg); overflow: hidden; margin-bottom: var(--space-4); }
.service-detail__address { font-size: var(--font-size-sm); color: var(--color-gray-500); display: flex; align-items: center; gap: var(--space-2); }
.service-form { }

@media (max-width: 1024px) {
    .service-detail__layout { grid-template-columns: 1fr; }
    .service-detail__sidebar { position: static; }
}


/* ============================================================
   SERVICE GRID
   ============================================================ */

.service-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--space-4); }
.service-grid--3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 768px) { .service-grid--3 { grid-template-columns: 1fr; } }


/* ============================================================
   SIDEBAR CARD (service detail sidebar)
   ============================================================ */

.sidebar-card {
    background: var(--color-white); border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-lg); padding: var(--space-5); box-shadow: var(--shadow-sm);
}
.sidebar-card__title { font-size: var(--font-size-lg); font-weight: 600; margin-bottom: var(--space-3); }
.sidebar-card__price { margin-bottom: var(--space-4); }
.sidebar-card__price-amount { font-size: var(--font-size-3xl); font-weight: 800; color: var(--color-gray-900); }
.sidebar-card__price-type { font-size: var(--font-size-sm); color: var(--color-gray-500); }
.sidebar-card__rating { display: flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-4); }
.sidebar-card__actions { display: flex; flex-direction: column; gap: var(--space-2); margin-top: var(--space-4); }
.sidebar-card__action-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    width: 100%;
    padding: var(--space-2) var(--space-4);
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius);
    background: var(--color-white);
    color: var(--color-gray-600);
    font-size: var(--font-size-sm);
    font-weight: 500;
    cursor: pointer;
    text-align: center;
    transition: background var(--transition), border-color var(--transition), color var(--transition);
    text-decoration: none;
}
.sidebar-card__action-btn:hover {
    background: var(--color-gray-50);
    border-color: var(--color-gray-300);
    color: var(--color-gray-800);
}
.sidebar-card__action-btn svg { flex-shrink: 0; }
.sidebar-card__login-hint { font-size: var(--font-size-xs); color: var(--color-gray-400); text-align: center; margin-top: var(--space-2); }


/* ============================================================
   CONTACT LOCKED EXTENSIONS
   ============================================================ */

.contact-locked__actions { display: flex; flex-direction: column; gap: var(--space-2); align-items: center; }
.contact-locked__pricing { margin: var(--space-4) 0; }
.contact-locked__price-option {
    display: flex; justify-content: space-between; align-items: center;
    padding: var(--space-3); border: 1px solid var(--color-gray-200); border-radius: var(--radius);
    margin-bottom: var(--space-2); cursor: pointer; transition: all var(--transition);
}
.contact-locked__price-option:hover { border-color: var(--color-primary); }
.contact-locked__price-option--recommended { border-color: var(--color-primary); background: var(--color-primary-bg); }
.contact-locked__price-label { font-size: var(--font-size-sm); font-weight: 500; }
.contact-locked__price-amount { font-weight: 700; color: var(--color-gray-900); }
.contact-locked__price-badge {
    font-size: var(--font-size-xs); background: var(--color-success-bg); color: var(--color-success);
    padding: 0.1em 0.5em; border-radius: var(--radius-sm); font-weight: 600;
}
.contact-locked__features { margin-top: var(--space-4); }
.contact-locked__features-title { font-size: var(--font-size-sm); font-weight: 600; margin-bottom: var(--space-2); }
.contact-locked__feature-list { text-align: left; display: flex; flex-direction: column; gap: var(--space-1); font-size: var(--font-size-sm); color: var(--color-gray-600); }
.contact-locked__hint { font-size: var(--font-size-xs); color: var(--color-gray-400); margin-top: var(--space-3); }
.contact-locked__trial { font-size: var(--font-size-sm); color: var(--color-primary); font-weight: 500; margin-top: var(--space-2); }


/* ============================================================
   IMAGE GALLERY EXTENSIONS
   ============================================================ */

.image-gallery { margin-bottom: var(--space-6); }
.image-gallery__main {
    border-radius: var(--radius-lg); overflow: hidden; margin-bottom: var(--space-3);
    cursor: zoom-in; aspect-ratio: 16 / 10; background: var(--color-gray-100);
}
.image-gallery__main img { width: 100%; height: 100%; object-fit: cover; }
.image-gallery__thumbs { display: flex; gap: var(--space-2); overflow-x: auto; }
.image-gallery__thumb {
    flex-shrink: 0; width: 80px; height: 60px; border-radius: var(--radius);
    overflow: hidden; cursor: pointer; border: 2px solid transparent; opacity: 0.7;
    transition: all var(--transition);
}
.image-gallery__thumb:hover, .image-gallery__thumb.is-active { opacity: 1; border-color: var(--color-primary); }
.image-gallery__thumb img { width: 100%; height: 100%; object-fit: cover; }
.image-gallery__count {
    position: absolute; bottom: var(--space-3); right: var(--space-3);
    background: rgba(0,0,0,0.7); color: var(--color-white); padding: var(--space-1) var(--space-3);
    border-radius: var(--radius); font-size: var(--font-size-sm);
}
.image-gallery__fullscreen {
    position: absolute; top: var(--space-3); right: var(--space-3);
    background: rgba(0,0,0,0.5); color: var(--color-white); border: none;
    padding: var(--space-2); border-radius: var(--radius); cursor: pointer;
}

.image-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(100px, 1fr)); gap: var(--space-2); }
.image-grid__item { position: relative; aspect-ratio: 1; border-radius: var(--radius); overflow: hidden; }
.image-grid__item img { width: 100%; height: 100%; object-fit: cover; }
.image-grid__add {
    aspect-ratio: 1; border: 2px dashed var(--color-gray-300); border-radius: var(--radius);
    display: flex; align-items: center; justify-content: center; cursor: pointer;
    color: var(--color-gray-400); font-size: 1.5rem; transition: all var(--transition);
}
.image-grid__add:hover { border-color: var(--color-primary); color: var(--color-primary); }


/* ============================================================
   MAP WIDGET
   ============================================================ */

.map-widget { position: relative; }
.map-widget__container { height: 400px; border-radius: var(--radius-lg); overflow: hidden; }
.map-widget__search {
    position: absolute; top: var(--space-3); left: var(--space-3); right: var(--space-3);
    z-index: 1000;
}
.map-widget__suggestions {
    position: absolute; top: 100%; left: 0; right: 0;
    background: var(--color-white); border: 1px solid var(--color-gray-200);
    border-radius: var(--radius); box-shadow: var(--shadow-md); z-index: 1001; display: none;
}
.map-widget__noscript {
    height: 400px; background: var(--color-gray-100); border-radius: var(--radius-lg);
    display: flex; align-items: center; justify-content: center; color: var(--color-gray-400);
}


/* ============================================================
   RADIUS SLIDER
   ============================================================ */

.radius-slider { margin-bottom: var(--space-4); }
.radius-slider__header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-2); }
.radius-slider__label { font-size: var(--font-size-sm); font-weight: 500; }
.radius-slider__value { font-size: var(--font-size-sm); font-weight: 600; color: var(--color-primary); }
.radius-slider__input {
    width: 100%; -webkit-appearance: none; height: 6px; border-radius: 3px;
    background: var(--color-gray-200); outline: none;
}
.radius-slider__input::-webkit-slider-thumb {
    -webkit-appearance: none; width: 20px; height: 20px; border-radius: 50%;
    background: var(--color-primary); cursor: pointer; box-shadow: var(--shadow-sm);
}
.radius-slider__presets { display: flex; gap: var(--space-1); margin-top: var(--space-2); }
.radius-slider__preset {
    padding: var(--space-1) var(--space-2); font-size: var(--font-size-xs);
    background: var(--color-gray-100); border: none; border-radius: var(--radius-sm);
    cursor: pointer; transition: all var(--transition); font-family: var(--font-family);
}
.radius-slider__preset:hover, .radius-slider__preset.is-active { background: var(--color-primary-bg); color: var(--color-primary); }


/* ============================================================
   PLAN CARD (pricing/subscription)
   ============================================================ */

.plans-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: var(--space-6); }
.subscription-plans { }

.plan-card {
    border: 2px solid var(--color-gray-200); border-radius: var(--radius-xl);
    overflow: hidden; background: var(--color-white); transition: all var(--transition); position: relative;
}
.plan-card.is-featured { border-color: var(--color-primary); box-shadow: var(--shadow-lg); }
.plan-card__badge {
    position: absolute; top: var(--space-3); right: var(--space-3);
    padding: 0.2em 0.7em; font-size: var(--font-size-xs); font-weight: 700;
    border-radius: var(--radius-full); background: var(--color-primary); color: var(--color-white);
}
.plan-card__badge--current { background: var(--color-success); }
.plan-card__header { padding: var(--space-6) var(--space-6) var(--space-4); text-align: center; }
.plan-card__name { font-size: var(--font-size-xl); font-weight: 700; margin-bottom: var(--space-2); }
.plan-card__price { margin-bottom: var(--space-2); }
.plan-card__amount { font-size: var(--font-size-4xl); font-weight: 800; color: var(--color-gray-900); }
.plan-card__period { font-size: var(--font-size-sm); color: var(--color-gray-500); }
.plan-card__savings { font-size: var(--font-size-xs); color: var(--color-success); font-weight: 600; }
.plan-card__features { padding: 0 var(--space-6); }
.plan-card__feature-list { display: flex; flex-direction: column; gap: var(--space-2); }
.plan-card__feature-list li {
    display: flex; align-items: center; gap: var(--space-2);
    font-size: var(--font-size-sm); color: var(--color-gray-600); list-style: none;
}
.plan-card__action { padding: var(--space-6); text-align: center; }
.plan-card__payment { font-size: var(--font-size-xs); color: var(--color-gray-400); margin-top: var(--space-2); text-align: center; }

.pricing-toggle { display: flex; align-items: center; justify-content: center; gap: var(--space-3); margin-bottom: var(--space-8); }
.pricing-toggle__label { font-size: var(--font-size-sm); font-weight: 500; color: var(--color-gray-500); }
.pricing-toggle__label.is-active { color: var(--color-gray-900); }
.pricing-toggle__switch { position: relative; width: 48px; height: 26px; cursor: pointer; }

.pricing-note { font-size: var(--font-size-xs); color: var(--color-gray-400); text-align: center; margin-top: var(--space-4); }


/* ============================================================
   AUTH PAGES
   ============================================================ */

.auth-page { display: flex; align-items: center; justify-content: center; min-height: calc(100vh - var(--header-height)); padding: var(--space-8) var(--space-4); }
.auth-card {
    width: 100%; max-width: 440px; background: var(--color-white);
    border: 1px solid var(--color-gray-200); border-radius: var(--radius-xl);
    box-shadow: var(--shadow-lg); padding: var(--space-8);
}
.auth-card__title { font-size: var(--font-size-2xl); text-align: center; margin-bottom: var(--space-1); }
.auth-card__subtitle { text-align: center; color: var(--color-gray-500); font-size: var(--font-size-sm); margin-bottom: var(--space-6); }
.auth-card__oauth { display: flex; flex-direction: column; gap: var(--space-2); margin-bottom: var(--space-4); }
.auth-card__divider {
    display: flex; align-items: center; gap: var(--space-3); margin: var(--space-4) 0;
    color: var(--color-gray-400); font-size: var(--font-size-sm);
}
.auth-card__divider::before, .auth-card__divider::after { content: ''; flex: 1; height: 1px; background: var(--color-gray-200); }
.auth-card__footer { text-align: center; margin-top: var(--space-4); font-size: var(--font-size-sm); color: var(--color-gray-500); }

.auth-form { }
.auth-form__errors {
    background: var(--color-danger-bg); color: var(--color-danger); padding: var(--space-3) var(--space-4);
    border-radius: var(--radius); margin-bottom: var(--space-4); font-size: var(--font-size-sm);
    border: 1px solid #fecaca;
}
.auth-form__switch { text-align: center; margin-top: var(--space-4); font-size: var(--font-size-sm); }
.auth-form__link { color: var(--color-primary); font-weight: 500; }
.auth-divider {
    display: flex; align-items: center; gap: var(--space-3); margin: var(--space-4) 0;
    color: var(--color-gray-400); font-size: var(--font-size-sm);
}
.auth-divider::before, .auth-divider::after { content: ''; flex: 1; height: 1px; background: var(--color-gray-200); }
.auth-oauth { display: flex; flex-direction: column; gap: var(--space-2); }

.role-selector { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3); margin-bottom: var(--space-5); }
.role-selector__option {
    padding: var(--space-4); border: 2px solid var(--color-gray-200); border-radius: var(--radius-lg);
    text-align: center; cursor: pointer; transition: all var(--transition);
}
.role-selector__option:hover { border-color: var(--color-primary-light); }
.role-selector__option.is-selected { border-color: var(--color-primary); background: var(--color-primary-bg); }
.role-selector__icon { font-size: 1.5rem; margin-bottom: var(--space-2); }
.role-selector__label { font-weight: 600; font-size: var(--font-size-sm); }
.role-select { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3); margin-bottom: var(--space-4); }
.role-select__option { padding: var(--space-3); border: 2px solid var(--color-gray-200); border-radius: var(--radius); text-align: center; cursor: pointer; transition: all var(--transition); }
.role-select__option.is-selected { border-color: var(--color-primary); background: var(--color-primary-bg); }
.role-select__label { font-size: var(--font-size-sm); font-weight: 600; }

.password-strength {
    height: 4px; border-radius: 2px; background: var(--color-gray-200); margin-top: var(--space-1); overflow: hidden;
}
.password-strength__bar { height: 100%; border-radius: 2px; transition: width 0.3s, background 0.3s; }


/* ============================================================
   DASHBOARD EXTENSIONS
   ============================================================ */

.dashboard-wrapper { display: grid; grid-template-columns: var(--sidebar-width) 1fr; min-height: calc(100vh - var(--header-height)); }
.dashboard-body { display: flex; min-height: calc(100vh - var(--header-height)); }
.dashboard-content { flex: 1; padding: var(--space-6) var(--space-8); max-width: 1000px; min-width: 0; overflow-x: hidden; }
.dashboard-content--wide { max-width: 100%; }

.dashboard-sidebar {
    width: var(--sidebar-width); background: var(--color-gray-50);
    border-right: 1px solid var(--color-gray-200); padding: var(--space-6) 0;
    position: sticky; top: var(--header-height); height: calc(100vh - var(--header-height)); overflow-y: auto;
}
.dashboard-sidebar__user { display: flex; align-items: center; gap: var(--space-3); padding: 0 var(--space-4) var(--space-5); border-bottom: 1px solid var(--color-gray-200); margin-bottom: var(--space-4); }
.dashboard-sidebar__avatar { width: 40px; height: 40px; border-radius: var(--radius-full); object-fit: cover; }
.dashboard-sidebar__user-info { }
.dashboard-sidebar__role { font-size: var(--font-size-xs); color: var(--color-gray-400); }

.dashboard-nav { padding: 0 var(--space-3); }
.dashboard-nav__link {
    display: flex; align-items: center; gap: var(--space-3);
    padding: var(--space-2) var(--space-3); font-size: var(--font-size-sm); color: var(--color-gray-600);
    border-radius: var(--radius); transition: all var(--transition); text-decoration: none;
    margin-bottom: var(--space-1);
}
.dashboard-nav__link:hover { background: var(--color-gray-200); color: var(--color-gray-800); text-decoration: none; }
.dashboard-nav__link.is-active { background: var(--color-primary-bg); color: var(--color-primary); font-weight: 600; }
.dashboard-nav__icon { width: 1.2em; text-align: center; }
.dashboard-nav__divider { height: 1px; background: var(--color-gray-200); margin: var(--space-3) var(--space-3); }

.dashboard-header { margin-bottom: var(--space-6); }
.dashboard-header__title { font-size: var(--font-size-2xl); margin-bottom: var(--space-1); }
.dashboard-header__subtitle { color: var(--color-gray-500); font-size: var(--font-size-sm); }

.dashboard-card {
    background: var(--color-white); border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-lg); overflow: hidden;
}
.dashboard-card--compact { }
.dashboard-card--highlight { border-color: var(--color-primary); }
.dashboard-card__header {
    display: flex; align-items: center; justify-content: space-between;
    padding: var(--space-4) var(--space-5); border-bottom: 1px solid var(--color-gray-100);
}
.dashboard-card__title { font-size: var(--font-size-base); font-weight: 600; margin-bottom: 0; }
.dashboard-card__link { font-size: var(--font-size-sm); color: var(--color-primary); }
.dashboard-card__row {
    display: flex; align-items: center; justify-content: space-between;
    padding: var(--space-3) var(--space-5); border-bottom: 1px solid var(--color-gray-50);
    font-size: var(--font-size-sm);
}
.dashboard-card__row:last-child { border-bottom: none; }

@media (max-width: 1024px) {
    .dashboard-wrapper { grid-template-columns: 1fr; }
    .dashboard-body { flex-direction: column; }
    .dashboard-sidebar {
        position: fixed; left: -100%; top: var(--header-height); z-index: var(--z-dropdown);
        width: var(--sidebar-width); transition: left var(--transition-slow);
    }
    .dashboard-sidebar.is-open { left: 0; }
    .dashboard-content {
        padding: var(--space-4);
        min-width: 0;        /* prevent grid blowout */
        overflow-x: hidden;  /* clip any overflowing child */
        max-width: 100vw;
    }
}


/* ============================================================
   STAT CARDS
   ============================================================ */

.stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--space-4); margin-bottom: var(--space-6); }
.stats-bar { margin-bottom: var(--space-6); }
.stats-bar__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: var(--space-4); }
.stats-bar__item { text-align: center; padding: var(--space-3); }
.stats-bar__number { font-size: var(--font-size-2xl); font-weight: 800; color: var(--color-gray-900); }
.stats-bar__label { font-size: var(--font-size-xs); color: var(--color-gray-500); margin-top: var(--space-1); }

.stat-card {
    display: flex; align-items: center; gap: var(--space-4);
    padding: var(--space-5); background: var(--color-white);
    border: 1px solid var(--color-gray-200); border-radius: var(--radius-lg);
    text-decoration: none; color: inherit;
    transition: box-shadow var(--transition), border-color var(--transition);
}
a.stat-card:hover {
    box-shadow: var(--shadow-md);
    border-color: var(--color-primary);
    text-decoration: none;
}
.stat-card__icon {
    width: 48px; height: 48px; border-radius: var(--radius-lg);
    display: flex; align-items: center; justify-content: center; font-size: 1.25rem;
    flex-shrink: 0;
}
.stat-card__icon--blue { background: var(--color-info-bg); color: var(--color-info); }
.stat-card__icon--green { background: var(--color-success-bg); color: var(--color-success); }
.stat-card__icon--yellow { background: var(--color-warning-bg); color: var(--color-warning); }
.stat-card__icon--red { background: var(--color-danger-bg); color: var(--color-danger); }
.stat-card__icon--purple { background: #f3e8ff; color: #7c3aed; }
.stat-card__icon--orange { background: #fff7ed; color: #ea580c; }
.stat-card--warning { text-decoration: none; border: 2px solid var(--color-warning, #f59e0b); cursor: pointer; }
.stat-card--warning:hover { background: #fffbeb; }
.stat-card__data { }
.stat-card__number { font-size: var(--font-size-2xl); font-weight: 800; color: var(--color-gray-900); line-height: 1; }
.stat-card__label { font-size: var(--font-size-xs); color: var(--color-gray-500); margin-top: var(--space-1); }


/* ============================================================
   QUICK ACTIONS
   ============================================================ */

.quick-actions { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: var(--space-3); }
.quick-action {
    display: flex; align-items: center; gap: var(--space-3);
    padding: var(--space-3) var(--space-4); background: var(--color-white);
    border: 1px solid var(--color-gray-200); border-radius: var(--radius);
    font-size: var(--font-size-sm); font-weight: 500; color: var(--color-gray-700);
    text-decoration: none; transition: all var(--transition);
}
.quick-action:hover { border-color: var(--color-primary); color: var(--color-primary); text-decoration: none; }


/* ============================================================
   PROFILE AVATAR
   ============================================================ */

.profile-avatar { position: relative; display: inline-block; margin-bottom: var(--space-4); }
.profile-avatar__image { width: 96px; height: 96px; border-radius: var(--radius-full); object-fit: cover; border: 3px solid var(--color-gray-200); }
.profile-avatar__change {
    position: absolute; bottom: 0; right: 0;
    width: 32px; height: 32px; border-radius: var(--radius-full);
    background: var(--color-primary); color: var(--color-white); border: 2px solid var(--color-white);
    display: flex; align-items: center; justify-content: center; cursor: pointer; font-size: 0.8rem;
}


/* ============================================================
   SETTINGS SECTIONS
   ============================================================ */

.settings-section { margin-bottom: var(--space-8); }
.settings-section__title { font-size: var(--font-size-lg); font-weight: 600; margin-bottom: var(--space-1); }
.settings-section__desc { font-size: var(--font-size-sm); color: var(--color-gray-500); margin-bottom: var(--space-4); }

.oauth-connections { display: flex; flex-direction: column; gap: var(--space-3); }
.oauth-connection {
    display: flex; align-items: center; justify-content: space-between;
    padding: var(--space-3) var(--space-4); border: 1px solid var(--color-gray-200);
    border-radius: var(--radius); background: var(--color-white);
}
.oauth-connection__provider { display: flex; align-items: center; gap: var(--space-3); font-weight: 500; }
.oauth-connection__status { font-size: var(--font-size-xs); }

.delete-account { padding: var(--space-6); background: var(--color-danger-bg); border: 1px solid #fecaca; border-radius: var(--radius-lg); }
.delete-account__title { color: var(--color-danger); }


/* ============================================================
   REVIEWS EXTENSIONS
   ============================================================ */

.review-list { display: flex; flex-direction: column; }
.review-item--dashboard { padding: var(--space-3) 0; }
.review-item--admin { }
.review-item__author { display: flex; align-items: center; gap: var(--space-3); }
.review-item__author-info { }
.review-item__rating { display: flex; align-items: center; gap: var(--space-1); }
.review-item__service { font-size: var(--font-size-xs); color: var(--color-gray-400); }
.review-item__actions { display: flex; gap: var(--space-2); margin-top: var(--space-2); }
.review-item__report { font-size: var(--font-size-xs); color: var(--color-gray-400); cursor: pointer; }
.review-item__reply-form { margin-top: var(--space-3); }
.review-item__reply-header { display: flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-1); font-size: var(--font-size-sm); font-weight: 600; }
.review-item__reply-text { font-size: var(--font-size-sm); color: var(--color-gray-600); }
.review-item__reply-date { font-size: var(--font-size-xs); color: var(--color-gray-400); }
.review-item__reply-actions { margin-top: var(--space-2); }

.rating-summary { margin-bottom: var(--space-6); display: flex; align-items: flex-start; gap: var(--space-6); flex-wrap: wrap; }
.rating-summary--inline { display: flex; align-items: center; gap: var(--space-6); }
.rating-summary__average { display: flex; flex-direction: column; align-items: center; gap: var(--space-1); min-width: 80px; }
.rating-summary__stars { display: flex; align-items: center; gap: 2px; color: var(--color-accent); }
.rating-summary__number { font-size: var(--font-size-4xl); font-weight: 800; color: var(--color-gray-900); line-height: 1; }
.rating-summary__bars { flex: 1; min-width: 160px; }

/* Booking CTA in sidebar */
.booking-cta { padding: var(--space-4) 0; }
.booking-cta__text { font-size: var(--font-size-sm); color: var(--color-gray-600); margin-bottom: var(--space-3); }
.booking-cta__hint { margin-top: var(--space-2); }

.rating-bar { display: flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-1); }
.rating-bar__label { font-size: var(--font-size-xs); width: 2em; text-align: right; color: var(--color-gray-500); }
.rating-bar__track { flex: 1; height: 8px; background: var(--color-gray-100); border-radius: 4px; overflow: hidden; }
.rating-bar__fill { height: 100%; background: var(--color-accent); border-radius: 4px; }
.rating-bar__count { font-size: var(--font-size-xs); color: var(--color-gray-400); width: 2em; }

.star-rating { display: inline-flex; gap: 2px; }
.star-rating__star { color: var(--color-gray-300); font-size: 1rem; }
.star-rating__star.is-filled { color: var(--color-accent); }
.star-input { display: inline-flex; gap: 2px; cursor: pointer; }
.star-input__star { font-size: 1.5rem; color: var(--color-gray-300); cursor: pointer; transition: color var(--transition); }
.star-input__star:hover, .star-input__star.is-active { color: var(--color-accent); }


/* ============================================================
   BOOKING DETAIL
   ============================================================ */

/* Responsive booking list — table on desktop, cards on mobile */
.booking-table--desktop { display: block; }
.booking-table--mobile  { display: none; }

@media (max-width: 768px) {
    .booking-table--desktop { display: none; }
    .booking-table--mobile  { display: flex; flex-direction: column; gap: var(--space-2); }
}

/* Booking card (mobile list item) */
.booking-card {
    display: block;
    padding: var(--space-3) var(--space-4);
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-lg);
    background: var(--color-white);
    text-decoration: none;
    color: inherit;
    transition: box-shadow var(--transition), border-color var(--transition);
}
.booking-card:hover {
    box-shadow: var(--shadow-sm);
    border-color: var(--color-primary-300, #93c5fd);
}
.booking-card__top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-2);
    margin-bottom: var(--space-2);
}
.booking-card__service {
    font-weight: 600;
    font-size: var(--font-size-sm);
    color: var(--color-gray-900);
}
.booking-card__meta {
    display: flex;
    gap: var(--space-3);
    font-size: var(--font-size-xs);
    color: var(--color-gray-500);
    margin-bottom: var(--space-1);
}
.booking-card__person {
    font-size: var(--font-size-xs);
    color: var(--color-gray-400);
}

.booking-detail { }
.booking-detail__header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: var(--space-6); }
.booking-detail__title { font-size: var(--font-size-2xl); margin-bottom: var(--space-1); }
.booking-detail__date { font-size: var(--font-size-sm); color: var(--color-gray-500); }
.booking-detail__card { background: var(--color-white); border: 1px solid var(--color-gray-200); border-radius: var(--radius-lg); padding: var(--space-5); margin-bottom: var(--space-4); }
.booking-detail__section-title { font-size: var(--font-size-base); font-weight: 600; margin-bottom: var(--space-3); }
.booking-detail__service { display: flex; gap: var(--space-4); align-items: center; }
.booking-detail__thumb { width: 80px; height: 60px; border-radius: var(--radius); overflow: hidden; flex-shrink: 0; }
.booking-detail__thumb img { width: 100%; height: 100%; object-fit: cover; }
.booking-detail__actions { display: flex; gap: var(--space-2); flex-wrap: wrap; }


/* ============================================================
   CALENDAR WIDGET
   ============================================================ */

.calendar-widget { }
.calendar-widget__toolbar { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-4); }
.calendar-widget__actions { display: flex; gap: var(--space-2); }
.calendar-widget__container { min-height: 500px; }
.calendar-widget__legend { display: flex; gap: var(--space-4); margin-top: var(--space-3); }
.calendar-widget__legend-item { display: flex; align-items: center; gap: var(--space-2); font-size: var(--font-size-xs); color: var(--color-gray-500); }
.calendar-widget__dot { width: 10px; height: 10px; border-radius: var(--radius-full); }
.calendar-widget__dot--available { background: var(--color-success); }
.calendar-widget__dot--blocked { background: var(--color-danger); }
.calendar-widget__dot--booked { background: var(--color-info); }

.calendar-layout { display: grid; grid-template-columns: 1fr 320px; gap: var(--space-6); }
.calendar-layout__main { }
.calendar-layout__sidebar { }
.calendar-sync { }

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


/* ============================================================
   RECURRING SCHEDULE
   ============================================================ */

.recurring-schedule { }
.recurring-day { margin-bottom: var(--space-3); }
.recurring-day__header {
    display: flex; align-items: center; justify-content: space-between;
    padding: var(--space-2) var(--space-3); background: var(--color-gray-50);
    border-radius: var(--radius); margin-bottom: var(--space-2);
}
.recurring-day__toggle { display: flex; align-items: center; gap: var(--space-2); font-weight: 500; font-size: var(--font-size-sm); }
.recurring-day__add { background: none; border: none; cursor: pointer; color: var(--color-primary); font-size: var(--font-size-sm); }
.recurring-day__slots { padding-left: var(--space-4); }
.recurring-day__slot { display: flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-2); font-size: var(--font-size-sm); }


/* ============================================================
   MESSAGES / CHAT
   ============================================================ */

.conversation-list { display: flex; flex-direction: column; }
.conversation-item {
    display: flex; align-items: center; gap: var(--space-3);
    padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--color-gray-50);
    cursor: pointer; transition: background var(--transition); text-decoration: none; color: inherit;
}
.conversation-item:hover { background: var(--color-gray-50); text-decoration: none; }
.conversation-item.is-active { background: var(--color-primary-bg); }
.conversation-item.is-unread { font-weight: 600; }
.conversation-item__avatar { width: 44px; height: 44px; border-radius: var(--radius-full); object-fit: cover; flex-shrink: 0; position: relative; }
.conversation-item__online {
    position: absolute; bottom: 0; right: 0; width: 12px; height: 12px;
    border-radius: var(--radius-full); background: var(--color-success); border: 2px solid var(--color-white);
}
.conversation-item__body { flex: 1; min-width: 0; }
.conversation-item__header { display: flex; justify-content: space-between; align-items: center; }
.conversation-item__name { font-size: var(--font-size-sm); font-weight: 600; }
.conversation-item__time { font-size: var(--font-size-xs); color: var(--color-gray-400); flex-shrink: 0; }
.conversation-item__preview { font-size: var(--font-size-xs); color: var(--color-gray-500); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.conversation-item__service { font-size: var(--font-size-xs); color: var(--color-primary); }
.conversation-item__badge {
    min-width: 20px; height: 20px; border-radius: var(--radius-full);
    background: var(--color-primary); color: var(--color-white); font-size: 0.65rem;
    display: flex; align-items: center; justify-content: center; font-weight: 700; flex-shrink: 0;
}

.chat-header {
    display: flex; align-items: center; gap: var(--space-3);
    padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--color-gray-200);
    background: var(--color-white);
}
.chat-header__back { background: none; border: none; cursor: pointer; color: var(--color-gray-500); font-size: 1.2rem; }
.chat-header__avatar { width: 36px; height: 36px; border-radius: var(--radius-full); object-fit: cover; }
.chat-header__user { font-weight: 600; font-size: var(--font-size-sm); }
.chat-header__service { font-size: var(--font-size-xs); color: var(--color-gray-400); }

.chat-messages { flex: 1; padding: var(--space-4); overflow-y: auto; display: flex; flex-direction: column; gap: var(--space-3); }
.chat-messages__date { text-align: center; font-size: var(--font-size-xs); color: var(--color-gray-400); margin: var(--space-2) 0; }
.chat-messages__empty { text-align: center; color: var(--color-gray-400); padding: var(--space-8); }

.chat-bubble { max-width: 75%; padding: var(--space-3) var(--space-4); border-radius: var(--radius-lg); font-size: var(--font-size-sm); }
.chat-bubble--mine { background: var(--color-primary); color: var(--color-white); margin-left: auto; border-bottom-right-radius: var(--radius-sm); }
.chat-bubble--theirs { background: var(--color-gray-100); color: var(--color-gray-800); border-bottom-left-radius: var(--radius-sm); }
.chat-bubble__content { line-height: 1.5; }
.chat-bubble__time { font-size: var(--font-size-xs); opacity: 0.7; margin-top: var(--space-1); }

.chat-input { padding: var(--space-3) var(--space-4); border-top: 1px solid var(--color-gray-200); background: var(--color-white); }
.chat-input__form { display: flex; gap: var(--space-2); }
.chat-input__form textarea {
    flex: 1; padding: var(--space-2) var(--space-3); border: 1px solid var(--color-gray-300);
    border-radius: var(--radius); resize: none; font-family: var(--font-family); font-size: var(--font-size-sm);
    min-height: 40px; max-height: 120px;
}
.chat-input__send { flex-shrink: 0; }


/* ============================================================
   NOTIFICATIONS
   ============================================================ */

.notification-list { }
.notification-item {
    display: flex; gap: var(--space-3); padding: var(--space-3) var(--space-4);
    border-bottom: 1px solid var(--color-gray-50); transition: background var(--transition);
}
.notification-item.is-unread { background: var(--color-info-bg); }
.notification-item__icon { width: 36px; height: 36px; border-radius: var(--radius-full); background: var(--color-gray-100); display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 0.9rem; }
.notification-item__body { flex: 1; }
.notification-item__text { font-size: var(--font-size-sm); color: var(--color-gray-700); }
.notification-item__time { font-size: var(--font-size-xs); color: var(--color-gray-400); margin-top: var(--space-1); }
.notification-item__link { font-size: var(--font-size-xs); color: var(--color-primary); }

.notification-preview { position: absolute; top: 100%; right: 0; width: 360px; background: var(--color-white); border: 1px solid var(--color-gray-200); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); z-index: var(--z-dropdown); display: none; }
.notification-preview.is-open { display: block; }
.notification-preview__header { padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--color-gray-100); display: flex; justify-content: space-between; align-items: center; }
.notification-preview__list { max-height: 300px; overflow-y: auto; }
.notification-preview__footer { padding: var(--space-2) var(--space-4); border-top: 1px solid var(--color-gray-100); text-align: center; }


/* ============================================================
   SUBSCRIPTION STATUS
   ============================================================ */

.subscription-status { padding: var(--space-5); border-radius: var(--radius-lg); border: 1px solid var(--color-gray-200); }
.subscription-status--active { border-color: var(--color-success); background: var(--color-success-bg); }
.subscription-status--inactive { border-color: var(--color-warning); background: var(--color-warning-bg); }
.subscription-status__badge { margin-bottom: var(--space-2); }
.subscription-status__actions { display: flex; gap: var(--space-2); margin-top: var(--space-4); }


/* ============================================================
   SYNC / CALENDAR SYNC
   ============================================================ */

.sync-providers { display: flex; flex-direction: column; gap: var(--space-3); }
.sync-provider-card {
    display: flex; align-items: center; gap: var(--space-4);
    padding: var(--space-4); border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-lg); background: var(--color-white);
}
.sync-provider-card__icon { font-size: 1.5rem; flex-shrink: 0; width: 40px; text-align: center; }
.sync-provider-card__name { font-weight: 600; font-size: var(--font-size-sm); }
.sync-provider-card__desc { font-size: var(--font-size-xs); color: var(--color-gray-500); }
.sync-provider-card__form { margin-left: auto; }


/* ============================================================
   ERROR PAGES
   ============================================================ */

.error-page { text-align: center; padding: var(--space-16) var(--space-4); min-height: 60vh; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.error-page__code { font-size: 6rem; font-weight: 900; color: var(--color-gray-200); line-height: 1; margin-bottom: var(--space-4); }
.error-page__title { font-size: var(--font-size-2xl); margin-bottom: var(--space-2); }
.error-page__desc { color: var(--color-gray-500); margin-bottom: var(--space-6); max-width: 500px; }
.error-page__content { }
.error-page__actions { display: flex; gap: var(--space-3); justify-content: center; }

.maintenance { text-align: center; padding: var(--space-16) var(--space-4); min-height: 100vh; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.maintenance__icon { font-size: 4rem; margin-bottom: var(--space-6); }
.maintenance__title { font-size: var(--font-size-3xl); margin-bottom: var(--space-3); }
.maintenance__desc { color: var(--color-gray-500); margin-bottom: var(--space-6); max-width: 500px; }
.maintenance__info { font-size: var(--font-size-sm); color: var(--color-gray-400); }
.maintenance__contact { margin-top: var(--space-4); }
.maintenance__actions { display: flex; gap: var(--space-3); justify-content: center; margin-top: var(--space-6); }
.maintenance__timer { font-size: var(--font-size-2xl); font-weight: 700; color: var(--color-primary); margin: var(--space-4) 0; }

.minimal-body { min-height: 100vh; display: flex; flex-direction: column; }
.minimal-header { padding: var(--space-4); text-align: center; border-bottom: 1px solid var(--color-gray-200); }
.minimal-header__logo img { height: 28px; }
.minimal-content { flex: 1; display: flex; align-items: center; justify-content: center; }
.minimal-footer { padding: var(--space-4); text-align: center; font-size: var(--font-size-xs); color: var(--color-gray-400); }


/* ============================================================
   COOKIE SETTINGS
   ============================================================ */

.cookie-settings { max-width: 600px; margin: 0 auto; }
.cookie-settings__group { margin-bottom: var(--space-4); padding: var(--space-4); border: 1px solid var(--color-gray-200); border-radius: var(--radius-lg); }
.cookie-settings__item { display: flex; justify-content: space-between; align-items: flex-start; }
.cookie-settings__info { flex: 1; }
.cookie-settings__toggle { flex-shrink: 0; margin-left: var(--space-4); }
.cookie-settings__always { font-size: var(--font-size-xs); color: var(--color-gray-400); }


/* ============================================================
   ACCORDION
   ============================================================ */

.accordion { }
.accordion__item { border-bottom: 1px solid var(--color-gray-200); }
.accordion__header {
    width: 100%; padding: var(--space-4) 0; background: none; border: none;
    text-align: left; font-size: var(--font-size-base); font-weight: 600;
    color: var(--color-gray-800); cursor: pointer; display: flex;
    justify-content: space-between; align-items: center; font-family: var(--font-family);
}
.accordion__icon { font-size: 1.25rem; color: var(--color-gray-400); transition: transform var(--transition); }
.accordion__item.is-open .accordion__icon { transform: rotate(180deg); }
.accordion__body { display: none; padding-bottom: var(--space-4); color: var(--color-gray-600); font-size: var(--font-size-sm); line-height: 1.7; }
.accordion__item.is-open .accordion__body { display: block; }


/* ============================================================
   TABS
   ============================================================ */

.tabs { display: flex; gap: var(--space-1); border-bottom: 2px solid var(--color-gray-200); margin-bottom: var(--space-6); overflow-x: auto; }
.tabs__tab {
    padding: var(--space-3) var(--space-4); font-size: var(--font-size-sm); font-weight: 500;
    color: var(--color-gray-500); border-bottom: 2px solid transparent; margin-bottom: -2px;
    white-space: nowrap; text-decoration: none; transition: all var(--transition);
}
.tabs__tab:hover { color: var(--color-gray-700); text-decoration: none; }
.tabs__tab.is-active { color: var(--color-primary); border-bottom-color: var(--color-primary); }


/* ============================================================
   TOGGLE SWITCH
   ============================================================ */

.toggle { position: relative; display: inline-block; width: 44px; height: 24px; }
.toggle input { opacity: 0; width: 0; height: 0; }
.toggle__slider {
    position: absolute; cursor: pointer; inset: 0; background: var(--color-gray-300);
    border-radius: var(--radius-full); transition: background var(--transition);
}
.toggle__slider::before {
    content: ''; position: absolute; height: 18px; width: 18px; left: 3px; bottom: 3px;
    background: var(--color-white); border-radius: var(--radius-full); transition: transform var(--transition);
}
.toggle input:checked + .toggle__slider { background: var(--color-primary); }
.toggle input:checked + .toggle__slider::before { transform: translateX(20px); }


/* ============================================================
   CHECKBOX CUSTOM
   ============================================================ */

.checkbox { display: flex; align-items: center; gap: var(--space-2); cursor: pointer; font-size: var(--font-size-sm); }
.checkbox__input { width: 18px; height: 18px; accent-color: var(--color-primary); cursor: pointer; }


/* ============================================================
   INPUT EXTENSIONS
   ============================================================ */

.input { width: 100%; padding: var(--space-3); border: 1px solid var(--color-gray-300); border-radius: var(--radius); font-size: var(--font-size-base); font-family: var(--font-family); transition: border-color var(--transition), box-shadow var(--transition); }
.input:focus { outline: none; border-color: var(--color-primary); box-shadow: 0 0 0 3px var(--color-primary-bg); }
.input--lg { padding: var(--space-4); font-size: var(--font-size-lg); }
.input--sm { padding: var(--space-2); font-size: var(--font-size-sm); }
.input--error { border-color: var(--color-danger); }
.input-group { display: flex; }
.input-group .input { border-radius: var(--radius) 0 0 var(--radius); }
.input-group .btn { border-radius: 0 var(--radius) var(--radius) 0; }

.form-row { display: flex; gap: var(--space-4); }
.form--compact .form-group { margin-bottom: var(--space-3); }
.form--inline { display: flex; align-items: flex-end; gap: var(--space-3); }
.form--search { }

.translation-block { padding: var(--space-4); background: var(--color-gray-50); border-radius: var(--radius-lg); margin-bottom: var(--space-4); border: 1px solid var(--color-gray-200); }


/* ============================================================
   ADDITIONAL BUTTON VARIANTS
   ============================================================ */

.btn--white { background: var(--color-white); color: var(--color-gray-800); border-color: var(--color-gray-300); }
.btn--white:hover { background: var(--color-gray-50); }
.btn--link { background: none; border: none; color: var(--color-primary); padding: 0; font-weight: 500; }
.btn--link:hover { text-decoration: underline; }
.btn--facebook { background: #1877f2; color: var(--color-white); }
.btn--google { background: var(--color-white); color: var(--color-gray-700); border-color: var(--color-gray-300); }
.btn--seznam { background: #cc0000; color: var(--color-white); }


/* ============================================================
   ADDITIONAL BADGES
   ============================================================ */

.badge--featured { background: var(--color-accent); color: var(--color-white); }
.badge--new { background: var(--color-success); color: var(--color-white); }
.badge--rental { background: var(--color-secondary); color: var(--color-white); }


/* ============================================================
   TABLE EXTENSIONS
   ============================================================ */

.table--striped tbody tr:nth-child(even) { background: var(--color-gray-50); }
.table--hoverable tbody tr { cursor: pointer; }
.table__actions { display: flex; gap: var(--space-1); }
.table__avatar { width: 32px; height: 32px; border-radius: var(--radius-full); object-fit: cover; }
.table__user { display: flex; align-items: center; gap: var(--space-2); }
.table__status { }


/* ============================================================
   MODAL EXTENSIONS
   ============================================================ */

.modal--lg { max-width: 640px; }
.modal--sm { max-width: 360px; }
.modal--confirm .modal__body { text-align: center; }
.modal--confirm .modal__footer { justify-content: center; }


/* ============================================================
   LIGHTBOX EXTENSIONS
   ============================================================ */

.lightbox__counter { position: absolute; bottom: var(--space-4); left: 50%; transform: translateX(-50%); color: rgba(255,255,255,0.7); font-size: var(--font-size-sm); }
.lightbox__caption { position: absolute; bottom: var(--space-10); left: 50%; transform: translateX(-50%); color: rgba(255,255,255,0.8); font-size: var(--font-size-sm); text-align: center; }
.lightbox__thumbs { position: absolute; bottom: var(--space-2); left: 50%; transform: translateX(-50%); display: flex; gap: var(--space-1); }
.lightbox__thumb-btn { width: 48px; height: 36px; border: 2px solid transparent; border-radius: var(--radius-sm); overflow: hidden; cursor: pointer; opacity: 0.5; padding: 0; }
.lightbox__thumb-btn.is-active { opacity: 1; border-color: var(--color-white); }


/* ============================================================
   PAGINATION EXTENSIONS
   ============================================================ */

.pagination__info { font-size: var(--font-size-sm); color: var(--color-gray-500); }
.pagination__first, .pagination__last { }
.pagination__prev, .pagination__next { }
.pagination--sm .pagination__link { min-width: 28px; height: 28px; font-size: var(--font-size-xs); }
.pagination--simple { display: flex; justify-content: space-between; align-items: center; }
.pagination--centered { justify-content: center; }


/* ============================================================
   FLASH EXTENSIONS
   ============================================================ */

.flash-container { margin-bottom: var(--space-4); }
.flash__icon { flex-shrink: 0; }
.flash__text { flex: 1; }


/* ============================================================
   PRICING CARD EXTENSIONS
   ============================================================ */

.pricing-card__badge { position: absolute; top: -12px; left: 50%; transform: translateX(-50%); padding: 0.25em 1em; background: var(--color-primary); color: var(--color-white); font-size: var(--font-size-xs); font-weight: 700; border-radius: var(--radius-full); white-space: nowrap; }
.pricing-card__name { font-size: var(--font-size-xl); font-weight: 700; margin-bottom: var(--space-4); }
.pricing-card__desc { font-size: var(--font-size-sm); color: var(--color-gray-500); margin-bottom: var(--space-4); }
.pricing-card__action { margin-top: var(--space-6); }


/* ============================================================
   CONTACT PAGE
   ============================================================ */

.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-8); }
.contact-grid__form { }
.contact-grid__info { }
.contact-info { display: flex; flex-direction: column; gap: var(--space-4); }

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


/* ============================================================
   FAQ EXTENSIONS
   ============================================================ */

.faq-section { margin-bottom: var(--space-6); }
.faq-section__title { font-size: var(--font-size-lg); font-weight: 600; margin-bottom: var(--space-3); }
.faq-cta { text-align: center; padding: var(--space-8); background: var(--color-gray-50); border-radius: var(--radius-xl); margin-top: var(--space-8); }


/* ============================================================
   PROSE (text content)
   ============================================================ */

.prose { font-size: var(--font-size-base); line-height: 1.8; color: var(--color-gray-700); }
.prose h2 { margin-top: var(--space-8); margin-bottom: var(--space-3); }
.prose h3 { margin-top: var(--space-6); margin-bottom: var(--space-2); }
.prose p { margin-bottom: var(--space-4); }
.prose ul, .prose ol { padding-left: var(--space-6); margin-bottom: var(--space-4); }
.prose li { margin-bottom: var(--space-1); list-style: disc; }
.prose a { color: var(--color-primary); text-decoration: underline; }

.page-meta { font-size: var(--font-size-xs); color: var(--color-gray-400); margin-bottom: var(--space-6); }


/* ============================================================
   ADMIN PANEL
   ============================================================ */

.admin-layout { display: grid; grid-template-columns: var(--sidebar-width) 1fr; min-height: 100vh; }
.admin-body { display: flex; min-height: 100vh; }
.admin-main { flex: 1; }
.admin-content { padding: var(--space-6); }

.admin-sidebar {
    width: var(--sidebar-width); background: var(--color-gray-900); color: var(--color-gray-300);
    display: flex; flex-direction: column; position: sticky; top: 0; height: 100vh; overflow-y: auto;
}
.admin-sidebar__header { padding: var(--space-4) var(--space-5); border-bottom: 1px solid var(--color-gray-800); }
.admin-sidebar__logo { color: var(--color-white); font-weight: 700; font-size: var(--font-size-lg); text-decoration: none; }
.admin-sidebar__logo:hover { color: var(--color-white); text-decoration: none; }
.admin-sidebar__nav { flex: 1; padding: var(--space-3) 0; }
.admin-sidebar__link {
    display: flex; align-items: center; gap: var(--space-3);
    padding: var(--space-2) var(--space-5); font-size: var(--font-size-sm);
    color: var(--color-gray-400); transition: all var(--transition); text-decoration: none;
}
.admin-sidebar__link:hover { color: var(--color-white); background: rgba(255,255,255,0.05); text-decoration: none; }
.admin-sidebar__link.is-active { color: var(--color-white); background: rgba(255,255,255,0.1); font-weight: 600; }
.admin-sidebar__badge {
    margin-left: auto; min-width: 20px; height: 20px; border-radius: var(--radius-full);
    background: var(--color-danger); color: var(--color-white); font-size: 0.65rem;
    display: flex; align-items: center; justify-content: center; font-weight: 700;
}
.admin-sidebar__footer { padding: var(--space-4) var(--space-5); border-top: 1px solid var(--color-gray-800); }

.admin-topbar {
    display: flex; align-items: center; justify-content: space-between;
    padding: var(--space-3) var(--space-6); background: var(--color-white);
    border-bottom: 1px solid var(--color-gray-200);
}
.admin-topbar__hamburger { display: none; background: none; border: none; cursor: pointer; font-size: 1.5rem; color: var(--color-gray-600); }
.admin-topbar__right { display: flex; align-items: center; gap: var(--space-3); }
.admin-topbar__user { display: flex; align-items: center; gap: var(--space-2); font-size: var(--font-size-sm); }

.admin-page { }
.admin-page__header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-6); }
.admin-page__title { font-size: var(--font-size-2xl); margin-bottom: 0; }
.admin-page__actions { display: flex; gap: var(--space-2); }
.admin-page-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-6); }
.admin-page-header__actions { display: flex; gap: var(--space-2); }
.admin-title { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-4); }
.admin-title__text { font-size: var(--font-size-xl); font-weight: 600; }

.admin-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: var(--space-4); margin-bottom: var(--space-6); }
.admin-stats__card {
    padding: var(--space-4); background: var(--color-white); border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-lg); border-left: 4px solid var(--color-primary);
}
.admin-stats__card--success { border-left-color: var(--color-success); }
.admin-stats__card--warning { border-left-color: var(--color-warning); }
.admin-stats__card--danger { border-left-color: var(--color-danger); }
.admin-stats__value { font-size: var(--font-size-2xl); font-weight: 800; color: var(--color-gray-900); }
.admin-stats__label { font-size: var(--font-size-xs); color: var(--color-gray-500); margin-top: var(--space-1); }
.admin-stats__secondary { font-size: var(--font-size-xs); color: var(--color-gray-400); }

.admin-stat { padding: var(--space-4); background: var(--color-white); border: 1px solid var(--color-gray-200); border-radius: var(--radius-lg); text-align: center; }
.admin-stat__number { font-size: var(--font-size-2xl); font-weight: 800; color: var(--color-gray-900); }
.admin-stat__label { font-size: var(--font-size-xs); color: var(--color-gray-500); }

.admin-grid { display: grid; grid-template-columns: 1fr 340px; gap: var(--space-6); }
.admin-grid--2 { grid-template-columns: 1fr 1fr; }
.admin-grid--2col { grid-template-columns: 1fr 1fr; }
.admin-grid__main { }
.admin-grid__sidebar { }

.admin-card { background: var(--color-white); border: 1px solid var(--color-gray-200); border-radius: var(--radius-lg); overflow: hidden; }
.admin-card__header { padding: var(--space-4) var(--space-5); border-bottom: 1px solid var(--color-gray-100); display: flex; justify-content: space-between; align-items: center; }

.admin-filters { margin-bottom: var(--space-4); }
.admin-filters__form { display: flex; gap: var(--space-3); align-items: flex-end; flex-wrap: wrap; }
.admin-filters__row { display: flex; gap: var(--space-3); flex-wrap: wrap; flex: 1; }
.admin-filters__actions { display: flex; gap: var(--space-2); }

.admin-compact-list { }
.admin-compact-list li {
    display: flex; justify-content: space-between; align-items: center;
    padding: var(--space-2) var(--space-4); border-bottom: 1px solid var(--color-gray-50);
    font-size: var(--font-size-sm);
}

.admin-export-buttons { display: flex; gap: var(--space-2); }

.admin-image-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(80px, 1fr)); gap: var(--space-2); }
.admin-image-grid__item { aspect-ratio: 1; border-radius: var(--radius); overflow: hidden; }
.admin-image-grid__item img { width: 100%; height: 100%; object-fit: cover; }

.admin-provider-summary { display: flex; gap: var(--space-4); align-items: center; margin-bottom: var(--space-6); }
.admin-provider-summary__avatar { width: 64px; height: 64px; border-radius: var(--radius-full); object-fit: cover; }

.region-tree { }
.region-tree__kraj { margin-bottom: var(--space-3); border: 1px solid var(--color-gray-200); border-radius: var(--radius-lg); overflow: hidden; }
.region-tree__kraj-header { display: flex; align-items: center; justify-content: space-between; padding: var(--space-3) var(--space-4); background: var(--color-gray-50); cursor: pointer; }
.region-tree__kraj-info { display: flex; align-items: center; gap: var(--space-3); font-weight: 500; }
.region-tree__toggle { background: none; border: none; cursor: pointer; color: var(--color-gray-400); }
.region-tree__okresy { padding: var(--space-2) var(--space-4); display: none; }
.region-tree__kraj.is-open .region-tree__okresy { display: block; }
.region-tree__bulk { display: flex; gap: var(--space-2); }

.category-tree { }
.category-tree__item { border: 1px solid var(--color-gray-200); border-radius: var(--radius); margin-bottom: var(--space-2); }
.category-tree__item--child { margin-left: var(--space-6); border-color: var(--color-gray-100); }
.category-tree__row { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-2) var(--space-3); }
.category-tree__handle { cursor: grab; color: var(--color-gray-300); }
.category-tree__icon { width: 1.5em; text-align: center; }
.category-tree__name { flex: 1; font-size: var(--font-size-sm); font-weight: 500; }
.category-tree__count { font-size: var(--font-size-xs); color: var(--color-gray-400); }
.category-tree__actions { display: flex; gap: var(--space-1); }
.category-tree__children { padding-left: var(--space-6); }

@media (max-width: 1024px) {
    .admin-layout { grid-template-columns: 1fr; }
    .admin-sidebar {
        position: fixed; left: -100%; top: 0; z-index: var(--z-modal);
        transition: left var(--transition-slow);
    }
    .admin-sidebar.is-open { left: 0; }
    .admin-topbar__hamburger { display: block; }
    .admin-grid { grid-template-columns: 1fr; }
    .admin-grid--2, .admin-grid--2col { grid-template-columns: 1fr; }
}


/* ============================================================
   MISC HELPERS
   ============================================================ */

.back-link { display: inline-flex; align-items: center; gap: var(--space-2); font-size: var(--font-size-sm); color: var(--color-gray-500); margin-bottom: var(--space-4); }
.back-link:hover { color: var(--color-primary); }

.sr-only-focusable:focus { position: static; width: auto; height: auto; overflow: visible; clip: auto; }

.cookie-bar__settings { }
.cookie-bar__reject { }


/* ============================================================
   RESPONSIVE ADDENDUM
   ============================================================ */

@media (max-width: 768px) {
    .stats-grid { grid-template-columns: 1fr 1fr; }
    .stats-bar__grid { grid-template-columns: 1fr 1fr; }
    .plans-grid { grid-template-columns: 1fr; }
    .quick-actions { grid-template-columns: 1fr; }
    .newsletter__form { flex-direction: column; }
    .booking-detail__header { flex-direction: column; gap: var(--space-3); }
    .booking-detail__service { flex-direction: column; }
    .booking-detail__actions { flex-direction: column; }
    /* Prevent table from expanding past screen width */
    .table-responsive { overflow-x: auto; max-width: 100%; }
    .table th, .table td { white-space: nowrap; }
    /* Tabs wrapping on small screens */
    .tabs { flex-wrap: wrap; }
}

@media (max-width: 480px) {
    .stats-grid { grid-template-columns: 1fr; }
    .cta-section__actions { flex-direction: column; }
    .auth-card { padding: var(--space-5); }
    .role-selector { grid-template-columns: 1fr; }
}


/* ============================================================
   REMAINING MISSING CLASSES
   ============================================================ */

.admin-title__count { font-size: var(--font-size-sm); color: var(--color-gray-400); font-weight: 400; }
.badge--lg { font-size: var(--font-size-sm); padding: 0.3em 0.8em; }
.badge--muted { background: var(--color-gray-100); color: var(--color-gray-500); }
.btn--oauth { display: flex; align-items: center; justify-content: center; gap: var(--space-2); width: 100%; padding: var(--space-3); border: 1px solid var(--color-gray-300); border-radius: var(--radius); background: var(--color-white); font-size: var(--font-size-sm); font-weight: 500; cursor: pointer; transition: all var(--transition); font-family: var(--font-family); }
.btn--oauth:hover { background: var(--color-gray-50); border-color: var(--color-gray-400); }
.calendar-layout__recurring { }
.calendar-layout__visual { }
.card--danger { border-color: var(--color-danger); }
.category-grid--full { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); }
.checkbox__label { cursor: pointer; display: inline-flex; align-items: center; gap: 2px; flex-wrap: wrap; }
.cookie-bar__inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); max-width: var(--container-max); margin: 0 auto; }
.cookie-bar__link { color: var(--color-secondary-light); text-decoration: underline; }
.dashboard-content__title { font-size: var(--font-size-xl); font-weight: 600; margin-bottom: var(--space-4); }
.delete-account__list { font-size: var(--font-size-sm); color: var(--color-gray-600); margin: var(--space-3) 0; padding-left: var(--space-4); }
.delete-account__list li { list-style: disc; margin-bottom: var(--space-1); }
.detail-list--copy { }
.flash__content { flex: 1; }
.flash__list { margin: var(--space-2) 0 0; padding-left: var(--space-4); font-size: var(--font-size-xs); }
.flash__list li { list-style: disc; margin-bottom: var(--space-1); }
.form-row--between { justify-content: space-between; }
.form__actions { display: flex; gap: var(--space-3); margin-top: var(--space-6); }
.btn--flex { flex: 1; justify-content: center; }
.form__fieldset { border: none; padding: 0; margin: 0 0 var(--space-6); }
.form__group { margin-bottom: var(--space-5); }
.form__group--half { flex: 1; }
.form__group--quarter { flex: 0.5; }
.form__hint { display: block; margin-top: var(--space-1); font-size: var(--font-size-xs); color: var(--color-gray-500); }
.form__label { display: block; font-size: var(--font-size-sm); font-weight: 600; color: var(--color-gray-700); margin-bottom: var(--space-1); }
.form__label--inline { display: inline; }
.form__label-link { float: right; font-size: var(--font-size-xs); font-weight: 400; color: var(--color-primary); }
.form__legend { font-size: var(--font-size-lg); font-weight: 600; margin-bottom: var(--space-4); padding-bottom: var(--space-2); border-bottom: 1px solid var(--color-gray-200); }
.form__optional { font-size: var(--font-size-xs); color: var(--color-gray-400); font-weight: 400; }
.form__row { display: flex; gap: var(--space-4); }
.gallery { margin-bottom: var(--space-6); position: relative; }
.gallery__placeholder { height: 300px; background: var(--color-gray-100); border-radius: var(--radius-lg); display: flex; align-items: center; justify-content: center; color: var(--color-gray-300); font-size: 3rem; }
.image-gallery__counter { position: absolute; bottom: var(--space-3); right: var(--space-3); background: rgba(0,0,0,0.6); color: white; padding: var(--space-1) var(--space-2); border-radius: var(--radius-sm); font-size: var(--font-size-xs); }
.image-gallery__main-img { width: 100%; height: 100%; object-fit: cover; }
.image-gallery__thumb-img { width: 100%; height: 100%; object-fit: cover; }
.image-grid__badge { position: absolute; top: var(--space-1); left: var(--space-1); }
.image-grid__remove { position: absolute; top: var(--space-1); right: var(--space-1); width: 22px; height: 22px; border-radius: var(--radius-full); background: rgba(0,0,0,0.5); color: white; border: none; cursor: pointer; font-size: 0.7rem; display: flex; align-items: center; justify-content: center; }
.input--xs { padding: var(--space-1) var(--space-2); font-size: var(--font-size-xs); }
.lightbox__backdrop { position: fixed; inset: 0; background: rgba(0,0,0,0.92); z-index: var(--z-modal); }
.lightbox__content { position: relative; z-index: calc(var(--z-modal) + 1); display: flex; align-items: center; justify-content: center; height: 100vh; }
.lightbox__img { max-width: 90vw; max-height: 90vh; object-fit: contain; }
.maintenance__estimate { font-size: var(--font-size-sm); color: var(--color-gray-500); margin-top: var(--space-2); }
.maintenance__logo { margin-bottom: var(--space-6); }
.maintenance__logo img { height: 32px; }
.maintenance__refresh { margin-top: var(--space-4); }
.maintenance__text { color: var(--color-gray-500); max-width: 500px; margin-bottom: var(--space-6); }
.modal__actions { display: flex; gap: var(--space-3); justify-content: flex-end; padding: var(--space-4) var(--space-6); border-top: 1px solid var(--color-gray-100); }
.modal__backdrop { position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: var(--z-modal-backdrop); display: none; align-items: center; justify-content: center; }
.modal__backdrop.is-open { display: flex; }
.modal__content { background: var(--color-white); border-radius: var(--radius-xl); box-shadow: var(--shadow-xl); width: 100%; max-width: 480px; max-height: 90vh; overflow-y: auto; }
.modal__content--sm { max-width: 360px; }
.notification-preview__body { max-height: 300px; overflow-y: auto; }
.notification-preview__item { display: flex; gap: var(--space-2); padding: var(--space-2) var(--space-4); border-bottom: 1px solid var(--color-gray-50); font-size: var(--font-size-sm); }
.notification-preview__title { font-size: var(--font-size-sm); font-weight: 600; }
.oauth-connection__icon { font-size: 1.25rem; }
.oauth-connection__info { flex: 1; }
.pagination__item { }
.pagination__link--active { background: var(--color-primary); border-color: var(--color-primary); color: var(--color-white); }
.pagination__link--disabled { opacity: 0.4; pointer-events: none; }
.pagination__link--next { }
.pagination__link--prev { }
.pagination__list { display: flex; align-items: center; gap: var(--space-1); }
.pricing-card__amount { font-size: var(--font-size-4xl); font-weight: 800; }
.pricing-card__feature--no { opacity: 0.4; text-decoration: line-through; }
.pricing-toggle__save { font-size: var(--font-size-xs); color: var(--color-success); font-weight: 600; }
.profile-avatar__actions { display: flex; gap: var(--space-2); margin-top: var(--space-2); }
.provider-card__avatar-link { display: block; }
.provider-card__bio { font-size: var(--font-size-sm); color: var(--color-gray-500); margin-top: var(--space-2); line-height: 1.5; }
.provider-card__header { display: flex; align-items: center; gap: var(--space-4); margin-bottom: var(--space-3); }
.provider-card__location { font-size: var(--font-size-sm); color: var(--color-gray-500); display: flex; align-items: center; gap: var(--space-1); }
.provider-card__since { font-size: var(--font-size-xs); color: var(--color-gray-400); }
.provider-card__stat { text-align: center; }
.provider-card__stat-label { font-size: var(--font-size-xs); color: var(--color-gray-400); }
.provider-card__stat-value { font-size: var(--font-size-lg); font-weight: 700; }
.provider-card__stats { display: flex; gap: var(--space-4); margin-top: var(--space-4); padding-top: var(--space-3); border-top: 1px solid var(--color-gray-100); }
.radius-slider__control { }
.radius-slider__hint { font-size: var(--font-size-xs); color: var(--color-gray-400); margin-top: var(--space-1); }
.review-list--admin { }
.role-select__card { padding: var(--space-4); cursor: pointer; }
.role-selector__card { padding: var(--space-4); cursor: pointer; }
.search-results__map { height: 400px; border-radius: var(--radius-lg); overflow: hidden; margin-bottom: var(--space-4); }
.search-results__view-toggle { display: flex; gap: var(--space-1); }
.search-sidebar__header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-4); }
.search-sidebar__reset { font-size: var(--font-size-xs); color: var(--color-primary); }
.search-sidebar__title { font-size: var(--font-size-base); font-weight: 600; }
.section--alt { background: var(--color-gray-50); }
.section--full-height { min-height: 60vh; display: flex; align-items: center; }
.section__action { margin-top: var(--space-6); text-align: center; }
.service-form__map { height: 300px; border-radius: var(--radius-lg); overflow: hidden; margin-bottom: var(--space-4); }

/* Geocode address suggest dropdown (dashboard) */
.geocode-suggest { position: absolute; top: 100%; left: 0; right: 0; z-index: 1000; background: #fff; border: 1px solid var(--color-border); border-top: none; border-radius: 0 0 var(--radius-md) var(--radius-md); box-shadow: var(--shadow-lg); max-height: 280px; overflow-y: auto; display: none; }
.geocode-suggest__item { padding: 10px 14px; cursor: pointer; border-bottom: 1px solid var(--color-border-light, #f1f5f9); transition: background 0.15s; }
.geocode-suggest__item:last-child { border-bottom: none; }
.geocode-suggest__item:hover { background: var(--color-bg-subtle, #f8fafc); }
.geocode-suggest__main { font-weight: 600; font-size: 0.9rem; color: var(--color-text); }
.geocode-suggest__sub { font-size: 0.8rem; color: var(--color-text-muted); margin-top: 2px; }
.geocode-suggest__empty { padding: 12px 14px; color: var(--color-text-muted); font-size: 0.85rem; text-align: center; }
.service-grid--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 1024px) { .service-grid--4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 768px) { .service-grid--4 { grid-template-columns: 1fr; } }
.settings-section--danger { border: 1px solid #fecaca; background: var(--color-danger-bg); padding: var(--space-5); border-radius: var(--radius-lg); }
.star-rating--interactive .star-rating__star { cursor: pointer; transition: color var(--transition), transform var(--transition); }
.star-rating--interactive .star-rating__star:hover { transform: scale(1.2); }
.table__link { color: var(--color-primary); font-weight: 500; }
.table__meta { font-size: var(--font-size-xs); color: var(--color-gray-400); }
.table__rating { display: flex; align-items: center; gap: var(--space-1); }
.table__service { display: flex; align-items: center; gap: var(--space-2); }
.table__thumb { width: 40px; height: 30px; border-radius: var(--radius-sm); object-fit: cover; }
.tabs__item { padding: var(--space-3) var(--space-4); font-size: var(--font-size-sm); font-weight: 500; color: var(--color-gray-500); border-bottom: 2px solid transparent; margin-bottom: -2px; white-space: nowrap; text-decoration: none; transition: all var(--transition); }
.tabs__item:hover { color: var(--color-gray-700); text-decoration: none; }
.tabs__item.is-active { color: var(--color-primary); border-bottom-color: var(--color-primary); }

/* ========================================
   Responsive utilities
   ======================================== */
@media (max-width: 767px) {
    .d-none-mobile { display: none !important; }
}
@media (min-width: 768px) {
    .d-none-desktop { display: none !important; }
}

/* ========================================
   Mobile service cards (dashboard)
   ======================================== */
.svc-cards { display: flex; flex-direction: column; gap: var(--space-3); }
.svc-card {
    background: var(--color-white);
    border: 1px solid var(--color-gray-100);
    border-radius: var(--radius-lg);
    padding: var(--space-4);
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.svc-card__top {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    margin-bottom: var(--space-3);
}
.svc-card__img {
    width: 48px;
    height: 48px;
    border-radius: var(--radius-md);
    object-fit: cover;
    flex-shrink: 0;
}
.svc-card__info { flex: 1; min-width: 0; }
.svc-card__title {
    display: block;
    font-weight: 600;
    font-size: var(--font-size-base);
    color: var(--color-gray-900);
    text-decoration: none;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.svc-card__title:hover { color: var(--color-primary); }
.svc-card__cat {
    display: block;
    font-size: var(--font-size-xs);
    color: var(--color-gray-400);
    margin-top: 2px;
}
.svc-card__meta {
    display: flex;
    gap: var(--space-4);
    padding: var(--space-3) 0;
    border-top: 1px solid var(--color-gray-100);
    border-bottom: 1px solid var(--color-gray-100);
    font-size: var(--font-size-sm);
    color: var(--color-gray-600);
}
.svc-card__meta span { display: flex; align-items: center; gap: 4px; }
.svc-card__meta svg { color: var(--color-primary); }
.svc-card__actions {
    display: flex;
    gap: var(--space-2);
    margin-top: var(--space-3);
}
.svc-card__actions .btn { flex: 1; justify-content: center; }

/* Dashboard section header with title + action button */
.section__header--flex {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--space-3);
    margin-bottom: var(--space-6);
    text-align: left;
}
@media (max-width: 479px) {
    .section__header--flex {
        flex-direction: column;
        align-items: stretch;
    }
    .section__header--flex .btn { text-align: center; justify-content: center; }
}
/* ================================================================
   Geocode suggest – doplňkové stavy
   ================================================================ */
.geocode-suggest__item--focused { background: var(--color-bg-subtle, #f8fafc); }
.geocode-wrap { position: relative; }

/* ================================================================
   Calendar link box (ve formuláři editace služby)
   ================================================================ */
.calendar-link-box {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    padding: var(--space-4) var(--space-5);
    background: var(--color-bg-subtle, #f8fafc);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
}
.calendar-link-box__text {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    color: var(--color-text);
}
.calendar-link-box__text svg { flex-shrink: 0; margin-top: 2px; color: var(--color-primary); }
.calendar-link-box__text strong { display: block; font-size: 0.9rem; }
.calendar-link-box__text p { margin: 2px 0 0; font-size: 0.82rem; color: var(--color-text-muted); }
@media (max-width: 479px) {
    .calendar-link-box { flex-direction: column; align-items: stretch; }
    .calendar-link-box .btn { width: 100%; justify-content: center; }
}

/* Form hint info variant */
.form__hint--info {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    color: var(--color-text-muted);
    font-size: 0.82rem;
}
.form__hint--info svg { flex-shrink: 0; color: var(--color-primary); }

/* ================================================================
   Mobile: service form location row
   Pole "Země" a "Dojezdová vzdálenost" vedle sebe, adresa pod nimi
   ================================================================ */
@media (max-width: 639px) {
    .form__row .form__group--half { flex: 1 1 calc(50% - var(--space-2)); min-width: 0; }
    .form__row { flex-wrap: wrap; }
}

/* ================================================================
   Location row: na mobilu Země + Vzdálenost vedle sebe, Adresa pod nimi
   Pořadí v HTML: quarter(země) | half(adresa) | quarter(vzdálenost)
   Na mobilu chceme: [země][vzdálenost] / [  adresa full-width  ]
   ================================================================ */
@media (max-width: 639px) {
    .form__row--location {
        flex-wrap: wrap;
    }
    /* Země (1. child = quarter) → vlevo, půl šířky */
    .form__row--location > .form__group:nth-child(1) {
        order: 1;
        flex: 0 0 calc(50% - var(--space-2));
        min-width: 0;
    }
    /* Adresa (2. child = half) → celá šířka, na druhém řádku */
    .form__row--location > .form__group:nth-child(2) {
        order: 3;
        flex: 0 0 100%;
    }
    /* Dojezdová vzdálenost (3. child = quarter) → vpravo, půl šířky */
    .form__row--location > .form__group:nth-child(3) {
        order: 2;
        flex: 0 0 calc(50% - var(--space-2));
        min-width: 0;
    }
}

/* ================================================================
   Service availability box (formulář editace služby)
   ================================================================ */
.svc-availability-box {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    padding: var(--space-4) var(--space-5);
    background: var(--color-bg-subtle, #f8fafc);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
}
.svc-availability-box__info {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
}
.svc-availability-box__info svg { flex-shrink: 0; margin-top: 2px; color: var(--color-primary); }
.svc-availability-box__info strong { display: block; font-size: 0.9rem; color: var(--color-text); }
.svc-availability-box__info p { margin: 2px 0 0; font-size: 0.82rem; color: var(--color-text-muted); }
@media (max-width: 479px) {
    .svc-availability-box { flex-direction: column; align-items: stretch; }
    .svc-availability-box .btn { width: 100%; justify-content: center; text-align: center; }
}

/* ================================================================
   Image list (editace služby - fotky s popiskem)
   ================================================================ */
.image-list { display: flex; flex-direction: column; gap: var(--space-3); margin-bottom: var(--space-4); }
.image-list__item {
    display: flex;
    gap: var(--space-3);
    align-items: flex-start;
    padding: var(--space-3);
    background: var(--color-bg-subtle, #f8fafc);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
}
.image-list__preview {
    position: relative;
    flex-shrink: 0;
    width: 90px;
    height: 90px;
    border-radius: var(--radius);
    overflow: hidden;
}
.image-list__preview img { width: 100%; height: 100%; object-fit: cover; }
.image-list__meta { flex: 1; display: flex; align-items: center; gap: var(--space-2); }
.image-list__meta .input--sm { font-size: 0.85rem; padding: 6px 10px; }
.image-alt-status { font-size: 1rem; flex-shrink: 0; width: 20px; text-align: center; }
.image-alt-status--ok { color: var(--color-success, #16a34a); }
.image-alt-status--err { color: var(--color-danger, #dc2626); }
@media (max-width: 479px) {
    .image-list__item { flex-direction: column; }
    .image-list__preview { width: 100%; height: 160px; }
}

/* ================================================================
   Dashboard draft services list
   ================================================================ */
.dashboard-card--draft { border-left: 3px solid var(--color-warning, #f59e0b); }
.draft-list { list-style: none; padding: 0; margin: 0; }
.draft-list__item {
    display: flex; align-items: center; justify-content: space-between;
    gap: var(--space-3); padding: var(--space-3) 0;
    border-bottom: 1px solid var(--color-gray-100);
}
.draft-list__item:last-child { border-bottom: none; }
.draft-list__name { font-size: var(--font-size-sm); color: var(--color-gray-700); flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }