/*
Theme Name: СтудияСофт
Author: Копчай Р.А.
Description: СтудияСофт - Искусство создавать решения
Version: 1.0
*/

/* Вставьте ВЕСЬ CSS-код из <style> тега */
	:root {
		--primary: #2563eb;
		--primary-dark: #1d4ed8;
		--secondary: #8b5cf6;
		--accent: #0ea5e9;
		--dark: #1e293b;
		--light: #f8fafc;
		--gray: #64748b;
		--light-gray: #e2e8f0;
		--transition: all 0.3s ease;
		--shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
		--shadow-hover: 0 15px 40px rgba(0, 0, 0, 0.12);
	}
	
	* {
		padding: 0;
		box-sizing: border-box;
	}
	
	body {
		font-family: 'Roboto', sans-serif;
		line-height: 1.6;
		color: var(--dark);
		background-color: var(--light);
		overflow-x: hidden;
	}
	
	h1, h2, h3, h4 {
		font-family: 'Montserrat', sans-serif;
		font-weight: 700;
		line-height: 1.2;
	}
	
	.container {
		width: 100%;
		max-width: 1200px;
		margin: 0 auto;
		padding: 0 20px;
	}
	
	.btn {
		display: inline-block;
		background: var(--primary);
		color: white;
		padding: 14px 32px;
		border-radius: 50px;
		text-decoration: none;
		font-weight: 500;
		transition: var(--transition);
		border: 2px solid var(--primary);
		box-shadow: 0 4px 6px rgba(37, 99, 235, 0.2);
		font-size: 1.05rem;
	}
	
	.btn:hover {
		background: var(--primary-dark);
		transform: translateY(-3px);
		box-shadow: 0 6px 12px rgba(37, 99, 235, 0.3);
	}
	
	.btn-outline {
		background: transparent;
		color: var(--primary);
	}
	
	.btn-outline:hover {
		background: var(--primary);
		color: white;
	}
	
	/* Header Styles */
	header {
		background: rgba(255, 255, 255, 0.97);
		box-shadow: 0 2px 10px rgba(0, 0, 0, 0.08);
		position: fixed;
		width: 100%;
		top: 0;
		left: 0;
		z-index: 1000;
		backdrop-filter: blur(8px);
		padding: 10px 0;
	}
	
	.header-container {
		display: flex;
		justify-content: space-between;
		align-items: center;
	}
	
	.logo {
		display: flex;
		align-items: center;
		font-size: 26px;
		font-weight: 700;
		color: var(--dark);
		text-decoration: none;
		gap: 12px;
	}
	
	.logo-icon {
		position: relative;
		width: 70px;
		height: 70px;
		display: flex;
		align-items: unset;
		justify-content: center;
	}
	
	.logo-icon .brush {
		position: absolute;
		font-size: 42px;
		color: var(--primary);
		opacity: 0.9;
		transform: rotate(-20deg);
	}
	
	.logo-icon .gear {
		position: absolute;
		font-size: 32px;
		color: var(--secondary);
		top: 12px;
		left: 18px;
		animation: rotate 12s linear infinite;
	}
	
	.logo-text {
		display: flex;
		flex-direction: column;
	}
	
	.logo-text span:first-child {
		font-family: 'Playfair Display', serif;
		font-size: 1.4em;
		letter-spacing: 1px;
	}
	
	.logo-text span:last-child {
		font-size: 0.65em;
		color: var(--gray);
		font-weight: 400;
		margin-top: -4px;
		letter-spacing: 1.5px;
	}
	
	.nav-links {
		display: flex;
		list-style: none;
	}
	
	.nav-links li {
		margin-left: 30px;
	}
	
	.nav-links a {
		text-decoration: none;
		color: var(--dark);
		font-weight: 500;
		transition: var(--transition);
		position: relative;
		font-size: 1.05rem;
	}
	
	.nav-links a:hover {
		color: var(--primary);
	}
	
	.nav-links a::after {
		content: '';
		position: absolute;
		bottom: -5px;
		left: 0;
		width: 0;
		height: 2px;
		background: var(--primary);
		transition: var(--transition);
	}
	
	.nav-links a:hover::after {
		width: 100%;
	}
	
	.mobile-menu-btn {
		display: none;
		background: none;
		border: none;
		font-size: 24px;
		color: var(--primary);
		cursor: pointer;
	}
	
	/* Hero Section */
	.hero {
		padding: 160px 0 100px;
		background: linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 100%);
		position: relative;
		overflow: hidden;
	}
	
	.hero::before {
		content: '';
		position: absolute;
		top: -50%;
		right: -50%;
		width: 100%;
		height: 200%;
		background: radial-gradient(circle, rgba(37, 99, 235, 0.08) 0%, transparent 70%);
		transform: rotate(30deg);
	}
	
	.hero-content {
		position: relative;
		z-index: 2;
		max-width: 650px;
	}
	
	.hero h1 {
		font-size: 5vh;
		margin-bottom: 20px;
		color: var(--dark);
		line-height: 1.1;
	}
	
	.hero h1 span {
		color: var(--primary);
		background: linear-gradient(120deg, var(--primary), var(--secondary));
		-webkit-background-clip: text;
		-webkit-text-fill-color: transparent;
	}
	
	.hero p {
		font-size: 2.5vh;
		margin-bottom: 30px;
		color: var(--gray);
		max-width: 550px;
	}
	
	.hero-btns {
		display: flex;
		gap: 15px;
		margin-top: 30px;
	}
	
	/* Slogan Section */
	.slogan-section {
		background: linear-gradient(to right, #f8fafc, #f0f9ff);
		padding: 60px 0;
		position: relative;
		overflow: hidden;
	}
	
	.slogan-container {
		display: flex;
		align-items: center;
		max-width: 1200px;
		margin: 0 auto;
		padding: 0 20px;
	}
	
	.slogan-visual {
		flex: 1;
		position: relative;
		display: flex;
		justify-content: center;
	}
	
	.slogan-c {
		position: relative;
		min-width: 30vw;
		max-width: 70vw;
		height: 50vh;
		color: var(--primary);
		line-height: 1;
	}
	
	.slogan-c .brush {
		position: absolute;
		top: 0;
		left: 0;
		color: var(--secondary);
		opacity: 0.7;
		z-index: 1;
	}
	
	.slogan-c .gear {
		position: absolute;
		top: 80px;
		left: 110px;
		color: var(--dark);
		font-size: 60px;
		animation: rotate 15s linear infinite;
	}
	
	.slogan-text {
		flex: 1;
	}
	
	.slogan-text h2 {
		font-size: 2.8rem;
		color: var(--dark);
		margin-bottom: 20px;
		line-height: 1.2;
	}
	
	.slogan-text p {
		font-size: 1.2rem;
		color: var(--gray);
		margin-bottom: 25px;
		max-width: 500px;
	}
	
	.slogan-highlight {
		display: inline-block;
		padding: 8px 20px;
		background: linear-gradient(to right, rgba(37, 99, 235, 0.1), rgba(139, 92, 246, 0.1));
		border-radius: 50px;
		color: var(--primary);
		font-weight: 500;
		margin-top: 15px;
		border: 1px solid rgba(37, 99, 235, 0.2);
	}
	
	/* Services Section */
	.services {
		padding: 60px 0;
		background: white;
	}
	
	.section-title {
		text-align: center;
		margin-bottom: 60px;
	}
	
	.section-title h2 {
		font-size: 2.5rem;
		color: var(--dark);
		margin-bottom: 15px;
	}
	
	.section-title p {
		color: var(--gray);
		max-width: 600px;
		margin: 0 auto;
		font-size: 1.1rem;
	}
	
	.services-grid {
		display: grid;
		grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
		gap: 30px;
	}
	
	.service-card {
		background: white;
		border-radius: 15px;
		padding: 40px 30px;
		box-shadow: var(--shadow);
		transition: var(--transition);
		text-align: center;
		border: 1px solid var(--light-gray);
	}
	
	.service-card:hover {
		transform: translateY(-10px);
		box-shadow: var(--shadow-hover);
		border-color: var(--primary);
	}
	
	.service-icon {
		width: 80px;
		height: 80px;
		background: #dbeafe;
		border-radius: 50%;
		display: flex;
		align-items: center;
		justify-content: center;
		margin: 0 auto 25px;
		color: var(--primary);
		font-size: 32px;
	}
	
	.service-card h3 {
		font-size: 1.5rem;
		margin-bottom: 15px;
		color: var(--dark);
	}
	
	.service-card p {
		color: var(--gray);
		margin-bottom: 20px;
	}
	
	/* About Section */
	.about {
		padding: 60px 0;
		background: linear-gradient(to bottom, #f0f9ff, #e0f2fe);
	}
	
	.about-content {
		display: flex;
		align-items: center;
		gap: 60px;
	}
	
	.about-text {
		flex: 1;
	}
	
	.about-text h2 {
		font-size: 2.5rem;
		margin-bottom: 20px;
		color: var(--dark);
	}
	
	.about-text p {
		margin-bottom: 20px;
		color: var(--gray);
		font-size: 1.1rem;
	}
	
	.about-features {
		margin-top: 30px;
	}
	
	.feature {
		display: flex;
		align-items: flex-start;
		margin-bottom: 20px;
	}
	
	.feature i {
		color: var(--primary);
		font-size: 24px;
		margin-right: 15px;
		flex-shrink: 0;
	}
	
	/* Contact Section */
	.contact {
		padding: 60px 0;
		background: white;
	}
	
	.contact-container {
		display: grid;
		grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
		gap: 50px;
	}
	
	.contact-info {
		background: linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);
		border-radius: 15px;
		padding: 40px;
		color: white;
		box-shadow: 0 15px 40px rgba(37, 99, 235, 0.2);
	}
	
	.contact-info h2 {
		font-size: 2rem;
		margin-bottom: 30px;
		color: white;
	}
	
	.contact-detail {
		display: flex;
		align-items: flex-start;
		margin-bottom: 25px;
	}
	
	.contact-detail i {
		font-size: 24px;
		margin-right: 15px;
		color: white;
		flex-shrink: 0;
	}
	
	.contact-detail div h3 {
		font-size: 1.2rem;
		margin-bottom: 5px;
	}
	
	.contact-detail div p, 
	.contact-detail div a {
		color: rgba(255, 255, 255, 0.9);
		text-decoration: none;
		transition: var(--transition);
		font-size: 1.1rem;
	}
	
	.contact-detail div a:hover {
		color: white;
		text-decoration: underline;
	}
	
	.location-map {
		background: #f1f5f9;
		border-radius: 15px;
		padding: 30px;
		box-shadow: var(--shadow);
		height: 100%;
	}
	
	.location-map h3 {
		font-size: 1.5rem;
		margin-bottom: 20px;
		color: var(--dark);
	}
	
	.map-placeholder {
		background: #e2e8f0;
		height: 300px;
		border-radius: 10px;
		display: flex;
		align-items: center;
		justify-content: center;
		color: var(--gray);
		font-weight: 500;
		margin-top: 20px;
		flex-direction: column;
		padding: 20px;
		text-align: center;
	}
	
	.map-placeholder i {
		font-size: 48px;
		margin-bottom: 15px;
		color: var(--primary);
	}
	
	/* Footer */
	footer {
		background: var(--dark);
		color: white;
		padding: 60px 0 30px;
	}
	
	.footer-container {
		display: grid;
		grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
		gap: 40px;
		margin-bottom: 40px;
	}
	
	.footer-col h3 {
		font-size: 1.3rem;
		margin-bottom: 20px;
		position: relative;
		padding-bottom: 10px;
	}
	
	.footer-col h3::after {
		content: '';
		position: absolute;
		bottom: 0;
		left: 0;
		width: 50px;
		height: 2px;
		background: var(--primary);
	}
	
	.footer-links {
		list-style: none;
	}
	
	.footer-links li {
		margin-bottom: 12px;
	}
	
	.footer-links a {
		color: #cbd5e1;
		text-decoration: none;
		transition: var(--transition);
	}
	
	.footer-links a:hover {
		color: white;
		padding-left: 5px;
	}
	
	.social-links {
		display: flex;
		gap: 15px;
		margin-top: 20px;
	}
	
	.social-links a {
		display: flex;
		align-items: center;
		justify-content: center;
		width: 40px;
		height: 40px;
		background: rgba(255, 255, 255, 0.1);
		border-radius: 50%;
		color: white;
		transition: var(--transition);
	}
	
	.social-links a:hover {
		background: var(--primary);
		transform: translateY(-3px);
	}
	
	.copyright {
		text-align: center;
		padding-top: 30px;
		border-top: 1px solid rgba(255, 255, 255, 0.1);
		color: #94a3b8;
		font-size: 0.9rem;
	}
	
	/* Animations */
	@keyframes fadeInUp {
		from {
			opacity: 0;
			transform: translateY(30px);
		}
		to {
			opacity: 1;
			transform: translateY(0);
		}
	}
	
	@keyframes rotate {
		from {
			transform: rotate(0deg);
		}
		to {
			transform: rotate(360deg);
		}
	}
	
	.animate {
		animation: fadeInUp 0.8s ease forwards;
	}
	
	.delay-1 {
		animation-delay: 0.1s;
	}
	
	.delay-2 {
		animation-delay: 0.2s;
	}
	
	.delay-3 {
		animation-delay: 0.3s;
	}
	
	/* Responsive Styles */
	@media (max-width: 992px) {
		.hero h1 {
			font-size: 5vh;
		}
		
		.slogan-container {
			flex-direction: column;
			text-align: center;
		}
		
		.slogan-text p {
			margin: 0 auto 25px;
		}
	}
	
	@media (max-width: 768px) {
		.mobile-menu-btn {
			display: block;
		}
		
		.nav-links {
			position: fixed;
			top: 80px;
			left: 0;
			background: white;
			width: 100%;
			flex-direction: column;
			align-items: center;
			padding: 20px 0;
			box-shadow: 0 10px 10px rgba(0, 0, 0, 0.1);
			transform: translateY(-150%);
			transition: var(--transition);
		}
		
		.nav-links.active {
			transform: translateY(0);
		}
		
		.nav-links li {
			margin: 15px 0;
		}
		
		.hero h1 {
			font-size: 5vh;
		}
		
		.hero-btns {
			flex-direction: column;
		}
		
		.about-content {
			flex-direction: column;
		}
		
		.slogan-text h2 {
			font-size: 2.3rem;
		}
	}
	
	@media (max-width: 576px) {
		.hero {
			padding: 140px 0 80px;
		}
		
		.hero h1 {
			font-size: 3.5vh;
		}
		
		.section-title h2 {
			font-size: 2rem;
		}
		
		.logo-text span:first-child {
			font-size: 1.2em;
		}
	}

	/* Секция кейсов */
	.case-studies-section {
		padding: 80px 0;
		background: linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 100%);
		position: relative;
		overflow: hidden;
	}

	.cases-carousel {
		position: relative;
		height: 500px;
		perspective: 1000px;
		margin: 0 auto;
		max-width: 1200px;
		touch-action: pan-y; /* Для поддержки свайпа */
	}

	.carousel-container {
		width: 100%;
		height: 100%;
		position: relative;
		transform-style: preserve-3d;
		cursor: grab;
	}

	.carousel-container:active {
		cursor: grabbing;
	}

	.carousel-track {
		position: relative;
		height: 100%;
		width: 100%;
		transform-style: preserve-3d;
		transition: transform 0.6s cubic-bezier(0.645, 0.045, 0.355, 1);
	}

	.carousel-slide {
		position: absolute;
		width: 70%;
		left: 15%;
		top: 0;
		transition: transform 0.8s ease, opacity 0.8s ease, filter 0.8s ease;
		transform-origin: center center;
		opacity: 0.3;
		filter: blur(5px);
		z-index: 1;
		pointer-events: none;
	}

	.carousel-slide.active {
		transform: translateZ(0);
		opacity: 1;
		filter: blur(0);
		z-index: 10;
		pointer-events: auto;
	}

	.carousel-slide.prev {
		transform: translateX(-80%) translateZ(-100px) rotateY(20deg);
		pointer-events: auto;
    	cursor: pointer;
	}

	.carousel-slide.next {
		transform: translateX(80%) translateZ(-100px) rotateY(-20deg);
		pointer-events: auto;
    	cursor: pointer;
	}

	.case-card {
		background: white;
		border-radius: 15px;
		overflow: hidden;
		box-shadow: 0 20px 50px rgba(37, 99, 235, 0.2);
		height: 100%;
		display: flex;
		flex-direction: column;
		transform: scale(1);
		transition: transform 0.1s ease;
	}

	.carousel-slide.active .case-card {
		transform: scale(1);
	}

	.case-header {
		background: linear-gradient(90deg, var(--primary), var(--secondary));
		color: white;		
	}

	.case-tags {
		display: flex;
		flex-wrap: wrap;
		gap: 8px;
		margin-bottom: 10px;
	}

	.case-tag {
		background: rgba(255, 255, 255, 0.2);
		padding: 4px 12px;
		border-radius: 50px;
		font-size: 0.85rem;
		font-weight: 500;
	}

	.case-title {
		font-size: min(5vw, 1.6rem);
		margin: 5px 0 10px;
		font-weight: 700;
		line-height: 1.3;
	}

	.client-info {
		display: flex;
		align-items: center;
		gap: 8px;
		font-size: 1rem;
		opacity: 0.9;
	}

	.case-content {
		padding: min(5vw, 1.6rem);
		flex-grow: 1;
		display: flex;
		flex-direction: column;
	}

	.case-tasks {
		flex-grow: 1;
		margin-bottom: 20px;
	}

	.case-tasks h4 {
		color: var(--primary);
		font-size: 1.1rem;
		margin-top: 0;
		margin-bottom: 12px;
		display: flex;
		align-items: center;
		gap: 8px;
	}

	.case-btns {
		display: flex;
		flex-direction: row;
		gap: 10px;
		justify-content: center;
		align-items: center;
	}

	.btn-solution {
		background: var(--primary);
		color: white;
		padding: 12px 20px;
		border-radius: 8px;
		text-decoration: none;
		font-weight: 500;
		transition: var(--transition);
		display: flex;
		align-items: center;
		justify-content: center;
		gap: 10px;
		margin-top: auto;
	}

	.btn-solution:hover {
		background: var(--primary-dark);
		transform: translateY(-3px);
		box-shadow: 0 4px 10px rgba(37, 99, 235, 0.3);
	}

	/* Навигация */
	.carousel-prev, .carousel-next {
		width: 50px;
		height: 50px;
		border-radius: 8px;
		background: var(--primary);
		color: white;
		border: none;
		cursor: pointer;
		display: flex;
		align-items: center;
		justify-content: center;
		transition: var(--transition);
		font-size: 1.2rem;
		z-index: 20;
		box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
	}

	.carousel-prev {
		left: 5%;
	}

	.carousel-next {
		right: 5%;
	}

	.carousel-prev:hover, .carousel-next:hover {
		background: var(--primary-dark);
		
	}

	/* Адаптивность */
	@media (max-width: 992px) {
		.cases-carousel {
			height: 450px;
		}

		.carousel-slide {
			width: 80%;
			left: 10%;
		}

		.carousel-prev {
			left: 2%;
		}

		.carousel-next {
			right: 2%;
		}
	}

	@media (max-width: 768px) {
		.cases-carousel {
			height: 400px;
		}

		.carousel-slide {
			width: 90%;
			left: 5%;
		}

		.case-title {
			
		}

		.carousel-prev, .carousel-next {
			width: 40px;
			height: 40px;
			font-size: 1rem;
		}
	}

	@media (max-width: 576px) {
		.case-studies-section {
			padding: 60px 0;
		}

		.cases-carousel {
			height: 500px;
		}

		.carousel-slide {
			width: 95%;
			left: 2.5%;
		}

		.case-header {
			
		}

		.case-content {
			
		}
	}

	/* Детальная страница кейса */
	.case-study-single {
		padding: 60px 0;
	}

	.case-header {
		background: linear-gradient(90deg, var(--primary), var(--secondary));
		color: white;
		padding: min(5vw, 1.6rem);
		border-radius: 15px 15px 0 0;
	}

	.case-title {
		
	}

	.case-content-single {
		background: white;
		border-radius: 0 0 15px 15px;
		box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
		padding-bottom: min(5vw, 1.6rem);
		flex-grow: 1;
		display: flex;
		flex-direction: column;
	}

	.case-section {
		padding-left: min(10vw, 1.6rem);
		padding-right: min(5vw, 1.6rem);
		font-size: min(5vw, 1.6rem);
		position: relative;
		overflow: hidden;
	}

	.case-section h2 {
		font-size: 1.8rem;
		margin-bottom: 20px;
		color: var(--primary);
		display: flex;
		align-items: center;
		gap: 12px;
	}

	.case-section-content {
		line-height: 1.7;
		font-size: 1.1rem;
	}

	.back-to-cases {
		margin-top: 50px;
		text-align: center;
	}

	.zadacha {
		background: linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 100%);
	}

	.reschenie {
		background: linear-gradient(to right, #f8fafc, #f0f9ff);
	}

	.result {
		
	}