/* --- ОСНОВНЫЕ ПЕРЕМЕННЫЕ --- */
:root {
    --bg-dark: #0a0a0c;
    --card-bg: #111116;
    --accent-purple: #9d4edd; 
    --accent-glow: rgba(157, 78, 221, 0.4);
    --text-main: #ffffff;
    --text-dim: #94a3b8;
}

/* --- СБРОС И БАЗА --- */
* { 
    box-sizing: border-box; 
    margin: 0; 
    padding: 0; 
}

a { 
    color: inherit; 
    text-decoration: none; 
}

body { 
    background-color: var(--bg-dark); 
    color: var(--text-main); 
    font-family: 'Inter', -apple-system, sans-serif; 
    line-height: 1.6; 
    overflow-x: hidden; 
}

/* --- АНИМАЦИЯ ПОЯВЛЕНИЯ (REVEAL) --- */
.reveal { 
    opacity: 0; 
    transform: translateY(30px); 
    transition: all 1s cubic-bezier(0.2, 1, 0.3, 1); 
}

.reveal.active { 
    opacity: 1 !important; 
    transform: translateY(0) !important; 
}

/* --- НАВИГАЦИЯ (ШАПКА) --- */
.navbar { 
    position: fixed; 
    top: 0; 
    width: 100%; 
    z-index: 1000; 
    background: rgba(10, 10, 12, 0.85); 
    backdrop-filter: blur(15px); 
    border-bottom: 1px solid rgba(255, 255, 255, 0.05); 
}

.navbar-content { 
    max-width: 1200px; 
    margin: 0 auto; 
    display: flex; 
    justify-content: space-between; 
    align-items: center; 
    padding: 18px 25px; 
}

.logo { 
    font-size: 1.6rem; 
    font-weight: 900; 
    color: #fff !important; 
}

.nav-links { 
    list-style: none; 
    display: flex; 
    align-items: center; 
    gap: 25px; 
}

.nav-links a { 
    color: var(--text-dim); 
    transition: 0.3s; 
    font-weight: 500; 
}

.nav-links a:hover { 
    color: var(--accent-purple); 
}

.btn-main-nav { 
    background: var(--accent-purple) !important; 
    color: #fff !important; 
    padding: 10px 22px; 
    border-radius: 10px; 
    font-weight: 700; 
    transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1); 
    border: 1px solid transparent;
}

.btn-main-nav:hover { 
    transform: translateY(-3px); 
    box-shadow: 0 5px 15px var(--accent-glow); 
    border-color: #fff; 
}

/* --- КОНТЕЙНЕРЫ --- */
.container { 
    max-width: 1000px; 
    margin: 0 auto; 
    padding: 160px 20px 80px; 
}

/* --- HERO СЕКЦИЯ (ГЛАВНАЯ) --- */
.hero { 
    text-align: center; 
    margin-bottom: 120px; 
}

.hero h1 { 
    font-size: clamp(2.5rem, 7vw, 4.5rem); 
    font-weight: 900; 
    margin-bottom: 25px; 
    color: #fff !important; 
    letter-spacing: -2px; 
    line-height: 1.1;
}

.hero-desc { 
    color: var(--text-dim) !important; 
    font-size: 1.1rem; 
    max-width: 650px; 
    margin: 0 auto 40px; 
    display: block; 
    opacity: 0;
    transform: translateY(20px);
    filter: blur(3px); /* Легкое размытие для киноэффекта */
    animation: fadeUp 1.5s ease-out forwards;
}
@keyframes fadeUp {
  to {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
  }
}
.badge { 
    display: inline-block; 
    padding: 6px 14px; 
    background: rgba(157, 78, 221, 0.1); 
    border: 1px solid var(--accent-purple); 
    color: var(--accent-purple); 
    border-radius: 100px; 
    font-size: 0.7rem; 
    font-weight: 800; 
    margin-bottom: 30px; 
    text-transform: uppercase; 
}

/* Кнопки в Hero */
.hero-btns { 
    display: flex; 
    justify-content: center; 
    gap: 15px; 
}

.btn-primary { 
    background: var(--accent-purple) !important; 
    color: #fff !important; 
    padding: 16px 32px; 
    border-radius: 12px; 
    font-weight: 700; 
    box-shadow: 0 8px 25px var(--accent-glow); 
    transition: 0.3s; 
}

.btn-secondary { 
    background: #16161d !important; 
    color: #fff !important; 
    padding: 16px 32px; 
    border-radius: 12px; 
    border: 1px solid #2a2a35; 
    transition: 0.3s; 
}

.btn-primary:hover, .btn-secondary:hover { 
    transform: translateY(-4px); 
}

/* --- ЭФФЕКТЫ МЕРЦАНИЯ (SHIMMER) --- */
@keyframes shimmer-anim { 
    to { background-position: 200% center; } 
}

/* Глубокий фиолетовый шиммер для 'цифровые' и 'со мной' */
.shimmer-purple {
    background: linear-gradient(90deg, #9d4edd, #5a189a, #9d4edd);
    background-size: 200% auto;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    animation: shimmer-anim 3s linear infinite;
    font-weight: 900;
}

/* Шиммер с белым для 'по-настоящему крупным' */
.shimmer {
    background: linear-gradient(90deg, #9d4edd, #fff, #9d4edd);
    background-size: 200% auto;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    animation: shimmer-anim 4s linear infinite;
    font-weight: 800;
}

/* --- КАРТОЧКИ (ВСЕ ВИДЫ) --- */
.card, .card-alt { 
    background: var(--card-bg) !important; 
    border: 1px solid #1e1e26 !important; 
    padding: 45px !important; 
    border-radius: 24px !important; 
    margin-bottom: 40px !important; 
    transition: 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275) !important; 
    display: block;
    width: 100%;
}

.card h2 { 
    color: var(--accent-purple) !important; 
    margin-bottom: 20px; 
    font-size: 1.8rem; 
    font-weight: 800; 
}

.card:hover, .card-alt:hover { 
    transform: translateY(-10px) !important; 
    border-color: var(--accent-purple) !important; 
    box-shadow: 0 15px 35px rgba(157, 78, 221, 0.15) !important; 
}

/* Карточка-ссылка на главной */
.project-link-card { 
    text-decoration: none; 
    cursor: pointer; 
    color: inherit; 
    padding: 45px !important; 
}

/* Карточки-строки (Контакты и Проекты) */
.card-alt { 
    display: flex !important; 
    align-items: center; 
    gap: 30px; 
}

.project-icon, .contact-icon { 
    width: 60px; 
    height: 60px; 
    background: rgba(157, 78, 221, 0.1); 
    border: 1px solid var(--accent-purple); 
    border-radius: 14px; 
    display: flex; 
    align-items: center; 
    justify-content: center; 
    color: var(--accent-purple); 
    font-size: 1.8rem; 
    flex-shrink: 0; 
}

.label { 
    font-size: 0.8rem; 
    color: var(--accent-purple); 
    font-weight: 800; 
    text-transform: uppercase; 
    letter-spacing: 2px; 
    margin-bottom: 6px; 
    display: block; 
}

.value { 
    font-size: 1.5rem; 
    font-weight: 900; 
    color: #fff !important; 
}

/* --- СПЕЦИАЛЬНЫЕ ЗАГОЛОВКИ (КОНТАКТЫ) --- */
.contact-header { 
    text-align: center; 
    margin-bottom: 60px; 
}

.page-title { 
    font-size: clamp(2.5rem, 6vw, 4rem); 
    font-weight: 900; 
    margin-bottom: 15px; 
    color: #fff; 
}

.page-subtitle { 
    color: var(--text-dim); 
    max-width: 650px; 
    margin: 0 auto; 
    font-size: 1.1rem; 
    line-height: 1.5; 
/*красивое появление*/
    opacity: 0;
    transform: translateY(20px);
    filter: blur(3px); /* Легкое размытие для киноэффекта */
    animation: fadeUp 1.5s ease-out forwards; 
}

/* --- КИНОМАТОГРАФИЧНЫЙ АНОНС (ПРОЕКТЫ) --- */
.coming-soon { 
    text-align: center; 
    margin-top: 120px; 
    padding-bottom: 40px;
}

.divider { 
    width: 80px; 
    height: 4px; 
    background: var(--accent-purple); 
    margin: 0 auto 35px; 
    border-radius: 10px; 
    box-shadow: 0 0 20px var(--accent-glow); 
}

.epic-text { 
    font-size: 2rem; 
    font-weight: 700; 
    color: #fff; 
    line-height: 1.4; 
}

.epic-text span { 
    color: var(--text-dim); 
    font-weight: 400; 
    font-size: 1.4rem; 
}

.epic-footer { 
    display: flex; 
    align-items: center; 
    justify-content: center; 
    gap: 20px; 
    margin-top: 40px; 
}

.line { 
    height: 1px; 
    width: 45px; 
    background: #222; 
}

.sub-epic { 
    color: var(--accent-purple); 
    font-size: 0.8rem; 
    text-transform: uppercase; 
    letter-spacing: 5px; 
    font-weight: 800; 
}

/* --- ФУТЕР --- */
footer { 
    width: 100%; 
    background: #08080a; 
    border-top: 1px solid #1a1a20; 
    padding: 60px 0; 
    margin-top: 100px; 
    text-align: center; 
}

.clock { 
    font-size: 1.1rem; 
    color: var(--accent-purple); 
    font-weight: 700; 
    margin-bottom: 12px; 
    font-family: 'Courier New', monospace; 
    text-shadow: 0 0 10px var(--accent-glow);
}

.copyright { 
    color: #444; 
    font-size: 0.85rem; 
    letter-spacing: 1px;
}

/* --- АДАПТИВНОСТЬ --- */
@media (max-width: 768px) { 
    .nav-links { display: none; } 
    .hero h1 { font-size: 3rem; }
    .card-alt { flex-direction: column; text-align: center; padding: 35px !important; }
    .epic-text { font-size: 1.5rem; }
    .epic-footer { flex-direction: column; gap: 12px; }
    .line { display: none; }
}
.body-404 {
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: radial-gradient(circle at center, #111116 0%, #0a0a0c 100%);
    overflow: hidden;
}

.container-404 {
    text-align: center;
    max-width: 600px;
    padding: 20px;
}

.error-visual {
    position: relative;
    margin-bottom: 20px;
}

.error-code {
    font-size: clamp(8rem, 15vw, 12rem);
    font-weight: 900;
    line-height: 1;
    color: var(--accent-purple);
    letter-spacing: -5px;
    position: relative;
    z-index: 2;
    filter: drop-shadow(0 0 20px var(--accent-glow));
}

.error-glow {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 150%;
    height: 150%;
    background: radial-gradient(circle, var(--accent-glow) 0%, transparent 70%);
    z-index: 1;
    opacity: 0.5;
}

.error-title {
    font-size: 2rem;
    font-weight: 800;
    margin-bottom: 15px;
    color: #fff;
}

.error-text {
    color: var(--text-dim);
    margin-bottom: 40px;
    font-size: 1.1rem;
}

/* Кнопка на 404 */
.body-404 .btn-primary {
    padding: 18px 40px;
    font-size: 1.1rem;
}