flatten easySite directory: remove extra easySite/easySite nesting
- Moved contents of main_dc/yalarba/easySite/easySite/ up to easySite/ - Updated docker-compose.yml build context path - Deleted empty nested easySite/ directory
This commit is contained in:
@@ -0,0 +1,201 @@
|
||||
/* assets/css/components.css */
|
||||
/* Кнопки */
|
||||
.btn {
|
||||
display: inline-flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
gap: var(--space-xs);
|
||||
padding: var(--space-sm) var(--space-lg);
|
||||
border: none;
|
||||
border-radius: var(--radius-md);
|
||||
font-weight: 500;
|
||||
text-decoration: none;
|
||||
cursor: pointer;
|
||||
transition: all 0.2s;
|
||||
font-size: 0.875rem;
|
||||
line-height: 1.25rem;
|
||||
}
|
||||
|
||||
.btn-primary {
|
||||
background: var(--primary-500);
|
||||
color: var(--text-inverse);
|
||||
}
|
||||
|
||||
.btn-primary:hover {
|
||||
background: var(--primary-600);
|
||||
transform: translateY(-1px);
|
||||
box-shadow: var(--shadow-md);
|
||||
}
|
||||
|
||||
.btn-secondary {
|
||||
background: var(--secondary-500);
|
||||
color: var(--text-inverse);
|
||||
}
|
||||
|
||||
.btn-secondary:hover {
|
||||
background: var(--secondary-600);
|
||||
}
|
||||
|
||||
.btn-outline {
|
||||
background: transparent;
|
||||
border: 1px solid var(--border-medium);
|
||||
color: var(--text-secondary);
|
||||
}
|
||||
|
||||
.btn-outline:hover {
|
||||
background: var(--gray-50);
|
||||
border-color: var(--primary-500);
|
||||
color: var(--primary-600);
|
||||
}
|
||||
|
||||
/* Карточки */
|
||||
.card {
|
||||
background: var(--bg-primary);
|
||||
border-radius: var(--radius-lg);
|
||||
box-shadow: var(--shadow-sm);
|
||||
border: 1px solid var(--border-light);
|
||||
overflow: hidden;
|
||||
transition: all 0.3s;
|
||||
}
|
||||
|
||||
.card:hover {
|
||||
box-shadow: var(--shadow-md);
|
||||
transform: translateY(-2px);
|
||||
}
|
||||
|
||||
.card-header {
|
||||
padding: var(--space-lg);
|
||||
border-bottom: 1px solid var(--border-light);
|
||||
}
|
||||
|
||||
.card-body {
|
||||
padding: var(--space-lg);
|
||||
}
|
||||
|
||||
.card-footer {
|
||||
padding: var(--space-lg);
|
||||
border-top: 1px solid var(--border-light);
|
||||
background: var(--bg-secondary);
|
||||
}
|
||||
|
||||
/* Формы */
|
||||
.form-group {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
gap: var(--space-xs);
|
||||
margin-bottom: var(--space-md);
|
||||
}
|
||||
|
||||
.form-label {
|
||||
font-weight: 500;
|
||||
color: var(--text-secondary);
|
||||
font-size: 0.875rem;
|
||||
}
|
||||
|
||||
.form-input {
|
||||
padding: var(--space-sm) var(--space-md);
|
||||
border: 1px solid var(--border-medium);
|
||||
border-radius: var(--radius-md);
|
||||
font-size: 1rem;
|
||||
transition: all 0.2s;
|
||||
background: var(--bg-primary);
|
||||
}
|
||||
|
||||
.form-input:focus {
|
||||
outline: none;
|
||||
border-color: var(--primary-500);
|
||||
box-shadow: 0 0 0 3px rgb(14 165 233 / 0.1);
|
||||
}
|
||||
|
||||
.form-select {
|
||||
padding: var(--space-sm) var(--space-md);
|
||||
border: 1px solid var(--border-medium);
|
||||
border-radius: var(--radius-md);
|
||||
background: var(--bg-primary);
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
/* Бейджи и теги */
|
||||
.badge {
|
||||
display: inline-flex;
|
||||
align-items: center;
|
||||
padding: 0.25rem 0.5rem;
|
||||
border-radius: var(--radius-sm);
|
||||
font-size: 0.75rem;
|
||||
font-weight: 500;
|
||||
text-transform: uppercase;
|
||||
letter-spacing: 0.05em;
|
||||
}
|
||||
|
||||
.badge-primary {
|
||||
background: var(--primary-100);
|
||||
color: var(--primary-700);
|
||||
}
|
||||
|
||||
.badge-secondary {
|
||||
background: var(--secondary-100);
|
||||
color: var(--secondary-700);
|
||||
}
|
||||
|
||||
.badge-accent {
|
||||
background: var(--accent-100);
|
||||
color: var(--accent-700);
|
||||
}
|
||||
|
||||
.badge-success {
|
||||
background: var(--success-50);
|
||||
color: var(--success-600);
|
||||
}
|
||||
|
||||
/* Навигация */
|
||||
.nav-link {
|
||||
color: var(--text-secondary);
|
||||
text-decoration: none;
|
||||
padding: var(--space-sm) var(--space-md);
|
||||
border-radius: var(--radius-md);
|
||||
transition: all 0.2s;
|
||||
font-weight: 500;
|
||||
}
|
||||
|
||||
.nav-link:hover {
|
||||
color: var(--primary-600);
|
||||
background: var(--primary-50);
|
||||
}
|
||||
|
||||
.nav-link.active {
|
||||
color: var(--primary-600);
|
||||
background: var(--primary-50);
|
||||
}
|
||||
|
||||
/* Дополнения для темной темы */
|
||||
.form-input,
|
||||
.form-select {
|
||||
background: var(--bg-primary);
|
||||
border-color: var(--border-medium);
|
||||
color: var(--text-primary);
|
||||
transition: all 0.3s ease;
|
||||
}
|
||||
|
||||
.form-input:focus,
|
||||
.form-select:focus {
|
||||
border-color: var(--primary-500);
|
||||
box-shadow: 0 0 0 3px rgb(14 165 233 / 0.1);
|
||||
}
|
||||
|
||||
.card {
|
||||
background: var(--bg-primary);
|
||||
border-color: var(--border-light);
|
||||
transition: all 0.3s ease;
|
||||
}
|
||||
|
||||
.btn-outline {
|
||||
background: transparent;
|
||||
border: 1px solid var(--border-medium);
|
||||
color: var(--text-secondary);
|
||||
}
|
||||
|
||||
.btn-outline:hover {
|
||||
background: var(--bg-secondary);
|
||||
border-color: var(--primary-500);
|
||||
color: var(--primary-500);
|
||||
}
|
||||
@@ -0,0 +1,236 @@
|
||||
/* assets/css/fonts.css */
|
||||
|
||||
/* ===== НАБОР 1: СОВРЕМЕННЫЙ И ПРОФЕССИОНАЛЬНЫЙ ===== */
|
||||
|
||||
/* Inter - основной текст */
|
||||
@font-face {
|
||||
font-family: "Inter";
|
||||
src: url("/fonts/Inter-Regular.woff2") format("woff2");
|
||||
font-weight: 300;
|
||||
font-style: normal;
|
||||
font-display: swap;
|
||||
}
|
||||
|
||||
@font-face {
|
||||
font-family: "Inter";
|
||||
src: url("/fonts/Inter-Regular.woff2") format("woff2");
|
||||
font-weight: 400;
|
||||
font-style: normal;
|
||||
font-display: swap;
|
||||
}
|
||||
|
||||
@font-face {
|
||||
font-family: "Inter";
|
||||
src: url("/fonts/Inter-Regular.woff2") format("woff2");
|
||||
font-weight: 500;
|
||||
font-style: normal;
|
||||
font-display: swap;
|
||||
}
|
||||
|
||||
@font-face {
|
||||
font-family: "Inter";
|
||||
src: url("/fonts/Inter-Regular.woff2") format("woff2");
|
||||
font-weight: 600;
|
||||
font-style: normal;
|
||||
font-display: swap;
|
||||
}
|
||||
|
||||
@font-face {
|
||||
font-family: "Inter";
|
||||
src: url("/fonts/Inter-Regular.woff2") format("woff2");
|
||||
font-weight: 700;
|
||||
font-style: normal;
|
||||
font-display: swap;
|
||||
}
|
||||
|
||||
/* Playfair Display - заголовки */
|
||||
@font-face {
|
||||
font-family: "Playfair Display";
|
||||
src: url("/fonts/PlayfairDisplay-Regular.woff2") format("woff2");
|
||||
font-weight: 400;
|
||||
font-style: normal;
|
||||
font-display: swap;
|
||||
}
|
||||
|
||||
@font-face {
|
||||
font-family: "Playfair Display";
|
||||
src: url("/fonts/PlayfairDisplay-Regular.woff2") format("woff2");
|
||||
font-weight: 500;
|
||||
font-style: normal;
|
||||
font-display: swap;
|
||||
}
|
||||
|
||||
@font-face {
|
||||
font-family: "Playfair Display";
|
||||
src: url("/fonts/PlayfairDisplay-Regular.woff2") format("woff2");
|
||||
font-weight: 600;
|
||||
font-style: normal;
|
||||
font-display: swap;
|
||||
}
|
||||
|
||||
@font-face {
|
||||
font-family: "Playfair Display";
|
||||
src: url("/fonts/PlayfairDisplay-Regular.woff2") format("woff2");
|
||||
font-weight: 700;
|
||||
font-style: normal;
|
||||
font-display: swap;
|
||||
}
|
||||
|
||||
/* JetBrains Mono - моноширинный (для кода, деталей) */
|
||||
@font-face {
|
||||
font-family: "JetBrains Mono";
|
||||
src: url("/fonts/JetBrainsMono-Regular.woff2") format("woff2");
|
||||
font-weight: 400;
|
||||
font-style: normal;
|
||||
font-display: swap;
|
||||
}
|
||||
|
||||
:root {
|
||||
/* Шрифтовые семейства - Набор 1 */
|
||||
--font-primary: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
|
||||
sans-serif;
|
||||
--font-heading: "Playfair Display", "Times New Roman", serif;
|
||||
--font-accent: "JetBrains Mono", "Courier New", monospace;
|
||||
|
||||
/* Размеры шрифтов */
|
||||
--text-xs: 0.75rem; /* 12px */
|
||||
--text-sm: 0.875rem; /* 14px */
|
||||
--text-base: 1rem; /* 16px */
|
||||
--text-lg: 1.125rem; /* 18px */
|
||||
--text-xl: 1.25rem; /* 20px */
|
||||
--text-2xl: 1.5rem; /* 24px */
|
||||
--text-3xl: 1.875rem; /* 30px */
|
||||
--text-4xl: 2.25rem; /* 36px */
|
||||
--text-5xl: 3rem; /* 48px */
|
||||
--text-6xl: 3.75rem; /* 60px */
|
||||
|
||||
/* Высота строк */
|
||||
--leading-tight: 1.25;
|
||||
--leading-normal: 1.5;
|
||||
--leading-relaxed: 1.75;
|
||||
--leading-loose: 2;
|
||||
|
||||
/* Межбуквенные интервалы */
|
||||
--tracking-tight: -0.025em;
|
||||
--tracking-normal: 0;
|
||||
--tracking-wide: 0.025em;
|
||||
--tracking-wider: 0.05em;
|
||||
|
||||
/* Насыщенность шрифтов */
|
||||
--font-light: 300;
|
||||
--font-normal: 400;
|
||||
--font-medium: 500;
|
||||
--font-semibold: 600;
|
||||
--font-bold: 700;
|
||||
--font-extrabold: 800;
|
||||
}
|
||||
|
||||
/* ===== НАБОР 2: ЭЛЕГАНТНЫЙ И МИНИМАЛИСТИЧНЫЙ ===== */
|
||||
|
||||
/* Manrope - основной текст */
|
||||
@font-face {
|
||||
font-family: "Manrope";
|
||||
src: url("/fonts/Manrope-ExtraLight.woff2") format("woff2");
|
||||
font-weight: 300;
|
||||
font-style: normal;
|
||||
font-display: swap;
|
||||
}
|
||||
|
||||
@font-face {
|
||||
font-family: "Manrope";
|
||||
src: url("/fonts/Manrope-ExtraLight.woff2") format("woff2");
|
||||
font-weight: 400;
|
||||
font-style: normal;
|
||||
font-display: swap;
|
||||
}
|
||||
|
||||
@font-face {
|
||||
font-family: "Manrope";
|
||||
src: url("/fonts/Manrope-ExtraLight.woff2") format("woff2");
|
||||
font-weight: 500;
|
||||
font-style: normal;
|
||||
font-display: swap;
|
||||
}
|
||||
|
||||
@font-face {
|
||||
font-family: "Manrope";
|
||||
src: url("/fonts/Manrope-ExtraLight.woff2") format("woff2");
|
||||
font-weight: 600;
|
||||
font-style: normal;
|
||||
font-display: swap;
|
||||
}
|
||||
|
||||
@font-face {
|
||||
font-family: "Manrope";
|
||||
src: url("/fonts/Manrope-ExtraLight.woff2") format("woff2");
|
||||
font-weight: 700;
|
||||
font-style: normal;
|
||||
font-display: swap;
|
||||
}
|
||||
|
||||
/* Lora - заголовки */
|
||||
@font-face {
|
||||
font-family: "Lora";
|
||||
src: url("/fonts/Lora-Regular.woff2") format("woff2");
|
||||
font-weight: 400;
|
||||
font-style: normal;
|
||||
font-display: swap;
|
||||
}
|
||||
|
||||
@font-face {
|
||||
font-family: "Lora";
|
||||
src: url("/fonts/Lora-Regular.woff2") format("woff2");
|
||||
font-weight: 500;
|
||||
font-style: normal;
|
||||
font-display: swap;
|
||||
}
|
||||
|
||||
@font-face {
|
||||
font-family: "Lora";
|
||||
src: url("/fonts/Lora-Regular.woff2") format("woff2");
|
||||
font-weight: 600;
|
||||
font-style: normal;
|
||||
font-display: swap;
|
||||
}
|
||||
|
||||
@font-face {
|
||||
font-family: "Lora";
|
||||
src: url("/fonts/Lora-Regular.woff2") format("woff2");
|
||||
font-weight: 700;
|
||||
font-style: normal;
|
||||
font-display: swap;
|
||||
}
|
||||
|
||||
/* Source Sans Pro - акцентный */
|
||||
@font-face {
|
||||
font-family: "Source Sans Pro";
|
||||
src: url("/fonts/SourceSansPro-Regular.woff2") format("woff2");
|
||||
font-weight: 300;
|
||||
font-style: normal;
|
||||
font-display: swap;
|
||||
}
|
||||
|
||||
@font-face {
|
||||
font-family: "Source Sans Pro";
|
||||
src: url("/fonts/SourceSansPro-Regular.woff2") format("woff2");
|
||||
font-weight: 400;
|
||||
font-style: normal;
|
||||
font-display: swap;
|
||||
}
|
||||
|
||||
@font-face {
|
||||
font-family: "Source Sans Pro";
|
||||
src: url("/fonts/SourceSansPro-Regular.woff2") format("woff2");
|
||||
font-weight: 600;
|
||||
font-style: normal;
|
||||
font-display: swap;
|
||||
}
|
||||
|
||||
/* Альтернативные переменные для Набора 2 */
|
||||
:root[data-font-set="elegant"] {
|
||||
/* Шрифтовые семейства - Набор 2 */
|
||||
--font-primary: "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI",
|
||||
Roboto, sans-serif;
|
||||
--font-heading: "Lora", "Times New Roman", serif;
|
||||
--font-accent: "Source Sans Pro", "Arial", sans-serif;
|
||||
}
|
||||
@@ -0,0 +1,66 @@
|
||||
/* assets/css/main.css */
|
||||
:root {
|
||||
--primary: #2563eb;
|
||||
--primary-dark: #1d4ed8;
|
||||
--gray-50: #f9fafb;
|
||||
--gray-100: #f3f4f6;
|
||||
--gray-600: #4b5563;
|
||||
--gray-800: #1f2937;
|
||||
--gray-900: #111827;
|
||||
--white: #ffffff;
|
||||
transition: color 0.3s ease, background-color 0.3s ease,
|
||||
border-color 0.3s ease;
|
||||
}
|
||||
|
||||
* {
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
box-sizing: border-box;
|
||||
transition: color 0.3s ease, background-color 0.3s ease,
|
||||
border-color 0.3s ease;
|
||||
}
|
||||
|
||||
body {
|
||||
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
|
||||
line-height: 1.6;
|
||||
color: var(--text-primary);
|
||||
background: var(--bg-primary);
|
||||
transition: color 0.3s ease, background-color 0.3s ease;
|
||||
}
|
||||
|
||||
/* Обновляем остальные стили для поддержки темы */
|
||||
.container {
|
||||
max-width: 1200px;
|
||||
margin: 0 auto;
|
||||
padding: 0 1rem;
|
||||
}
|
||||
|
||||
.btn {
|
||||
display: inline-block;
|
||||
padding: 0.75rem 1.5rem;
|
||||
border: none;
|
||||
border-radius: 0.5rem;
|
||||
text-decoration: none;
|
||||
font-weight: 500;
|
||||
cursor: pointer;
|
||||
transition: all 0.3s ease;
|
||||
}
|
||||
|
||||
.btn-primary {
|
||||
background: var(--primary-500);
|
||||
color: var(--text-inverse);
|
||||
}
|
||||
|
||||
.btn-primary:hover {
|
||||
background: var(--primary-600);
|
||||
transform: translateY(-1px);
|
||||
}
|
||||
|
||||
.card {
|
||||
background: var(--bg-primary);
|
||||
border-radius: 0.5rem;
|
||||
box-shadow: var(--shadow-sm);
|
||||
padding: 1.5rem;
|
||||
border: 1px solid var(--border-light);
|
||||
transition: all 0.3s ease;
|
||||
}
|
||||
@@ -0,0 +1,110 @@
|
||||
/* assets/css/travel-typography.css */
|
||||
/* Герой-секция */
|
||||
.hero-title {
|
||||
font-family: var(--font-heading);
|
||||
font-size: clamp(2.5rem, 5vw, 4rem);
|
||||
font-weight: var(--font-bold);
|
||||
line-height: 1.1;
|
||||
letter-spacing: var(--tracking-tight);
|
||||
margin-bottom: var(--space-lg);
|
||||
}
|
||||
|
||||
.hero-subtitle {
|
||||
font-family: var(--font-accent);
|
||||
font-size: clamp(1.125rem, 2vw, 1.5rem);
|
||||
font-weight: var(--font-light);
|
||||
line-height: var(--leading-relaxed);
|
||||
opacity: 0.9;
|
||||
margin-bottom: var(--space-xl);
|
||||
}
|
||||
|
||||
/* Карточки туров */
|
||||
.tour-title {
|
||||
font-family: var(--font-primary);
|
||||
font-size: var(--text-lg);
|
||||
font-weight: var(--font-semibold);
|
||||
line-height: var(--leading-tight);
|
||||
color: var(--text-primary);
|
||||
margin-bottom: var(--space-xs);
|
||||
}
|
||||
|
||||
.tour-location {
|
||||
font-family: var(--font-primary);
|
||||
font-size: var(--text-sm);
|
||||
font-weight: var(--font-normal);
|
||||
color: var(--text-tertiary);
|
||||
margin-bottom: var(--space-sm);
|
||||
}
|
||||
|
||||
.tour-description {
|
||||
font-family: var(--font-primary);
|
||||
font-size: var(--text-sm);
|
||||
font-weight: var(--font-normal);
|
||||
line-height: var(--leading-relaxed);
|
||||
color: var(--text-secondary);
|
||||
margin-bottom: var(--space-md);
|
||||
}
|
||||
|
||||
/* Навигация и фильтры */
|
||||
.nav-brand {
|
||||
font-family: var(--font-heading);
|
||||
font-size: var(--text-xl);
|
||||
font-weight: var(--font-bold);
|
||||
color: var(--primary-600);
|
||||
}
|
||||
|
||||
.filter-title {
|
||||
font-family: var(--font-primary);
|
||||
font-size: var(--text-sm);
|
||||
font-weight: var(--font-semibold);
|
||||
text-transform: uppercase;
|
||||
letter-spacing: var(--tracking-wide);
|
||||
color: var(--text-secondary);
|
||||
margin-bottom: var(--space-sm);
|
||||
}
|
||||
|
||||
/* Отзывы и рейтинги */
|
||||
.review-text {
|
||||
font-family: var(--font-accent);
|
||||
font-size: var(--text-base);
|
||||
font-weight: var(--font-normal);
|
||||
line-height: var(--leading-relaxed);
|
||||
color: var(--text-secondary);
|
||||
font-style: italic;
|
||||
}
|
||||
|
||||
.review-author {
|
||||
font-family: var(--font-primary);
|
||||
font-size: var(--text-sm);
|
||||
font-weight: var(--font-semibold);
|
||||
color: var(--text-primary);
|
||||
}
|
||||
|
||||
/* Кнопки с иконками */
|
||||
.btn-with-icon {
|
||||
display: inline-flex;
|
||||
align-items: center;
|
||||
gap: var(--space-xs);
|
||||
font-family: var(--font-primary);
|
||||
font-weight: var(--font-medium);
|
||||
}
|
||||
|
||||
/* Адаптивная типографика */
|
||||
@media (max-width: 768px) {
|
||||
:root {
|
||||
--text-5xl: 2.5rem;
|
||||
--text-4xl: 2rem;
|
||||
--text-3xl: 1.75rem;
|
||||
--text-2xl: 1.5rem;
|
||||
--text-xl: 1.25rem;
|
||||
--text-lg: 1.125rem;
|
||||
}
|
||||
|
||||
.hero-title {
|
||||
font-size: 2.5rem;
|
||||
}
|
||||
|
||||
.hero-subtitle {
|
||||
font-size: 1.25rem;
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,140 @@
|
||||
/* assets/css/travel.css */
|
||||
/* Герой-секция с фоном */
|
||||
.hero-section {
|
||||
background: linear-gradient(
|
||||
135deg,
|
||||
var(--primary-500) 0%,
|
||||
var(--primary-700) 100%
|
||||
);
|
||||
color: var(--text-inverse);
|
||||
position: relative;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
.hero-section::before {
|
||||
content: "";
|
||||
position: absolute;
|
||||
top: 0;
|
||||
left: 0;
|
||||
right: 0;
|
||||
bottom: 0;
|
||||
background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1000 1000"><polygon fill="%230ea5e9" points="0,1000 1000,0 1000,1000"/></svg>');
|
||||
opacity: 0.1;
|
||||
pointer-events: none;
|
||||
}
|
||||
|
||||
/* Карточки туров */
|
||||
.tour-card {
|
||||
position: relative;
|
||||
border-radius: var(--radius-xl);
|
||||
overflow: hidden;
|
||||
background: var(--bg-primary);
|
||||
}
|
||||
|
||||
.tour-card__image {
|
||||
width: 100%;
|
||||
height: 200px;
|
||||
object-fit: cover;
|
||||
}
|
||||
|
||||
.tour-card__badge {
|
||||
position: absolute;
|
||||
top: var(--space-md);
|
||||
right: var(--space-md);
|
||||
}
|
||||
|
||||
.tour-card__price {
|
||||
color: var(--primary-600);
|
||||
font-weight: 600;
|
||||
font-size: 1.25rem;
|
||||
}
|
||||
|
||||
.tour-card__discount {
|
||||
color: var(--error-500);
|
||||
text-decoration: line-through;
|
||||
font-size: 0.875rem;
|
||||
}
|
||||
|
||||
/* Категории услуг */
|
||||
.category-card {
|
||||
background: var(--bg-primary);
|
||||
border: 1px solid var(--border-light);
|
||||
border-radius: var(--radius-lg);
|
||||
padding: var(--space-xl);
|
||||
text-align: center;
|
||||
transition: all 0.3s;
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
.category-card:hover {
|
||||
border-color: var(--primary-300);
|
||||
transform: translateY(-4px);
|
||||
box-shadow: var(--shadow-lg);
|
||||
}
|
||||
|
||||
.category-card__icon {
|
||||
width: 48px;
|
||||
height: 48px;
|
||||
margin: 0 auto var(--space-md);
|
||||
background: var(--primary-100);
|
||||
border-radius: var(--radius-lg);
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
color: var(--primary-600);
|
||||
}
|
||||
|
||||
/* Фильтры поиска */
|
||||
.search-filters {
|
||||
background: var(--bg-secondary);
|
||||
border-radius: var(--radius-lg);
|
||||
padding: var(--space-lg);
|
||||
border: 1px solid var(--border-light);
|
||||
}
|
||||
|
||||
.filter-group {
|
||||
margin-bottom: var(--space-lg);
|
||||
}
|
||||
|
||||
.filter-label {
|
||||
display: block;
|
||||
margin-bottom: var(--space-sm);
|
||||
font-weight: 500;
|
||||
color: var(--text-secondary);
|
||||
}
|
||||
|
||||
/* Рейтинги */
|
||||
.rating-stars {
|
||||
display: flex;
|
||||
gap: 2px;
|
||||
}
|
||||
|
||||
.rating-star {
|
||||
color: var(--secondary-400);
|
||||
}
|
||||
|
||||
.rating-star.empty {
|
||||
color: var(--gray-300);
|
||||
}
|
||||
|
||||
.rating-value {
|
||||
font-weight: 600;
|
||||
color: var(--text-primary);
|
||||
margin-left: var(--space-xs);
|
||||
}
|
||||
|
||||
/* Дополнения для темной темы */
|
||||
.search-filters {
|
||||
background: var(--bg-secondary);
|
||||
border-color: var(--border-light);
|
||||
}
|
||||
|
||||
.category-card {
|
||||
background: var(--bg-primary);
|
||||
border-color: var(--border-light);
|
||||
}
|
||||
|
||||
.category-card:hover {
|
||||
border-color: var(--primary-300);
|
||||
background: var(--bg-secondary);
|
||||
}
|
||||
@@ -0,0 +1,254 @@
|
||||
/* assets/css/typography.css */
|
||||
/* Базовые настройки типографики */
|
||||
body {
|
||||
font-family: var(--font-primary);
|
||||
font-size: var(--text-base);
|
||||
line-height: var(--leading-normal);
|
||||
font-weight: var(--font-normal);
|
||||
color: var(--text-primary);
|
||||
-webkit-font-smoothing: antialiased;
|
||||
-moz-osx-font-smoothing: grayscale;
|
||||
}
|
||||
|
||||
/* Заголовки */
|
||||
h1,
|
||||
.h1 {
|
||||
font-family: var(--font-heading);
|
||||
font-size: var(--text-5xl);
|
||||
font-weight: var(--font-bold);
|
||||
line-height: var(--leading-tight);
|
||||
letter-spacing: var(--tracking-tight);
|
||||
color: var(--text-primary);
|
||||
margin-bottom: var(--space-lg);
|
||||
}
|
||||
|
||||
h2,
|
||||
.h2 {
|
||||
font-family: var(--font-heading);
|
||||
font-size: var(--text-4xl);
|
||||
font-weight: var(--font-semibold);
|
||||
line-height: var(--leading-tight);
|
||||
letter-spacing: var(--tracking-tight);
|
||||
color: var(--text-primary);
|
||||
margin-bottom: var(--space-md);
|
||||
}
|
||||
|
||||
h3,
|
||||
.h3 {
|
||||
font-family: var(--font-heading);
|
||||
font-size: var(--text-3xl);
|
||||
font-weight: var(--font-semibold);
|
||||
line-height: var(--leading-tight);
|
||||
color: var(--text-primary);
|
||||
margin-bottom: var(--space-md);
|
||||
}
|
||||
|
||||
h4,
|
||||
.h4 {
|
||||
font-family: var(--font-primary);
|
||||
font-size: var(--text-2xl);
|
||||
font-weight: var(--font-semibold);
|
||||
line-height: var(--leading-tight);
|
||||
color: var(--text-primary);
|
||||
margin-bottom: var(--space-sm);
|
||||
}
|
||||
|
||||
h5,
|
||||
.h5 {
|
||||
font-family: var(--font-primary);
|
||||
font-size: var(--text-xl);
|
||||
font-weight: var(--font-semibold);
|
||||
line-height: var(--leading-normal);
|
||||
color: var(--text-primary);
|
||||
margin-bottom: var(--space-sm);
|
||||
}
|
||||
|
||||
h6,
|
||||
.h6 {
|
||||
font-family: var(--font-primary);
|
||||
font-size: var(--text-lg);
|
||||
font-weight: var(--font-semibold);
|
||||
line-height: var(--leading-normal);
|
||||
color: var(--text-primary);
|
||||
margin-bottom: var(--space-sm);
|
||||
}
|
||||
|
||||
/* Текстовые элементы */
|
||||
p {
|
||||
margin-bottom: var(--space-md);
|
||||
line-height: var(--leading-relaxed);
|
||||
color: var(--text-secondary);
|
||||
}
|
||||
|
||||
.lead {
|
||||
font-size: var(--text-xl);
|
||||
font-weight: var(--font-light);
|
||||
line-height: var(--leading-relaxed);
|
||||
color: var(--text-secondary);
|
||||
}
|
||||
|
||||
.small {
|
||||
font-size: var(--text-sm);
|
||||
color: var(--text-tertiary);
|
||||
}
|
||||
|
||||
/* Ссылки */
|
||||
a {
|
||||
color: var(--primary-600);
|
||||
text-decoration: none;
|
||||
transition: color 0.2s;
|
||||
}
|
||||
|
||||
a:hover {
|
||||
color: var(--primary-700);
|
||||
text-decoration: underline;
|
||||
}
|
||||
|
||||
/* Списки */
|
||||
ul,
|
||||
ol {
|
||||
margin-bottom: var(--space-md);
|
||||
padding-left: var(--space-lg);
|
||||
}
|
||||
|
||||
li {
|
||||
margin-bottom: var(--space-xs);
|
||||
line-height: var(--leading-relaxed);
|
||||
color: var(--text-secondary);
|
||||
}
|
||||
|
||||
/* Специальные текстовые классы */
|
||||
.text-hero {
|
||||
font-family: var(--font-heading);
|
||||
font-size: var(--text-6xl);
|
||||
font-weight: var(--font-bold);
|
||||
line-height: var(--leading-tight);
|
||||
letter-spacing: var(--tracking-tight);
|
||||
}
|
||||
|
||||
.text-subtitle {
|
||||
font-family: var(--font-accent);
|
||||
font-size: var(--text-xl);
|
||||
font-weight: var(--font-light);
|
||||
line-height: var(--leading-relaxed);
|
||||
color: var(--text-secondary);
|
||||
}
|
||||
|
||||
.text-caption {
|
||||
font-family: var(--font-primary);
|
||||
font-size: var(--text-sm);
|
||||
font-weight: var(--font-normal);
|
||||
color: var(--text-tertiary);
|
||||
text-transform: uppercase;
|
||||
letter-spacing: var(--tracking-wide);
|
||||
}
|
||||
|
||||
.text-price {
|
||||
font-family: var(--font-primary);
|
||||
font-size: var(--text-2xl);
|
||||
font-weight: var(--font-bold);
|
||||
color: var(--primary-600);
|
||||
}
|
||||
|
||||
.text-price-old {
|
||||
font-family: var(--font-primary);
|
||||
font-size: var(--text-lg);
|
||||
font-weight: var(--font-normal);
|
||||
color: var(--text-tertiary);
|
||||
text-decoration: line-through;
|
||||
}
|
||||
|
||||
/* Классы для выравнивания */
|
||||
.text-center {
|
||||
text-align: center;
|
||||
}
|
||||
.text-left {
|
||||
text-align: left;
|
||||
}
|
||||
.text-right {
|
||||
text-align: right;
|
||||
}
|
||||
|
||||
/* Классы для насыщенности */
|
||||
.font-light {
|
||||
font-weight: var(--font-light);
|
||||
}
|
||||
.font-normal {
|
||||
font-weight: var(--font-normal);
|
||||
}
|
||||
.font-medium {
|
||||
font-weight: var(--font-medium);
|
||||
}
|
||||
.font-semibold {
|
||||
font-weight: var(--font-semibold);
|
||||
}
|
||||
.font-bold {
|
||||
font-weight: var(--font-bold);
|
||||
}
|
||||
|
||||
/* Классы для цвета текста */
|
||||
.text-primary {
|
||||
color: var(--text-primary);
|
||||
}
|
||||
.text-secondary {
|
||||
color: var(--text-secondary);
|
||||
}
|
||||
.text-tertiary {
|
||||
color: var(--text-tertiary);
|
||||
}
|
||||
.text-inverse {
|
||||
color: var(--text-inverse);
|
||||
}
|
||||
.text-accent {
|
||||
color: var(--accent-600);
|
||||
}
|
||||
.text-warning {
|
||||
color: var(--warning-600);
|
||||
}
|
||||
.text-error {
|
||||
color: var(--error-600);
|
||||
}
|
||||
.text-success {
|
||||
color: var(--success-600);
|
||||
}
|
||||
|
||||
/* Дополнения для темной темы */
|
||||
body {
|
||||
color: var(--text-primary);
|
||||
background: var(--bg-primary);
|
||||
}
|
||||
|
||||
h1,
|
||||
.h1,
|
||||
h2,
|
||||
.h2,
|
||||
h3,
|
||||
.h3,
|
||||
h4,
|
||||
.h4,
|
||||
h5,
|
||||
.h5,
|
||||
h6,
|
||||
.h6 {
|
||||
color: var(--text-primary);
|
||||
}
|
||||
|
||||
p {
|
||||
color: var(--text-secondary);
|
||||
}
|
||||
|
||||
.lead {
|
||||
color: var(--text-secondary);
|
||||
}
|
||||
|
||||
.small {
|
||||
color: var(--text-tertiary);
|
||||
}
|
||||
|
||||
a {
|
||||
color: var(--primary-500);
|
||||
}
|
||||
|
||||
a:hover {
|
||||
color: var(--primary-400);
|
||||
}
|
||||
@@ -0,0 +1,207 @@
|
||||
/* assets/css/variables.css */
|
||||
:root {
|
||||
/* Основные цвета - природа, путешествия */
|
||||
--primary-50: #f0f9ff;
|
||||
--primary-100: #e0f2fe;
|
||||
--primary-200: #bae6fd;
|
||||
--primary-300: #7dd3fc;
|
||||
--primary-400: #38bdf8;
|
||||
--primary-500: #0ea5e9; /* Основной синий - небо/вода */
|
||||
--primary-600: #0284c7;
|
||||
--primary-700: #0369a1;
|
||||
--primary-800: #075985;
|
||||
--primary-900: #0c4a6e;
|
||||
|
||||
/* Вторичные цвета - природа/земля */
|
||||
--secondary-50: #fefce8;
|
||||
--secondary-100: #fef9c3;
|
||||
--secondary-200: #fef08a;
|
||||
--secondary-300: #fde047;
|
||||
--secondary-400: #facc15; /* Золотой - солнце/песок */
|
||||
--secondary-500: #eab308;
|
||||
--secondary-600: #ca8a04;
|
||||
--secondary-700: #a16207;
|
||||
--secondary-800: #854d0e;
|
||||
--secondary-900: #713f12;
|
||||
|
||||
/* Акцентные цвета - зелень/природа */
|
||||
--accent-50: #f0fdf4;
|
||||
--accent-100: #dcfce7;
|
||||
--accent-200: #bbf7d0;
|
||||
--accent-300: #86efac;
|
||||
--accent-400: #4ade80; /* Зеленый - природа/растения */
|
||||
--accent-500: #22c55e;
|
||||
--accent-600: #16a34a;
|
||||
--accent-700: #15803d;
|
||||
--accent-800: #166534;
|
||||
--accent-900: #14532d;
|
||||
|
||||
/* Нейтральные цвета */
|
||||
--gray-50: #f8fafc;
|
||||
--gray-100: #f1f5f9;
|
||||
--gray-200: #e2e8f0;
|
||||
--gray-300: #cbd5e1;
|
||||
--gray-400: #94a3b8;
|
||||
--gray-500: #64748b;
|
||||
--gray-600: #475569;
|
||||
--gray-700: #334155;
|
||||
--gray-800: #1e293b;
|
||||
--gray-900: #0f172a;
|
||||
|
||||
/* Семантические цвета */
|
||||
--success-50: #f0fdf4;
|
||||
--success-500: #22c55e;
|
||||
--success-600: #16a34a;
|
||||
|
||||
--warning-50: #fffbeb;
|
||||
--warning-500: #f59e0b;
|
||||
--warning-600: #d97706;
|
||||
|
||||
--error-50: #fef2f2;
|
||||
--error-500: #ef4444;
|
||||
--error-600: #dc2626;
|
||||
|
||||
--info-50: #eff6ff;
|
||||
--info-500: #3b82f6;
|
||||
--info-600: #2563eb;
|
||||
|
||||
/* Фоновые цвета */
|
||||
--bg-primary: #ffffff;
|
||||
--bg-secondary: #f8fafc;
|
||||
--bg-tertiary: #f1f5f9;
|
||||
|
||||
/* Текстовые цвета */
|
||||
--text-primary: #0f172a;
|
||||
--text-secondary: #475569;
|
||||
--text-tertiary: #64748b;
|
||||
--text-inverse: #ffffff;
|
||||
|
||||
/* Границы */
|
||||
--border-light: #e2e8f0;
|
||||
--border-medium: #cbd5e1;
|
||||
--border-dark: #94a3b8;
|
||||
|
||||
/* Тени */
|
||||
--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
|
||||
--shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
|
||||
--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1),
|
||||
0 4px 6px -4px rgb(0 0 0 / 0.1);
|
||||
|
||||
/* Радиусы */
|
||||
--radius-sm: 0.375rem;
|
||||
--radius-md: 0.5rem;
|
||||
--radius-lg: 0.75rem;
|
||||
--radius-xl: 1rem;
|
||||
|
||||
/* Отступы */
|
||||
--space-xs: 0.5rem;
|
||||
--space-sm: 0.75rem;
|
||||
--space-md: 1rem;
|
||||
--space-lg: 1.5rem;
|
||||
--space-xl: 2rem;
|
||||
--space-2xl: 3rem;
|
||||
|
||||
&[data-theme="dark"] {
|
||||
/* Основные цвета - темная тема */
|
||||
--primary-50: #0c4a6e;
|
||||
--primary-100: #075985;
|
||||
--primary-200: #0369a1;
|
||||
--primary-300: #0284c7;
|
||||
--primary-400: #0ea5e9;
|
||||
--primary-500: #38bdf8;
|
||||
--primary-600: #7dd3fc;
|
||||
--primary-700: #bae6fd;
|
||||
--primary-800: #e0f2fe;
|
||||
--primary-900: #f0f9ff;
|
||||
|
||||
/* Вторичные цвета - темная тема */
|
||||
--secondary-50: #713f12;
|
||||
--secondary-100: #854d0e;
|
||||
--secondary-200: #a16207;
|
||||
--secondary-300: #ca8a04;
|
||||
--secondary-400: #eab308;
|
||||
--secondary-500: #facc15;
|
||||
--secondary-600: #fde047;
|
||||
--secondary-700: #fef08a;
|
||||
--secondary-800: #fef9c3;
|
||||
--secondary-900: #fefce8;
|
||||
|
||||
/* Акцентные цвета - темная тема */
|
||||
--accent-50: #14532d;
|
||||
--accent-100: #166534;
|
||||
--accent-200: #15803d;
|
||||
--accent-300: #16a34a;
|
||||
--accent-400: #22c55e;
|
||||
--accent-500: #4ade80;
|
||||
--accent-600: #86efac;
|
||||
--accent-700: #bbf7d0;
|
||||
--accent-800: #dcfce7;
|
||||
--accent-900: #f0fdf4;
|
||||
|
||||
/* Нейтральные цвета - темная тема */
|
||||
--gray-50: #0f172a;
|
||||
--gray-100: #1e293b;
|
||||
--gray-200: #334155;
|
||||
--gray-300: #475569;
|
||||
--gray-400: #64748b;
|
||||
--gray-500: #94a3b8;
|
||||
--gray-600: #cbd5e1;
|
||||
--gray-700: #e2e8f0;
|
||||
--gray-800: #f1f5f9;
|
||||
--gray-900: #f8fafc;
|
||||
|
||||
/* Семантические цвета - темная тема */
|
||||
--success-50: #14532d;
|
||||
--success-500: #4ade80;
|
||||
--success-600: #86efac;
|
||||
|
||||
--warning-50: #713f12;
|
||||
--warning-500: #facc15;
|
||||
--warning-600: #fde047;
|
||||
|
||||
--error-50: #7f1d1d;
|
||||
--error-500: #f87171;
|
||||
--error-600: #fca5a5;
|
||||
|
||||
--info-50: #1e3a8a;
|
||||
--info-500: #60a5fa;
|
||||
--info-600: #93c5fd;
|
||||
|
||||
/* Фоновые цвета - темная тема */
|
||||
--bg-primary: #0f172a;
|
||||
--bg-secondary: #1e293b;
|
||||
--bg-tertiary: #334155;
|
||||
|
||||
/* Текстовые цвета - темная тема */
|
||||
--text-primary: #f8fafc;
|
||||
--text-secondary: #e2e8f0;
|
||||
--text-tertiary: #cbd5e1;
|
||||
--text-inverse: #0f172a;
|
||||
|
||||
/* Границы - темная тема */
|
||||
--border-light: #334155;
|
||||
--border-medium: #475569;
|
||||
--border-dark: #64748b;
|
||||
|
||||
/* Тени - темная тема */
|
||||
--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.4);
|
||||
--shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.3),
|
||||
0 2px 4px -2px rgb(0 0 0 / 0.3);
|
||||
--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.3),
|
||||
0 4px 6px -4px rgb(0 0 0 / 0.3);
|
||||
}
|
||||
|
||||
/* Градиенты для hero-секции */
|
||||
--hero-gradient: linear-gradient(
|
||||
135deg,
|
||||
var(--primary-500) 0%,
|
||||
var(--primary-700) 100%
|
||||
);
|
||||
--hero-pattern: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1000 1000"><polygon fill="%230ea5e9" points="0,1000 1000,0 1000,1000"/></svg>');
|
||||
|
||||
/* Темная тема */
|
||||
&[data-theme="dark"] {
|
||||
--hero-gradient: linear-gradient(135deg, #1e293b 0%, #0f172a 100%);
|
||||
--hero-pattern: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1000 1000"><polygon fill="%23374151" points="0,1000 1000,0 1000,1000"/></svg>');
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user