:root {
    /* Палитра */
    --color-bg: #fff;
    --color-fg: #0b0b0b;
    --color-muted: #666;
    --color-primary: #8c41c5;
    --color-danger: #bb003b;
    --color-border: #5d2a83;
    --color-link: #8d44d2;
    --color-item: #eeeeee;
    --highlight: #8c41c510;
    /* Типографика и размеры */
    --font-body: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    --space-1: 4px;
    --space-2: 8px;
    --space-3: 16px;
    --space-4: 24px;
    --space-5: 40px;
    /* Скругления и тени */
    --radius: 12px;
    --shadow: 0 1px 2px rgba(0, 0, 0, .08), 0 8px 24px rgba(0, 0, 0, .08);
}

/* Тёмная тема: переопределяем только значения токенов */
body.theme-dark {
    --color-bg: #2c2c2c;
    --color-fg: #f5f5f5;
    --color-muted: #aaa;
    --color-primary: #652894;
    --color-link: #af65e8;
    --color-item: #3c3c3c;
    --color-border: #ac61e5;
    --highlight: #ffffff10;
}


* {
    box-sizing: border-box;
}

html,
body {
    min-height: 100vh;
    margin: 0;
    padding: 0;
}

body {
    font-family: var(--font-body);
    background: var(--color-bg);
    color: var(--color-fg);
    line-height: 1.5;
    display: flex;
    flex-direction: column;
}
.bg-item{
    background-color: var(--color-item);
    --bs-table-bg: var(--color-item);
    --bs-bg-color: var(--color-item);
}
.bg-primary-color{
    background-color: var(--color-primary);
    --bs-table-bg: var(--color-primary);
    --bs-bg-color: var(--color-primary);
    --bs-btn-hover-bg: color-mix(in srgb, var(--color-primary) 70%, var(--color-bg));
}
.bg-purple {
    background-color: var(--color-border);
}
.text-type {
    color: var(--color-fg);
    --bs-color: var(--color-fg);
    --bs-table-color: var(--color-fg);
}
.text-purple {
    color: var(--color-border);
    --bs-color: var(--color-border);
    --bs-table-color: var(--color-border);
}
.text-muted-color{
    color: var(--color-muted);
    --bs-color: var(--color-muted);
    --bs-table-color: var(--color-muted);
}
.highlight-text {
    color: var(--color-border);
    font-style: italic;
    font-weight: bold;
}
.outline-purple{
    color: var(--color-fg);
    --bs-btn-color: var(--color-fg);
    --bs-btn-bg: transparent;
    --bs-btn-border-color: var(--color-border);
    border-width: 2px;
}
.outline-purple:hover {
    border-color: var(--color-primary);
    border-width: 3px;
}

main{
    max-width: 1200px;
    width: 90%;
    padding-inline: var(--space-5);
    flex: 1;
}

footer {
    padding: var(--space-1);
    background-color: var(--color-item);
}

img,
video {
    height: auto;
    display: block;
    max-width: 100%;
    margin: 0 auto;
    border-radius: var(--radius);
}

dialog {
    line-height: 1;
    color: var(--color-fg);
    background-color: var(--color-bg);
    border-radius: var(--space-3);
    border: 0.2rem solid var(--color-border);

    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
    animation: slideIn 0.3s ease;
    max-height: 90vh;
}

.dialog-title {
    margin: 0;
}

label {
    display: block;
    margin: 0.5rem 0 0.25rem;
    color: var(--color-fg);
}

input,
select,
textarea,
button {
    color: var(--color-fg);
    width: 100%;
    padding: .5rem .75rem;
    border: 1px solid var(--color-muted);
    border-radius: var(--radius);
    background: var(--color-bg);
    margin: .2rem;
}

button,
[type="submit"] {
    background: var(--color-primary);
    color: #fff;
    border: 0.02rem solid var(--color-border);
    cursor: pointer;
}

a {
    color: var(--color-link);
}

.table.custom-table {
    --bs-table-border-color: color-mix(in srgb, var(--color-border) 50%, transparent);
    --bs-table-hover-bg: var(--highlight);
    --bs-table-hover-color: inherit;
}

.custom-table th {
    --bs-table-bg: color-mix(in srgb, var(--color-primary) 50%, transparent);
    --bs-table-color: #fff;
}

.link-btn {
    --bs-btn-color: color-mix(in srgb, var(--color-border) 90%, transparent);
    --bs-btn-hover-color: var(--color-border);
    --bs-btn-bg: color-mix(in srgb, var(--color-primary) 20%, transparent);
    --bs-btn-hover-bg: color-mix(in srgb, var(--color-primary) 40%, transparent);
}

.theme-dark .card {
    --bs-card-bg: var(--color-item);
    --bs-card-cap-color: var(--color-fg);
    --bs-card-color: var(--color-fg);
}

.galery-btn {
    transform: translateY(-40px) !important;
}

button:hover {
    filter: brightness(0.95);
}

.breadcrumb-item, .breadcrumb-item::before {
    color: var(--color-muted) !important;
}

:disabled,
[aria-disabled="true"] {
    opacity: .6;
    cursor: not-allowed;
}

/* .card {
    --bs-color: var(--color-fg);
} */

:where(input, select, textarea, button):focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

[aria-invalid="true"] {
    border-color: var(--color-danger);
}

.my-header {
    padding-top: 1em;
    margin-bottom: 1em;
}

.header_logo img {
    margin: 0;
    filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.3));
    width: max(60px, 4vw);
    height: auto;
    object-fit: contain;
}

.theme-toggle {
    width: max(45px, 4vw);
    height: max(45px, 4vw);
    font-size: 0.9em;
}

.small-text {
    color: var(--color-muted);
    font-weight: bold;
}

.our-master {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-3);
}

.our-master_portrait img {
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid var(--color-primary);
    box-shadow: var(--shadow);
    width: min(200px, 30vw);
    height: min(200px, 30vw);
}

.funfact-card {
    background: var(--color-item);
    border-radius: var(--radius);
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.08);
    border-left: 4px solid var(--color-primary);
    transition: transform 0.3s ease;
}

.funfact-card:hover {
    transform: translateY(-5px);
}

.funfact-title {
    font-size: 20px;
    color: var(--color-border);
    margin: 0 0 10px 0;
    font-weight: 600;
}

.experience-desc {
    color: var(--color-muted);
    line-height: 1.6;
    margin: 0;
}

.funfacts_list {
    display: flex;
    gap: 2rem;
    list-style: none;
    padding: 0;
    margin: 0;
    flex-wrap: wrap;
}


.navigation .navbar-toggler {
    padding: 0;
    max-width: 2rem;
    height: 2rem;
    color: color-mix(in srgb, var(--color-fg) 40%, var(--color-bg) 50%);
}

.navigation .navbar-toggler:focus {
    outline: none;
    box-shadow: none;
}

.navigation .navbar-toggler:hover {
    border-radius: 50%;
    background-color: var(--highlight);
}

.nav-link.active {
    color: var(--color-fg) !important;
    padding-inline: 1rem;
    border-radius: var(--radius);
    background-color: var(--highlight);
}

.nav-link {
    color: color-mix(in srgb, var(--color-fg) 50%, var(--color-bg) 50%);
}

.nav-link:hover,
.navbar-toggler-icon:hover {
    color: color-mix(in srgb, var(--color-fg) 80%, var(--color-bg) 20%);
}

.questions .answer,
.btn {
    color: color-mix(in srgb, var(--color-fg) 70%, var(--color-bg) 30%);
    --bs-btn-hover-color: var(--color-fg);
    --bs-btn-active-color: var(--color-fg);
    --bs-btn-focus-color: var(--color-fg);
}

.questions .answer,
.btn:focus {
    color: var(--color-fg);
}

.product-card {
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    height: 100%;
}

.product-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
}

.price-tag {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--color-border);
}
.accordion-button.bg-transparent,
.accordion-button.bg-transparent.collapsed {
    background-color: transparent !important;
    border: none !important;
}