/* ==========================================================================
   Andrey Sayurov Resume Portfolio v2 Stylesheet
   Theme: Premium Business Minimalist Dark (CMO / Tech Executive)
   ========================================================================== */

/* Design Tokens & Variables */
:root {
    --font-heading: 'Outfit', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    
    /* Premium Slate & Dark Palette */
    --color-bg: #090a0f;
    --color-bg-secondary: #0e1017;
    --color-card-bg: rgba(20, 24, 35, 0.4);
    --color-border: rgba(255, 255, 255, 0.06);
    --color-border-hover: rgba(255, 255, 255, 0.12);
    
    /* Clean Professional Accent (Muted Teal/Cyan) */
    --color-cyan: #00c2ff;
    --color-cyan-rgb: 0, 194, 255;
    --color-success: #10b981;
    
    --color-text: #f3f4f6;
    --color-text-muted: #9ca3af;
    --color-text-dark: #6b7280;
    
    --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.3);
    --shadow-md: 0 10px 30px rgba(0, 0, 0, 0.5);
    --shadow-lg: 0 20px 40px rgba(0, 0, 0, 0.7);
    
    --transition-fast: 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    --transition-smooth: 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    
    --border-radius-sm: 6px;
    --border-radius-md: 12px;
    --border-radius-lg: 20px;
    
    --header-height: 72px;
}

/* Base Reset & Core Styles */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
    font-size: 16px;
}

body {
    background-color: var(--color-bg);
    color: var(--color-text);
    font-family: var(--font-body);
    line-height: 1.6;
    overflow-x: hidden;
    position: relative;
    -webkit-font-smoothing: antialiased;
}

/* Background gradient backdrop (no grids or floating spheres) */
body::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: radial-gradient(circle at 50% -20%, rgba(var(--color-cyan-rgb), 0.05) 0%, transparent 60%);
    z-index: -1;
    pointer-events: none;
}

/* Typography */
h1, h2, h3, h4 {
    font-family: var(--font-heading);
    font-weight: 700;
    line-height: 1.25;
    color: var(--color-text);
    letter-spacing: -0.01em;
}

a {
    color: inherit;
    text-decoration: none;
    transition: color var(--transition-fast);
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

.container {
    width: 100%;
    max-width: 1140px;
    margin: 0 auto;
    padding: 0 24px;
}

/* Header Navbar */
.navbar {
    height: var(--header-height);
    position: sticky;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--color-border);
    background-color: rgba(9, 10, 15, 0.8);
    transition: background-color var(--transition-fast), box-shadow var(--transition-fast);
}

.navbar__container {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.nav-logo {
    font-family: var(--font-heading);
    font-size: 1.2rem;
    font-weight: 800;
    letter-spacing: -0.02em;
    color: var(--color-text);
}

.nav-logo__cyan {
    color: var(--color-cyan);
}

.nav-menu {
    display: flex;
    gap: 28px;
}

.nav-menu__link {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--color-text-muted);
    letter-spacing: 0.02em;
    position: relative;
    padding: 6px 0;
}

.nav-menu__link:hover {
    color: var(--color-text);
}

.nav-menu__link::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: var(--color-cyan);
    transform: scaleX(0);
    transform-origin: right;
    transition: transform var(--transition-fast);
}

.nav-menu__link:hover::after {
    transform: scaleX(1);
    transform-origin: left;
}

.navbar__actions {
    display: flex;
    align-items: center;
    gap: 16px;
}

.lang-switch-wrap {
    display: flex;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    overflow: hidden;
    background-color: rgba(255, 255, 255, 0.02);
}

.lang-btn {
    padding: 4px 10px;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--color-text-dark);
}

.lang-btn.active {
    background-color: rgba(255, 255, 255, 0.05);
    color: var(--color-cyan);
}

.lang-btn:hover:not(.active) {
    color: var(--color-text-muted);
}

/* Burger Toggle */
.burger-btn {
    display: none;
    flex-direction: column;
    justify-content: space-between;
    width: 20px;
    height: 14px;
    background: transparent;
    border: none;
    cursor: pointer;
    z-index: 110;
}

.burger-bar {
    width: 100%;
    height: 2px;
    background-color: var(--color-text);
    transition: all var(--transition-fast);
}

.burger-btn.open .burger-bar:nth-child(1) {
    transform: translateY(6px) rotate(45deg);
}

.burger-btn.open .burger-bar:nth-child(2) {
    opacity: 0;
}

.burger-btn.open .burger-bar:nth-child(3) {
    transform: translateY(-6px) rotate(-45deg);
}

/* Mobile Nav Drawer */
.mobile-drawer {
    position: fixed;
    top: var(--header-height);
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(9, 10, 15, 0.98);
    backdrop-filter: blur(20px);
    z-index: 99;
    padding: 40px 24px;
    transform: translateY(-100%);
    opacity: 0;
    pointer-events: none;
    transition: all var(--transition-smooth);
    border-bottom: 1px solid var(--color-border);
}

.mobile-drawer.open {
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
}

.mobile-nav {
    display: flex;
    flex-direction: column;
    gap: 20px;
    align-items: center;
}

.mobile-nav__link {
    font-size: 1.1rem;
    font-weight: 500;
    color: var(--color-text-muted);
}

.mobile-nav__link:hover {
    color: var(--color-cyan);
}

.mobile-nav__actions {
    width: 100%;
    margin-top: 20px;
}

/* Buttons */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-body);
    font-weight: 500;
    font-size: 0.8rem;
    padding: 10px 20px;
    border-radius: var(--border-radius-sm);
    cursor: pointer;
    transition: all var(--transition-smooth);
    border: none;
    gap: 8px;
    outline: none;
    letter-spacing: 0.02em;
}

.btn--sm {
    padding: 8px 14px;
    font-size: 0.75rem;
}

.btn--full {
    width: 100%;
}

.btn--cyan {
    background-color: var(--color-cyan);
    color: #090a0f;
    font-weight: 600;
}

.btn--cyan:hover {
    background-color: #33d0ff;
    transform: translateY(-1px);
}

.btn--secondary {
    background-color: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--color-border);
    color: var(--color-text);
}

.btn--secondary:hover {
    background-color: rgba(255, 255, 255, 0.07);
    border-color: var(--color-border-hover);
    transform: translateY(-1px);
}

/* Hero Resume Section */
.hero-resume {
    padding: 60px 0 80px 0;
    border-bottom: 1px solid var(--color-border);
}

.hero-resume__container {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 48px;
    align-items: center;
}

.photo-wrapper {
    width: 100%;
    aspect-ratio: 1/1;
    border-radius: var(--border-radius-lg);
    overflow: hidden;
    border: 1px solid var(--color-border);
    background-color: var(--color-bg-secondary);
    box-shadow: var(--shadow-md);
}

.resume-photo {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.search-status-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background-color: rgba(16, 185, 129, 0.06);
    border: 1px solid rgba(16, 185, 129, 0.2);
    padding: 5px 12px;
    border-radius: 40px;
    margin-bottom: 18px;
}

.search-status-badge__dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background-color: var(--color-success);
    box-shadow: 0 0 8px var(--color-success);
    animation: blink 2s infinite;
}

.search-status-badge__text {
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: #34d399;
}

.resume-name {
    font-size: clamp(2rem, 4.5vw, 3rem);
    font-weight: 800;
    margin-bottom: 8px;
    line-height: 1.15;
}

.resume-role {
    font-size: clamp(1rem, 2vw, 1.25rem);
    font-weight: 500;
    color: var(--color-cyan);
    margin-bottom: 20px;
}

.resume-bio {
    font-size: 1rem;
    color: var(--color-text-muted);
    font-weight: 300;
    line-height: 1.65;
    margin-bottom: 24px;
}

.quick-contacts {
    display: flex;
    gap: 16px 24px;
    flex-wrap: wrap;
    margin-bottom: 24px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--color-border);
}

.contact-pill {
    font-size: 0.8rem;
    color: var(--color-text-muted);
    display: flex;
    align-items: center;
    gap: 8px;
}

.contact-pill i {
    color: var(--color-cyan);
    font-size: 0.85rem;
}

.contact-pill a:hover {
    color: var(--color-cyan);
}

.resume-downloads {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
}

.downloads-label {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--color-text-muted);
}

.downloads-buttons {
    display: flex;
    gap: 10px;
}

/* Sections Header */
.resume-section-header {
    text-align: center;
    max-width: 680px;
    margin: 0 auto 48px auto;
}

.resume-section-title {
    font-size: clamp(1.6rem, 3vw, 2.2rem);
    font-weight: 800;
    margin-bottom: 12px;
}

.resume-section-subtitle {
    font-size: 0.9rem;
    color: var(--color-text-muted);
    font-weight: 300;
}

/* Vertical Case Studies List */
.resume-cases {
    padding: 80px 0;
    border-bottom: 1px solid var(--color-border);
}

.cases-vertical-list {
    display: flex;
    flex-direction: column;
    gap: 40px;
}

.detailed-case-card {
    background-color: var(--color-bg-secondary);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius-lg);
    padding: 36px;
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.detailed-case-card:hover {
    border-color: var(--color-border-hover);
    box-shadow: var(--shadow-md);
}

.case-card-header {
    margin-bottom: 24px;
    border-bottom: 1px solid var(--color-border);
    padding-bottom: 16px;
}

.case-card-badge {
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--color-cyan);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    display: block;
    margin-bottom: 6px;
}

.case-card-title {
    font-size: 1.35rem;
    font-weight: 800;
}

.case-card-body-layout {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 36px;
    align-items: start;
}

.case-card-text-block p {
    font-size: 0.9rem;
    color: var(--color-text-muted);
    margin-bottom: 12px;
    font-weight: 300;
    line-height: 1.6;
}

.case-card-text-block p strong {
    color: var(--color-text);
    font-weight: 500;
}

.case-results-box {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin: 24px 0;
    background-color: rgba(255, 255, 255, 0.01);
    border: 1px solid var(--color-border);
    padding: 16px;
    border-radius: var(--border-radius-sm);
}

.result-metric {
    display: flex;
    flex-direction: column;
}

.result-metric__val {
    font-family: var(--font-heading);
    font-size: 1.4rem;
    font-weight: 800;
    color: var(--color-text);
    line-height: 1.2;
    margin-bottom: 4px;
}

.result-metric__label {
    font-size: 0.7rem;
    color: var(--color-text-muted);
    line-height: 1.3;
}

.case-card-stack {
    font-size: 0.8rem;
    color: var(--color-text-muted);
    border-top: 1px dashed var(--color-border);
    padding-top: 12px;
    margin-top: 16px;
}

.case-card-stack strong {
    color: var(--color-text);
    font-weight: 500;
}

.case-card-link-wrapper {
    margin-top: 20px;
}

.case-link-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--color-cyan);
    letter-spacing: 0.04em;
}

.case-link-btn:hover {
    color: #33d0ff;
}

.case-card-visual-block {
    position: relative;
    border-radius: var(--border-radius-md);
    overflow: hidden;
    border: 1px solid var(--color-border);
    background-color: var(--color-bg);
}

.case-visual-img {
    width: 100%;
    height: auto;
    display: block;
}

/* Before After Component */
.slider-container {
    width: 100%;
    aspect-ratio: 16/10;
    position: relative;
    overflow: hidden;
}

.slider-image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.slider-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: opacity 0.15s ease-in-out;
}

.before-image {
    width: 50%;
    z-index: 2;
    overflow: hidden;
}

.before-image img {
    width: var(--slider-width, 500px);
    max-width: none;
    height: 100%;
}

.after-image {
    z-index: 1;
}

.slider-handle {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 50%;
    width: 2px;
    background-color: white;
    z-index: 3;
    cursor: ew-resize;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.slider-handle__line {
    flex: 1;
    width: 2px;
    background-color: rgba(255, 255, 255, 0.4);
}

.slider-handle__button {
    width: 28px;
    height: 28px;
    background-color: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #090a0f;
    box-shadow: var(--shadow-sm);
    font-size: 0.75rem;
}

.slider-label {
    position: absolute;
    bottom: 10px;
    padding: 3px 8px;
    background-color: rgba(9, 10, 15, 0.9);
    border: 1px solid var(--color-border);
    border-radius: 4px;
    font-size: 0.65rem;
    font-weight: 700;
    z-index: 4;
}

.slider-label--before {
    left: 10px;
    color: var(--color-text-muted);
}

.slider-label--after {
    right: 10px;
    color: var(--color-cyan);
}

.render-thumbs-mini {
    display: flex;
    gap: 6px;
    padding: 10px;
    background-color: rgba(255, 255, 255, 0.02);
    border-top: 1px solid var(--color-border);
    justify-content: center;
}

.thumb-btn-mini {
    background: transparent;
    border: 1px solid var(--color-border);
    color: var(--color-text-dark);
    padding: 4px 10px;
    font-size: 0.7rem;
    border-radius: 4px;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.thumb-btn-mini:hover {
    color: var(--color-text-muted);
    border-color: var(--color-border-hover);
}

.thumb-btn-mini.active {
    border-color: var(--color-cyan);
    color: var(--color-cyan);
    background-color: rgba(0, 194, 255, 0.05);
}

/* Illustration block */
.bg-illustration {
    background-color: rgba(255, 255, 255, 0.01);
    padding: 24px;
    height: 100%;
    min-height: 200px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.stats-visual-mockup {
    width: 100%;
}

.stats-visual-row {
    display: flex;
    justify-content: space-between;
    font-size: 0.75rem;
    color: var(--color-text-muted);
    margin-bottom: 4px;
}

.stats-visual-row strong {
    font-size: 0.9rem;
    font-family: var(--font-heading);
    color: var(--color-text);
}

.stats-visual-progress {
    height: 4px;
    background-color: rgba(255, 255, 255, 0.04);
    border-radius: 6px;
    margin-bottom: 16px;
    overflow: hidden;
}

.progress-bar-fill {
    height: 100%;
    background-color: var(--color-text-dark);
    border-radius: 6px;
}

.visual-centered {
    background-color: rgba(255, 255, 255, 0.01);
    padding: 36px;
    height: 100%;
    min-height: 200px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.badge-round {
    width: 110px;
    height: 110px;
    border-radius: 50%;
    border: 1px dashed rgba(var(--color-cyan-rgb), 0.3);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background-color: rgba(var(--color-cyan-rgb), 0.02);
}

.badge-round__number {
    font-family: var(--font-heading);
    font-size: 1.8rem;
    font-weight: 800;
    color: var(--color-cyan);
    line-height: 1;
}

.badge-round__label {
    font-size: 0.7rem;
    color: var(--color-text-muted);
    text-align: center;
    line-height: 1.2;
    margin-top: 4px;
}

/* Professional Resume Timeline */
.resume-experience {
    padding: 80px 0;
    border-bottom: 1px solid var(--color-border);
}

.timeline {
    position: relative;
    max-width: 800px;
    margin: 0 auto;
}

.timeline-line {
    position: absolute;
    left: 16px;
    top: 8px;
    bottom: 8px;
    width: 1px;
    background-color: var(--color-border);
}

.timeline-item {
    position: relative;
    margin-bottom: 40px;
    padding-left: 48px;
}

.timeline-item:last-child {
    margin-bottom: 0;
}

.timeline-marker {
    position: absolute;
    left: 12px;
    top: 6px;
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background-color: var(--color-bg);
    border: 2px solid var(--color-cyan);
    z-index: 5;
    transition: transform var(--transition-fast);
}

.timeline-item:hover .timeline-marker {
    transform: scale(1.4);
    background-color: var(--color-cyan);
}

.timeline-content {
    background-color: var(--color-bg-secondary);
    border: 1px solid var(--color-border);
    padding: 24px;
    border-radius: var(--border-radius-md);
    transition: border-color var(--transition-fast);
}

.timeline-item:hover .timeline-content {
    border-color: var(--color-border-hover);
}

.job-header {
    margin-bottom: 16px;
    border-bottom: 1px solid var(--color-border);
    padding-bottom: 12px;
}

.job-date {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--color-cyan);
    letter-spacing: 0.04em;
    display: block;
    margin-bottom: 6px;
}

.job-company {
    font-size: 1.15rem;
    font-weight: 800;
    margin-bottom: 2px;
}

.job-title {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--color-text-muted);
}

.job-body p {
    font-size: 0.85rem;
    color: var(--color-text);
    margin-bottom: 12px;
}

.job-body ul {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.job-body ul li {
    font-size: 0.8rem;
    color: var(--color-text-muted);
    position: relative;
    padding-left: 16px;
}

.job-body ul li::before {
    content: '•';
    position: absolute;
    left: 0;
    top: 0;
    color: var(--color-cyan);
    font-size: 0.95rem;
}

.job-body ul li strong {
    color: var(--color-text);
    font-weight: 500;
}

/* Skills Grid */
.resume-skills {
    padding: 80px 0;
    border-bottom: 1px solid var(--color-border);
}

.skills-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 32px;
    max-width: 800px;
    margin: 0 auto 48px auto;
}

.skills-block {
    background-color: var(--color-bg-secondary);
    border: 1px solid var(--color-border);
    padding: 24px;
    border-radius: var(--border-radius-md);
}

.skills-block__title {
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: 16px;
    border-bottom: 1px solid var(--color-border);
    padding-bottom: 10px;
}

.skills-block__title i {
    color: var(--color-cyan);
    margin-right: 6px;
}

.skills-tags {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}

.skills-tags span {
    font-size: 0.75rem;
    background-color: rgba(255, 255, 255, 0.01);
    border: 1px solid var(--color-border);
    padding: 5px 12px;
    border-radius: 4px;
    color: var(--color-text-muted);
    transition: all var(--transition-fast);
}

.skills-tags span:hover {
    border-color: var(--color-cyan);
    color: var(--color-text);
    background-color: rgba(0, 194, 255, 0.02);
}

.education-block {
    max-width: 800px;
    margin: 0 auto;
}

.education-block__title {
    font-size: 1.1rem;
    font-weight: 700;
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.education-block__title i {
    color: var(--color-cyan);
}

.education-item {
    background-color: var(--color-bg-secondary);
    border: 1px solid var(--color-border);
    padding: 20px 24px;
    border-radius: var(--border-radius-md);
}

.education-item strong {
    font-size: 0.85rem;
    color: var(--color-text);
    display: block;
    margin-bottom: 4px;
}

.education-item p {
    font-size: 0.8rem;
    color: var(--color-text-muted);
}

/* Contact box CTA */
.resume-contact {
    padding: 80px 0;
}

.contact-box {
    background-color: var(--color-bg-secondary);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius-lg);
    padding: 48px 36px;
    text-align: center;
    max-width: 800px;
    margin: 0 auto;
}

.contact-box__title {
    font-size: 1.7rem;
    font-weight: 800;
    margin-bottom: 12px;
}

.contact-box__text {
    font-size: 0.95rem;
    color: var(--color-text-muted);
    font-weight: 300;
    max-width: 560px;
    margin: 0 auto 32px auto;
}

.contact-methods {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: 30px;
}

.contact-method-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background-color: rgba(255, 255, 255, 0.02);
    border: 1px solid var(--color-border);
    padding: 10px 20px;
    border-radius: var(--border-radius-sm);
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--color-text-muted);
    transition: all var(--transition-fast);
}

.contact-method-btn:hover {
    border-color: var(--color-cyan);
    color: var(--color-cyan);
    transform: translateY(-1px);
}

.contact-downloads {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
    border-top: 1px dashed var(--color-border);
    padding-top: 24px;
    font-size: 0.8rem;
    color: var(--color-text-muted);
}

.contact-downloads .download-link {
    color: var(--color-text);
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.contact-downloads .download-link:hover {
    color: var(--color-cyan);
}

/* Footer */
.footer-resume {
    background-color: var(--color-bg);
    border-top: 1px solid var(--color-border);
    padding: 30px 0;
}

.footer-resume__container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 16px;
}

.footer-resume__copy {
    font-size: 0.75rem;
    color: var(--color-text-dark);
}

.footer-resume__links {
    display: flex;
    gap: 16px;
}

.footer-resume__links a {
    font-size: 0.75rem;
    color: var(--color-text-muted);
}

.footer-resume__links a:hover {
    color: var(--color-cyan);
}

/* Animations */
@keyframes blink {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.4; }
}

/* Responsive Rules */
@media (max-width: 992px) {
    .case-card-body-layout {
        grid-template-columns: 1fr;
        gap: 28px;
    }
    
    .case-card-visual-block {
        max-width: 440px;
        margin: 0 auto;
        width: 100%;
    }
}

@media (max-width: 768px) {
    .nav-menu { display: none; }
    .burger-btn { display: flex; }
    
    .hero-resume__container {
        grid-template-columns: 1fr;
        text-align: center;
        gap: 24px;
    }
    
    .photo-wrapper {
        max-width: 160px;
        margin: 0 auto;
    }
    
    .quick-contacts {
        justify-content: center;
    }
    
    .resume-downloads {
        flex-direction: column;
        align-items: center;
    }
    
    .skills-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }
    
    .detailed-case-card {
        padding: 24px;
    }
}

@media (max-width: 576px) {
    .case-results-box {
        grid-template-columns: 1fr;
        gap: 12px;
    }
    
    .timeline-line {
        left: 8px;
    }
    
    .timeline-item {
        padding-left: 28px;
    }
    
    .timeline-marker {
        left: 4px;
    }
    
    .timeline-content {
        padding: 16px;
    }
    
    .contact-methods {
        flex-direction: column;
    }
    
    .contact-method-btn {
        width: 100%;
        justify-content: center;
    }
}

/* ==========================================================================
   Ported v1 funnel blocks — restyled for v2 dark theme (added 2026-06-04)
   ========================================================================== */

/* Manifesto */
.resume-manifesto { padding: 80px 0; border-bottom: 1px solid var(--color-border); }
.manifesto-box { max-width: 820px; margin: 0 auto; text-align: center; }
.manifesto-box__title { font-size: clamp(1.6rem, 3vw, 2.2rem); font-weight: 800; margin-bottom: 20px; }
.manifesto-box__text { font-size: 1rem; color: var(--color-text-muted); font-weight: 300; line-height: 1.7; margin-bottom: 40px; }
.manifesto-metrics { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.manifesto-metric { background-color: var(--color-bg-secondary); border: 1px solid var(--color-border); border-radius: var(--border-radius-md); padding: 24px 16px; }
.manifesto-metric__num { display: block; font-family: var(--font-heading); font-size: 2rem; font-weight: 800; color: var(--color-cyan); line-height: 1; margin-bottom: 8px; }
.manifesto-metric__label { font-size: 0.78rem; color: var(--color-text-muted); line-height: 1.35; }

/* Pains */
.resume-pains { padding: 80px 0; border-bottom: 1px solid var(--color-border); }
.pains-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; max-width: 900px; margin: 0 auto; }
.pain-card { background-color: var(--color-bg-secondary); border: 1px solid var(--color-border); border-radius: var(--border-radius-md); padding: 28px; transition: border-color var(--transition-fast); }
.pain-card:hover { border-color: var(--color-border-hover); }
.pain-card__icon { font-size: 1.6rem; margin-bottom: 14px; }
.pain-card__title { font-size: 1.05rem; font-weight: 700; margin-bottom: 10px; }
.pain-card__text { font-size: 0.85rem; color: var(--color-text-muted); font-weight: 300; line-height: 1.6; }

/* Path (static stepper) */
.resume-path { padding: 80px 0; border-bottom: 1px solid var(--color-border); }
.path-steps { max-width: 800px; margin: 0 auto; display: flex; flex-direction: column; gap: 16px; }
.path-step { display: flex; gap: 20px; background-color: var(--color-bg-secondary); border: 1px solid var(--color-border); border-radius: var(--border-radius-md); padding: 20px 24px; transition: border-color var(--transition-fast); }
.path-step:hover { border-color: var(--color-border-hover); }
.path-step__num { flex: 0 0 auto; width: 32px; height: 32px; border-radius: 50%; border: 2px solid var(--color-cyan); display: flex; align-items: center; justify-content: center; font-family: var(--font-heading); font-weight: 800; font-size: 0.9rem; color: var(--color-cyan); }
.path-step__body { flex: 1; min-width: 0; }
.path-step__title { font-size: 1rem; font-weight: 700; margin-bottom: 2px; }
.path-step__usual { font-size: 0.75rem; color: var(--color-text-dark); display: block; margin-bottom: 12px; }
.path-step__tags { display: flex; flex-wrap: wrap; gap: 6px; }
.path-step__tags span { font-size: 0.72rem; background-color: rgba(255, 255, 255, 0.01); border: 1px solid var(--color-border); padding: 4px 10px; border-radius: 4px; color: var(--color-text-muted); }

/* Examples grid */
.resume-examples { padding: 80px 0; border-bottom: 1px solid var(--color-border); }
.examples-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.example-card { background-color: var(--color-bg-secondary); border: 1px solid var(--color-border); border-radius: var(--border-radius-md); overflow: hidden; transition: border-color var(--transition-fast), transform var(--transition-fast); }
.example-card:hover { border-color: var(--color-border-hover); transform: translateY(-2px); }
.example-card__visual { aspect-ratio: 16 / 10; overflow: hidden; background-color: var(--color-bg); }
.example-card__visual img { width: 100%; height: 100%; object-fit: cover; }
.example-card__body { padding: 18px 20px; }
.example-card__tag { font-size: 0.65rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: var(--color-cyan); display: block; margin-bottom: 8px; }
.example-card__title { font-size: 0.98rem; font-weight: 700; margin-bottom: 6px; line-height: 1.3; }
.example-card__meta { font-size: 0.72rem; color: var(--color-text-dark); display: block; margin-bottom: 10px; }
.example-card__text { font-size: 0.82rem; color: var(--color-text-muted); font-weight: 300; line-height: 1.55; }

/* Segments / personas */
.resume-segments { padding: 80px 0; border-bottom: 1px solid var(--color-border); }
.segments-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; max-width: 900px; margin: 0 auto; }
.persona-card { background-color: var(--color-bg-secondary); border: 1px solid var(--color-border); border-radius: var(--border-radius-md); padding: 28px; transition: border-color var(--transition-fast); }
.persona-card:hover { border-color: var(--color-border-hover); }
.persona-card__avatar { font-size: 1.6rem; margin-bottom: 12px; }
.persona-card__title { font-size: 1.05rem; font-weight: 700; margin-bottom: 10px; }
.persona-card__pain { font-size: 0.82rem; color: var(--color-text-dark); margin-bottom: 8px; }
.persona-card__offer { font-size: 0.85rem; color: var(--color-text-muted); font-weight: 300; line-height: 1.6; }
.segments-note { text-align: center; font-size: 0.85rem; color: var(--color-text-muted); margin-top: 28px; }

/* FAQ accordion (native details) */
.resume-faq { padding: 80px 0; border-bottom: 1px solid var(--color-border); }
.faq-list { max-width: 760px; margin: 0 auto; display: flex; flex-direction: column; gap: 12px; }
.faq-item { background-color: var(--color-bg-secondary); border: 1px solid var(--color-border); border-radius: var(--border-radius-md); overflow: hidden; }
.faq-q { display: flex; justify-content: space-between; align-items: center; gap: 16px; padding: 18px 22px; cursor: pointer; font-family: var(--font-heading); font-weight: 600; font-size: 0.95rem; color: var(--color-text); list-style: none; }
.faq-q::-webkit-details-marker { display: none; }
.faq-q__icon { color: var(--color-cyan); font-size: 0.8rem; transition: transform var(--transition-fast); flex: 0 0 auto; }
.faq-item[open] .faq-q__icon { transform: rotate(45deg); }
.faq-a { padding: 0 22px 20px 22px; }
.faq-a p { font-size: 0.85rem; color: var(--color-text-muted); font-weight: 300; line-height: 1.65; }

/* Responsive for ported blocks */
@media (max-width: 992px) {
    .examples-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
    .pains-grid { grid-template-columns: 1fr; }
    .segments-grid { grid-template-columns: 1fr; }
}
@media (max-width: 576px) {
    .manifesto-metrics { grid-template-columns: 1fr; }
    .examples-grid { grid-template-columns: 1fr; }
}

/* Reach / viral proof band (2026-06-04) */
.resume-reach { padding: 56px 0; border-bottom: 1px solid var(--color-border); }
.reach-band { max-width: 960px; margin: 0 auto; }
.reach-band__lead { text-align: center; margin-bottom: 28px; }
.reach-band__tag { font-size: 0.7rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: var(--color-cyan); display: block; margin-bottom: 10px; }
.reach-band__title { font-size: clamp(1.3rem, 2.4vw, 1.8rem); font-weight: 800; max-width: 640px; margin: 0 auto; }
.reach-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.reach-stat { text-align: center; background-color: var(--color-bg-secondary); border: 1px solid var(--color-border); border-radius: var(--border-radius-md); padding: 24px 12px; }
.reach-stat__num { display: block; font-family: var(--font-heading); font-size: clamp(1.5rem, 3vw, 2.1rem); font-weight: 800; color: var(--color-text); line-height: 1; margin-bottom: 8px; }
.reach-stat--accent .reach-stat__num { color: var(--color-cyan); }
.reach-stat__label { font-size: 0.75rem; color: var(--color-text-muted); }
@media (max-width: 576px) { .reach-stats { grid-template-columns: repeat(2, 1fr); } }

/* Plan v3 additions (2026-06-04): hero CTA, 3-up numbers, 3-group skills */
.hero-cta { display: flex; gap: 12px; flex-wrap: wrap; }
.reach-stats--3 { grid-template-columns: repeat(3, 1fr); }
.reach-stats--3 .reach-stat__num { font-size: clamp(1.1rem, 2.2vw, 1.5rem); }
@media (max-width: 768px) { .reach-stats--3 { grid-template-columns: 1fr; } }
.skills-grid--3 { grid-template-columns: repeat(3, 1fr); max-width: 1040px; }
@media (max-width: 880px) { .skills-grid--3 { grid-template-columns: 1fr; } }

.navbar__actions { margin-left: auto; }

/* Video case placeholder (2026-06-04) */
.video-placeholder { display: flex; flex-direction: column; align-items: center; gap: 12px; color: var(--color-text-muted); }
.video-placeholder i { width: 56px; height: 56px; border-radius: 50%; border: 2px solid var(--color-cyan); display: flex; align-items: center; justify-content: center; color: var(--color-cyan); font-size: 1.1rem; padding-left: 3px; }
.video-placeholder span { font-size: 0.78rem; }


/* Pains icons adapted to v2 dark theme (2026-06-04) */
.pain-card__icon{ width:46px; height:46px; border-radius:12px; display:flex; align-items:center; justify-content:center; background:rgba(0,194,255,.08); color:var(--color-cyan); font-size:1.15rem; margin-bottom:16px; }


/* WebKit/Safari backdrop-filter sticky paint fix: navbar children (Обсудить проект / burger)
   didn't render until the first scroll. Promote them to their own compositing layer. */
.navbar{ -webkit-backface-visibility:hidden; backface-visibility:hidden; }
.navbar__container,
.nav-menu,
.navbar__actions,
.burger-btn{ -webkit-transform:translateZ(0); transform:translateZ(0); }


/* Nav CTA («Обсудить проект»): hidden on the first screen, fades in after one viewport */
.navbar__actions .btn--cyan{ opacity:0; visibility:hidden; pointer-events:none; transition:opacity .3s ease, visibility .3s ease; }
.navbar.nav--cta-on .btn--cyan{ opacity:1; visibility:visible; pointer-events:auto; }


/* mobile hero tweaks 2026-06-04: bigger photo, centered/larger/lower CTA buttons */
@media (max-width: 768px) {
    .hero-resume { padding-top: 32px; }
    .photo-wrapper { max-width: 192px; }              /* +20% from 160px */
    .hero-cta { flex-direction: column; align-items: center; gap: 18px; margin-top: 16px; }
    .hero-cta .btn { padding: 14px 30px; font-size: 0.95rem; }
}


/* Hero proof points with glowing cyan dots (2026-06-04) */
.hero-points{ list-style:none; display:flex; flex-direction:column; gap:12px; width:fit-content; margin:4px 0 26px; padding:0; }
.hero-points li{ display:flex; align-items:flex-start; gap:12px; font-size:0.92rem; color:var(--color-text-muted); line-height:1.4; }
.hero-points b{ color:var(--color-text); font-weight:600; }
.hero-points__dot{ flex:0 0 auto; width:9px; height:9px; margin-top:6px; border-radius:50%; background:var(--color-cyan); box-shadow:0 0 10px 1px rgba(0,194,255,0.85), 0 0 4px rgba(0,194,255,0.95); }
@media (max-width:768px){ .hero-points{ margin-left:auto; margin-right:auto; } }


/* Mobile: status badge in navbar top-left + lighter hero points (2026-06-04) */
.nav-status{ display:none; }
@media (max-width:768px){
  .navbar__actions .btn--cyan{ display:none; }   /* mobile: CTA lives in burger drawer; free the navbar */
  .nav-status{ display:inline-flex; align-items:center; gap:7px; min-width:0; max-width:calc(100vw - 92px);
    background:rgba(16,185,129,0.07); border:1px solid rgba(16,185,129,0.25); padding:5px 11px; border-radius:30px; }
  .nav-status__dot{ width:6px; height:6px; flex:0 0 auto; border-radius:50%; background:var(--color-success);
    box-shadow:0 0 8px var(--color-success); animation:blink 2s infinite; }
  .nav-status__text{ font-size:0.58rem; font-weight:700; letter-spacing:0.03em; color:#34d399;
    white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
  .search-status-badge{ display:none; }          /* hero badge moves to navbar on mobile */
  .hero-points{ gap:11px; }
  .hero-points li{ font-size:0.82rem; line-height:1.35; }
  .hero-points__dot{ width:8px; height:8px; margin-top:5px; }
}


/* hero-points links (plansay.ru) */
.hero-points a{ color:var(--color-cyan); text-decoration:none; border-bottom:1px solid rgba(0,194,255,0.45); transition:border-color .2s ease; }
.hero-points a:hover{ border-bottom-color:var(--color-cyan); }


/* hero-points mobile spacing: more room before first point and after last (2026-06-04) */
@media (max-width:768px){
  .hero-points{ margin-top:22px; margin-bottom:36px; }
}


/* Pains block on white (user request 2026-06-04) */
#pains{ background:#ffffff; }
#pains .resume-section-title{ color:#0f172a; }
#pains .pain-card{ background:#f8fafc; border-color:rgba(15,23,42,0.08); box-shadow:0 6px 20px rgba(15,23,42,0.06); }
#pains .pain-card:hover{ border-color:rgba(2,132,199,0.45); }
#pains .pain-card__title{ color:#0f172a; }
#pains .pain-card__text{ color:#475569; }
#pains .pain-card__icon{ background:rgba(2,132,199,0.10); color:#0284c7; }


/* desktop hero vertical air between rows (2026-06-04) */
@media (min-width:769px){
  .search-status-badge{ margin-bottom:24px; }
  .resume-name{ margin-bottom:12px; }
  .resume-role{ margin-bottom:28px; }
  .resume-bio{ margin-bottom:34px; line-height:1.7; }
  .hero-points{ gap:16px; margin-bottom:34px; }
  .hero-points li{ line-height:1.5; }
}


/* desktop: bigger overall font (v1-like) + hero sizing (2026-06-04) */
@media (min-width:769px){
  html{ font-size:18px; }
  .hero-resume{ min-height:calc(100vh - var(--header-height)); }
  .hero-resume__container{ grid-template-columns:290px 1fr; align-items:start; }
  .photo-wrapper{ margin-top:20px; }
  .resume-role{ font-size:clamp(1.25rem,2.2vw,1.45rem); margin-bottom:36px; }
  .resume-bio{ font-size:1.1rem; margin-bottom:60px; }
  .hero-points{ gap:12px; margin-bottom:80px; }
}
@media (max-width:768px){ .hero-br{ display:none; } }


/* v1-style subtle grid on dark background (2026-06-04) */
body{
  background-image:
    linear-gradient(rgba(255,255,255,0.015) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.015) 1px, transparent 1px);
  background-size: 40px 40px;
}


/* pain card before/after strip (2026-06-04, white pains theme) */
.pain-ba{ display:flex; flex-direction:column; align-items:flex-start; gap:4px; margin-top:16px; font-size:0.8rem; font-weight:600; }
.pain-ba__lbl{ color:#0f172a; }
.pain-ba__old{ color:#94a3b8; text-decoration:line-through; text-decoration-color:#cbd5e1; }
.pain-ba__new{ color:#0284c7; }


/* pain card: icon moved inline next to before/after (2026-06-04) */
.pain-foot{ display:flex; align-items:center; gap:14px; margin-top:16px; }
.pain-foot .pain-card__icon{ margin-bottom:0; }
.pain-foot .pain-ba{ margin-top:0; }


/* keep title->tags gap after removing 'Обычно:' line (2026-06-04) */
.path-step__title{ margin-bottom:34px; } /* path-step__title margin restore */


/* Cases block on white (2026-06-04) */
#cases{ background:#ffffff; }
#cases .resume-section-title{ color:#0f172a; }
#cases .resume-section-subtitle{ color:#64748b; }
#cases .detailed-case-card{ background:#f8fafc; border-color:rgba(15,23,42,0.08); box-shadow:0 6px 20px rgba(15,23,42,0.06); }
#cases .detailed-case-card:hover{ border-color:rgba(2,132,199,0.4); }
#cases .case-card-header{ border-bottom-color:rgba(15,23,42,0.1); }
#cases .case-card-badge{ color:#0284c7; }
#cases .case-card-title{ color:#0f172a; }
#cases .case-card-text-block p{ color:#475569; }
#cases .case-card-text-block p strong{ color:#0f172a; }
#cases .case-results-box{ background:#ffffff; border-color:rgba(15,23,42,0.08); }
#cases .result-metric__val{ color:#0f172a; }
#cases .result-metric__label{ color:#64748b; }
#cases .case-card-stack{ color:#64748b; border-top-color:rgba(15,23,42,0.12); }
#cases .case-card-stack strong{ color:#0f172a; }
#cases .case-link-btn{ color:#0284c7; }
#cases .case-link-btn:hover{ color:#0369a1; }
#cases .case-card-visual-block{ border-color:rgba(15,23,42,0.1); background:#ffffff; }
#cases .bg-illustration,
#cases .visual-centered{ background:rgba(15,23,42,0.03); }
#cases .badge-round{ border-color:rgba(2,132,199,0.35); background:rgba(2,132,199,0.05); }
#cases .badge-round__number{ color:#0284c7; }
#cases .badge-round__label{ color:#64748b; }
#cases .stats-visual-row{ color:#64748b; }
#cases .stats-visual-row strong{ color:#0f172a; }
#cases .stats-visual-progress{ background:rgba(15,23,42,0.06); }
#cases .progress-bar-fill{ background:#94a3b8; }
#cases .render-thumbs-mini{ background:rgba(15,23,42,0.03); border-top-color:rgba(15,23,42,0.1); }
#cases .thumb-btn-mini{ color:#64748b; border-color:rgba(15,23,42,0.15); }
#cases .thumb-btn-mini.active{ color:#0284c7; border-color:#0284c7; background:rgba(2,132,199,0.06); }


/* Case "Подробнее о проекте" expander (white cases theme, 2026-06-04) */
.case-more{ margin-top:18px; }
.case-more__summary{ cursor:pointer; list-style:none; display:inline-flex; align-items:center; gap:8px; font-weight:600; font-size:0.9rem; color:#0284c7; user-select:none; }
.case-more__summary:hover{ color:#0369a1; }
.case-more__summary::-webkit-details-marker{ display:none; }
.case-more__summary::before{ content:'+'; font-weight:700; font-size:1.05rem; line-height:1; width:18px; height:18px; display:inline-flex; align-items:center; justify-content:center; border:1px solid currentColor; border-radius:5px; }
.case-more[open] .case-more__summary::before{ content:'\2013'; }
.case-more__body{ margin-top:14px; }
.case-more__body .case-card-stack{ margin-top:14px; }
#cases .case-results-box{ margin:0 0 4px 0; }


/* case 1-sentence lead + metrics as blue-dot bullets (white cases, 2026-06-04) */
#cases .case-card-lead{ font-size:0.95rem; color:#475569; line-height:1.5; margin:10px 0 0; }
#cases .case-results-box{ display:flex; flex-direction:column; gap:11px; grid-template-columns:none; background:none; border:none; box-shadow:none; padding:0; margin:2px 0 6px; }
#cases .result-metric{ flex-direction:row; align-items:center; gap:10px; }
#cases .result-metric::before{ content:""; flex:0 0 auto; width:9px; height:9px; border-radius:50%; background:#0284c7; box-shadow:0 0 8px rgba(2,132,199,0.5); }
#cases .result-metric__val{ font-family:var(--font-heading); font-size:1rem; font-weight:800; color:#0f172a; line-height:1.3; margin:0; }
#cases .result-metric__label{ font-size:0.9rem; color:#475569; line-height:1.3; }


/* VAAM case deliverables chips (white cases, 2026-06-04) */
#cases .case-deliverables{ display:flex; flex-wrap:wrap; align-items:center; gap:8px; margin:8px 0 2px; }
#cases .case-deliverables__label{ font-size:0.85rem; font-weight:600; color:#0f172a; margin-right:2px; }
#cases .case-deliverables__chip{ font-size:0.78rem; color:#0369a1; background:rgba(2,132,199,0.08); border:1px solid rgba(2,132,199,0.18); padding:4px 11px; border-radius:20px; }


/* Skills block on white (2026-06-04) */
#skills{ background:#ffffff; }
#skills .resume-section-title{ color:#0f172a; }
#skills .resume-section-subtitle{ color:#64748b; }
#skills .skills-block{ background:#f8fafc; border-color:rgba(15,23,42,0.08); box-shadow:0 6px 20px rgba(15,23,42,0.06); }
#skills .skills-block__title{ color:#0f172a; border-bottom-color:rgba(15,23,42,0.1); }
#skills .skills-block__title i{ color:#0284c7; }
#skills .skills-tags span{ background:#ffffff; border-color:rgba(15,23,42,0.12); color:#475569; }
#skills .skills-tags span:hover{ border-color:#0284c7; color:#0f172a; background:rgba(2,132,199,0.05); }




/* legal footnote + asterisk (2026-06-04) */
.footer-resume__legal{ font-size:0.72rem; color:var(--color-text-dark); margin-top:16px; line-height:1.5; }
sup{ font-size:0.7em; vertical-align:super; line-height:0; }


/* Contact CTA buttons + testimonials (white, 2026-06-04) */
.contact-cta{ display:flex; flex-wrap:wrap; justify-content:center; gap:14px; margin:0 auto 30px; max-width:640px; }
.cbtn{ display:inline-flex; align-items:center; gap:9px; padding:14px 26px; border-radius:40px; font-weight:600; font-size:0.9rem; transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease, color .2s ease; }
.cbtn:hover{ transform:translateY(-2px); }
.cbtn--tg{ background:#0284c7; color:#fff; box-shadow:0 8px 22px rgba(2,132,199,0.28); }
.cbtn--tg:hover{ box-shadow:0 12px 28px rgba(2,132,199,0.38); }
.cbtn--mail{ background:rgba(255,255,255,0.04); color:var(--color-text); border:1px solid var(--color-border); }
.cbtn--mail:hover{ border-color:var(--color-cyan); color:var(--color-cyan); }
.cbtn--max{ background:linear-gradient(135deg,#f97316,#ef4444); color:#fff; box-shadow:0 8px 22px rgba(239,68,68,0.26); }
.cbtn--max:hover{ box-shadow:0 12px 28px rgba(239,68,68,0.36); color:#fff; }
.resume-testimonials{ padding:80px 0; border-bottom:1px solid var(--color-border); background:#ffffff; }
#testimonials .resume-section-title{ color:#0f172a; }
.testimonials-grid{ display:grid; grid-template-columns:1fr 1fr; gap:24px; max-width:900px; margin:0 auto; }
.testimonial{ background:#f8fafc; border:1px solid rgba(15,23,42,0.08); border-radius:var(--border-radius-lg); padding:32px; box-shadow:0 6px 20px rgba(15,23,42,0.06); margin:0; }
.testimonial__stars{ color:#f59e0b; font-size:1.05rem; letter-spacing:3px; margin-bottom:16px; }
.testimonial__text{ color:#334155; font-size:1rem; line-height:1.6; margin:0 0 18px; }
.testimonial__author{ color:#64748b; font-weight:600; font-size:0.9rem; }
@media (max-width:768px){ .testimonials-grid{ grid-template-columns:1fr; } }


/* mobile footer wrap fix (2026-06-04) */
.footer-resume__links{ flex-wrap:wrap; }


/* "Обсудить проект" outline-pill button -> #contact (2026-06-04) */
.btn-discuss{ display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:11px 28px; border-radius:40px; border:1.5px solid var(--color-cyan); background:rgba(0,194,255,0.07); color:var(--color-cyan); font-weight:600; font-size:0.88rem; white-space:nowrap; transition:background .25s ease, box-shadow .25s ease, transform .2s ease; }
.btn-discuss:hover{ background:rgba(0,194,255,0.14); box-shadow:0 0 22px rgba(0,194,255,0.22); transform:translateY(-1px); color:var(--color-cyan); }
.btn-discuss--nav{ padding:8px 22px; font-size:0.82rem; }
@media (max-width:768px){ .btn-discuss--nav{ display:none; } }


/* unify button shape: all buttons pill (2026-06-04) */
.btn{ border-radius:40px; }
.btn-discuss{ padding:10px 26px; }


/* mobile case metrics: stack value over label (2026-06-04) */
@media (max-width:768px){
  #cases .result-metric{ display:grid; grid-template-columns:auto 1fr; column-gap:10px; row-gap:1px; align-items:start; }
  #cases .result-metric::before{ margin-top:6px; }
  #cases .result-metric__val{ font-size:0.95rem; }
  #cases .result-metric__label{ grid-column:2; font-size:0.85rem; line-height:1.4; }
}
