

/* Resetare CSS */
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

body {
	font-family: 'Roboto', sans-serif;
	scroll-behavior: smooth;
	color: #333;
}

.container {
	width: 90%;
	max-width: 1200px;
	margin: 0 auto;
}

.navbar {
	position: fixed;
	width: 100%;
	background-color: rgba(255, 255, 255, 0.9);
	z-index: 1000;
	transition: background-color 0.3s;
}

.navbar .container {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 15px 0;
}

.navbar .logo a {
	font-size: 24px;
	font-weight: bold;
	color: #333;
	text-decoration: none;
}

.navbar .nav-links {
	list-style: none;
	display: flex;
}

.navbar .nav-links li {
	margin-left: 30px;
}

.navbar .nav-links a {
	text-decoration: none;
	color: #333;
	font-weight: 500;
	transition: color 0.3s;
}

.navbar .nav-links a:hover {
	color: #007BFF;
}

.burger {
	display: none;
	cursor: pointer;
}

.burger div {
	width: 25px;
	height: 3px;
	margin: 5px;
	background-color: #333;
	transition: all 0.3s ease;
}

/* Home Section */
.section-home {
	height: 100vh;
	background: url('/image/hero.jpg') no-repeat center center/cover;
	position: relative;
	overflow-x: hidden;
}

.section-home .overlay {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-color: rgba(0, 0, 0, 0.5);
}

.home-content {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	color: #fff;
	text-align: center;
}

.home-content h1 {
	font-size: 48px;
	margin-bottom: 20px;
	animation: fadeInDown 1s;
}

.home-content p {
	font-size: 20px;
	margin-bottom: 30px;
	animation: fadeInUp 1s;
}

.home-content .btn {
	padding: 15px 30px;
	background-color: #007BFF;
	color: #fff;
	text-decoration: none;
	font-weight: bold;
	border-radius: 50px;
	transition: background-color 0.3s;
}

.home-content .btn:hover {
	background-color: #0056b3;
}

/* Keyframes for animations */
@keyframes fadeInDown {
	from {
		opacity: 0;
		transform: translateY(-20px);
	} to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes fadeInUp {
	from {
		opacity: 0;
		transform: translateY(20px);
	} to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* Evenimente Section */
.section-evenimente {
	padding: 100px 0;
	background-color: #f9f9f9;
}

.section-evenimente h2 {
	text-align: center;
	margin-bottom: 50px;
	font-size: 36px;
}

.grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 30px;
}

.card {
	background-color: #fff;
	border-radius: 10px;
	overflow: hidden;
	box-shadow: 0 5px 15px rgba(0,0,0,0.1);
	transition: transform 0.3s;
}

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

.card-image img {
	width: 100%;
	height: 200px;
	object-fit: cover;
}

.card-content {
	padding: 20px;
}

.card-content h3 {
	margin-bottom: 15px;
}

.card-content .btn-details {
	padding: 10px 20px;
	background-color: #007BFF;
	color: #fff;
	border: none;
	border-radius: 50px;
	cursor: pointer;
	transition: background-color 0.3s;
}

.card-content .btn-details:hover {
	background-color: #0056b3;
}

/* Echipa Section */
.section-echipa {
	padding: 100px 0;
}

.section-echipa h2 {
	text-align: center;
	margin-bottom: 50px;
	font-size: 36px;
}

.team-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 30px;
}

.team-card {
	text-align: center;
}

.team-card img {
	aspect-ratio: 1 / 1;
	width: 60%;
	border-radius: 50%;
	object-fit: cover;
	margin-bottom: 20px;
}

.team-card h3 {
	margin-bottom: 5px;
}

.team-card p {
	color: #777;
}

/* Servicii Section */
.section-servicii {
	padding: 100px 0;
	background-color: #f9f9f9;
}

.section-servicii h2 {
	text-align: center;
	margin-bottom: 50px;
	font-size: 36px;
}

.services-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 30px;
}

.service-card {
	text-align: center;
	padding: 40px 20px;
	background-color: #fff;
	border-radius: 10px;
	transition: transform 0.3s;
}

.service-card:hover {
	transform: translateY(-10px);
}

.service-card i {
	font-size: 50px;
	color: #007BFF;
	margin-bottom: 20px;
}

.service-card h3 {
	margin-bottom: 15px;
}

.service-card p {
	color: #777;
}

/* Contact Section */
.section-contact {
	padding: 100px 0;
}

.section-contact h2 {
	text-align: center;
	margin-bottom: 50px;
	font-size: 36px;
}

.contact-wrapper {
	display: flex;
	flex-wrap: wrap;
	gap: 50px;
	justify-content: center;
}

#contact-form {
	flex: 1;
	min-width: 300px;
}

.form-group {
	margin-bottom: 20px;
}

.form-group label {
	display: block;
	margin-bottom: 10px;
	font-weight: bold;
}

.form-group input,
.form-group textarea {
	width: 100%;
	padding: 15px;
	border: 1px solid #ccc;
	border-radius: 5px;
}

#contact-form .btn {
	padding: 15px 30px;
	background-color: #007BFF;
	color: #fff;
	border: none;
	border-radius: 50px;
	cursor: pointer;
	transition: background-color 0.3s;
}

#contact-form .btn:hover {
	background-color: #0056b3;
}

#harta {
	flex: 1;
	min-width: 300px;
}

/* Footer */
footer {
	background-color: #333;
	color: #fff;
	text-align: center;
	padding: 20px;
}

/* Responsivitate */
@media screen and (max-width: 768px) {
	.navbar .nav-links {
		position: absolute;
		right: 0;
		height: 100vh;
		top: 0;
		background-color: rgba(255,255,255,0.95);
		flex-direction: column;
		align-items: center;
		justify-content: center;
		transform: translateX(100%);
		transition: transform 0.5s ease-in;
	}

	.navbar .nav-links li {
		margin: 20px 0;
	}

	.burger {
		display: block;
	}

	.nav-active {
		transform: translateX(0);
	}

	.burger.toggle .line1 {
		transform: rotate(-45deg) translate(-5px, 6px);
	}

	.burger.toggle .line2 {
		opacity: 0;
	}

	.burger.toggle .line3 {
		transform: rotate(45deg) translate(-5px, -6px);
	}

	.contact-wrapper {
		flex-direction: column;
	}
}


/* Stiluri generale */
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

body {
	font-family: 'Roboto', sans-serif;
	color: #333;
}
* {
	scroll-behavior: smooth;
}

/* ... alte stiluri existente ... */

/* Stiluri pentru burger menu */
.burger {
	display: none;
	cursor: pointer;
	position: absolute;
	top: 15px;
	right: 20px;
	z-index: 1001;
}

.burger div {
	width: 25px;
	height: 3px;
	background-color: #333;
	margin: 5px;
	transition: all 0.3s ease;
}

/* Navbar scrolled */
.navbar.scrolled {
	background-color: rgba(255, 255, 255, 0.9);
	box-shadow: 0 2px 5px rgba(0,0,0,0.1);
}

/* Responsivitate */
@media screen and (max-width: 768px) {
	.navbar .nav-links {
		position: fixed;
		right: 0;
		top: 0;
		height: 100vh;
		width: 100%;
		background-color: rgba(255,255,255,0.95);
		flex-direction: column;
		align-items: center;
		justify-content: center;
		transform: translateX(100%);
		transition: transform 0.5s ease-in-out;
		z-index: 1000;
	}

	.navbar .nav-links li {
		margin: 20px 0;
	}

	.burger {
		display: block;
	}

	.nav-active {
		transform: translateX(0%);
	}

	.burger.toggle .line1 {
		transform: rotate(-45deg) translate(-5px, 6px);
	}

	.burger.toggle .line2 {
		opacity: 0;
	}

	.burger.toggle .line3 {
		transform: rotate(45deg) translate(-5px, -6px);
	}

	.contact-wrapper {
		flex-direction: column;
	}
}

:root {
	--gap: calc( .75vmin + .75vmax );
	--break: 30em;
	--rad: calc( var( --gap ) * 1 );
	--white: 255, 255, 255;
	--black: 0, 0, 0;
	--opacity-none: 0;
	--opacity-low: .25;
	--opacity-medium: .5;
	--opacity-high: .75;
	--opacity-full: 1;
	--transition-fast: 250ms;
	--col-0: 1, 158, 159;
	--col-1: 252, 31, 90;
	--col-2: 48, 82, 142;
	--col-x: 211, 211, 211;
	font-family: "Montserrat", sans-serif;
	font-optical-sizing: auto;
	font-weight: normal;
	font-style: normal;
	font-size: 16px;
	--prim: rgba( var( --col-2 ), var( --opacity-full ) );
	--seco: rgba( var( --col-0 ), var( --opacity-full ) );
}
#articole-header {
	position: sticky;
	top: 0px;
	padding: calc( var( --gap ) * 1 ) calc( var( --gap ) * 1 );
	background: rgba( var( --white ), var( --opacity-high ) );
	backdrop-filter: blur( calc( var( --gap ) * 2 ) );
	-webkit-backdrop-filter: blur( calc( var( --gap ) * 2 ) );
	min-width: 100dvw;
	margin-left: calc( 50% - 50dvw );
	z-index: 99;
}
#articole-header nav * {
	transition: all var( --transition-fast ) ease-in-out;
}
#articole-header:has( nav.scroll ) {
	padding-block: calc( var( --gap ) * .5 );
}
#articole-header:has( nav.scroll ) nav a:first-of-type img {
	max-height: 30px;
}
#articole-header:has( nav.scroll ) nav a:first-of-type span {
	opacity: 0;
}
nav {
	container: nav / inline-size;
	padding-inline: calc( ( 100vw - 1360px ) / 2 );
}
nav a,
nav label {
	display: flex;
	cursor: pointer;
	color: rgba( var( --col-1 ), var( --opacity-full ) );
	text-decoration: none;
	position: relative;
	font-size: 1.2em;
	font-weight: bold;
}
nav a:before,
nav label:before {
	content: "";
	position: absolute;
	display: block;
	width: 100%;
	height: 2px;
	bottom: 0;
	left: 0;
	background-color: rgba( var( --col-1 ), var( --opacity-full ) );
	transform: scaleX( 0 );
	transition: all var( --transition-fast ) ease-in-out;
}
nav a:not( :has( img ) ):hover:before,
nav label:not( [for="nav-menu"] ):hover:before {
	transform: scaleX( 1 );
}
@media ( pointer: fine ) {
	nav a.perma:has( svg ) {
		transition: all var( --transition-fast ) ease-in-out;
		border-radius: 50%;
	}
	nav a.perma:has( svg ):before {
		background-color: transparent;
	}
	nav a.perma:has( svg ):hover {
		transform: scale( 1.2 );
		outline: 4px solid var( --prim );
	}
}
@media ( pointer: coarse ) {
	.section-home svg {
		scale: 2;
	}
}
nav svg {
	width: 1.4em;
	aspect-ratio: 1 / 1;
}
nav *.perma svg {
	min-width: 40px;
}
nav div div svg {
	margin-left: calc( var( --gap ) * .5 );
}
nav div div svg path {
	fill: rgba( var( --col-1 ), var( --opacity-medium ) );
}
nav > label {
	display: none;
}
nav,
nav > div {
	display: flex;
	gap: var( --gap );
	justify-content: flex-end;
	align-items: center;
}
nav > a:first-of-type {
	margin-right: auto;
	display: flex;
	align-items: center;
	gap: calc( var( --gap ) * 1 );
	text-decoration: none;
	font-weight: 900;
	text-transform: uppercase;
	color: rgba( var( --col-2 ), var( --opacity-full) );
}



nav > a:first-of-type img {
	max-height: 4em;
}
nav > div > div {
	position: relative;
}
nav > div > div > div {
	display: none;
	position: absolute;
}
nav > div > div input,
nav label input#nav-menu[type="checkbox"],
nav label svg {
	display: none;
}
nav label:not( :has( input:is( :checked ) ) ) .fa-bars,
nav label:has( input:is( :checked ) ) .fa-xmark-large {
	display: block;
}
nav > div > div:has( input:is( :checked ) ) > div {
	display: grid;
	grid-template-columns: 1fr;
	padding: calc( var( --gap ) * 1 ) calc( var( --gap ) * .5 );
	width: 100%;
	background-color: rgba( var( --white ), var( --opacity-full ) );
	gap: calc( var( --gap ) * .5 );
}



@container nav ( width < 70em ) {
	nav label {
		display: flex;
		align-items: center;
	}
	nav > *:not( *.perma ) {
		display: none;
	}
	nav > div > div {
		position: relative;
		top: initial;
		left: initial;
		right: initial;
	}
	nav > div > div:has( input:is( :checked ) ) > div {
		padding-left: calc( var( --gap ) * 3 );
		display: grid;
		grid-template-columns: 1fr;
	}
	nav:has( > label input:is( :checked ) ) > div {
		margin-inline:  calc( 0px - var( --gap ) * 1 );
		position: absolute;
		top: 100%;
		right: 0px;
		left: 0px;
		display: flex;
		flex-direction: column;
		align-items: flex-start;
		background-color: rgba( var( --white ), var( --opacity-full ) );
		gap: 0px;
		border-bottom: 2px solid rgba( var( --col-2 ), var( --opacity-full ) );
	}
	nav:has( label input:is( :checked ) ) > div > * {
		margin-left: calc( var( --gap ) * 2 );
		padding-block: calc( var( --gap ) * 1.5 );
		width: calc( 100% - var( --gap ) * 1 );
	}
	nav:has( div > div > label input:is( :checked ) ) > div > div > div {
		margin-left: calc( var( --gap ) * -1 );
		padding-block: calc( var( --gap ) * .5 );
		width: calc( 100% + var( --gap ) * 1 );
		background-color: rgba( var( --white ), var( --opacity-full ) );
		border-bottom: 2px solid rgba( var( --col-2 ), var( --opacity-full ) );
	}
	nav:has( label input:is( :checked ) ) > div > div > div > a {
		padding-block: calc( var( --gap ) * .5 );
	}
	nav > div > div svg {
		disnplay: none;
	}
	nav:has( div > div input[type="checkbox"]:is( :checked ) ) svg.fa-angle-down,
	nav:has( div > div input[type="checkbox"]:is( :not( :checked ) ) ) svg.fa-angle-right {
		display: block;
	}
	@media ( pointer: fine ) {
		nav > div > div:hover > div {
			padding-left: calc( var( --gap ) * 3 );
		}
	}
}
@container nav ( width >= 70em ) {
	nav:has( div > div:hover ) svg.fa-angle-down,
	nav:has( div > div:not( :hover ) ) svg.fa-angle-right {
		display: block;
	}
	nav:has( div > div:hover ) svg.fa-angle-right {
		display: none;
	}
	nav > div > div:hover > div {
		display: grid;
		grid-template-columns: 1fr;
		padding: calc( var( --gap ) * 1 ) calc( var( --gap )* .5 );
		width: 100%;
		background-color: rgba( var( --white ), var( --opacity-full ) );
		gap: calc( var( --gap ) * .5 );
	}
}

.team-card h3 {
	padding: 0px;
	margin-bottom: calc( var( --gap ) * 2 );
	font-size: 1.4em;
	text-transform: uppercase;
}
.team-card.d,
.team-card.d a {
	color: rgba( var( --col-1 ), 1 );
}
.team-card.d {
	order: 1;
}
.team-card.e,
.team-card.e a {
	color: rgba( var( --col-2 ), 1 );
}
.team-card.e {
	order: 2;
}
.card-dets {
	width: 60%;
	margin: auto;
	display: grid;
	gap: 30px;
	grid-template-rows: 1fr 1fr;
	grid-template-columns: 100px 1fr;
}
.card-dets cite {
	justify-self: end;
}
.card-dets a {
	justify-self: start;
	color: rgba( var( --col-1 ), 1 );
}

a[name] {
	display: block;
	height: 2px;
	background: transparent;
	transform: translateY( calc( 0px - var( --gap ) * 3 ) );
}
h2 {
	padding-block: calc( var( --gap ) );
	text-align: center;
}
.container:nth-of-type( odd ) h2 {
	color: rgba( var( --col-2 ), 1 );
}
.container:nth-of-type( even ) h2 {
	color: rgba( var( --col-1 ), 1 );
}

.section-services {
	background: url( "/image/camera.jpg" ) no-repeat center center;
	background-size: cover;
	margin-block: calc( var( --gap ) * 2 );
}

.section-services .container {
	display: grid;
	grid-template-columns: 3fr 2fr;
	gap: 30px;
	width: 100%;
}
.section-services .container > div {
	color: white;
}
.section-services .container > div:nth-of-type( 1 ) {
	display: flex;
	align-items: flex-end;
	justify-content: center;
}
.section-services .container > div:nth-of-type( 1 ) > div,
.like-why-us,
.like-why-us-pink {
	font-size: 3em;
	font-weight: bold;
	padding: calc( var( --gap ) * 1 );
}
.like-why-us {
	color: black !important;
}
.like-why-us-pink {
	color: rgba( var( --col-1 ), 1 ) !important;
}
.section-services .container > div:nth-of-type( 2 ) {
	background-color: #e74e68;
	padding: calc( var( --gap ) * 2 );
	min-height: 70dvh;
	display: flex;
	align-items: center;
	justify-content: center;
}
#contact-form .btn {
	background-color: rgba( var( --col-1 ), 1 );
	font-weight: bold;
}

.section-projects .container .grid .card:last-of-type {
	grid-column: 1 / -1;
}
.section-projects .container .grid .card:last-of-type img {
	min-height: 400px;
}

.te {
	color: grey;
	line-height: 2.6em;
}
.te span {
	font-size: 2.6em;
	font-weight: bold;
}
.contact-wrapper {
	display: grid;
	flex-wrap: wrap;
	gap: 30px;
	justify-content: center;
	grid-template-columns: 1fr 1fr;
	align-items: center;
}

@media screen and (max-width: 768px) {
	.contact-wrapper {
		dislay: grid;
		grid-template-columns: 1fr;
	}
}

@media ( pointer: coarse ) {
	a[name] {
		transform: translateY( calc( 0px - var( --gap ) * 6 ) );
	}
	.team-card img {
		border-radius: 10%;
		margin: 0px;
	}
	.team-grid {
		display: grid;
		grid-template-columns: 1fr;
		grid-template-rows: 1fr;
	}
	.card-dets {
		width: 90%;
		gap: 5px;
		grid-template-columns: 60px 1fr;
	}
	.team-card.d {
		order: 2;
	}
	.team-card.e {
		order: 1;
	}
	.section-services .container {
		grid-template-columns: 1fr;
		grid-template-rows: 3fr 2fr;
	}
	.section-services .container > div:nth-of-type( 1 ) {
		align-items: start;
	}
	.section-services .container > div:nth-of-type( 2 ) {
		min-height: initial;
	}
	.te {
		line-height: 1.8em;
	}
	.te span {
		font-size: 1.8em;
	}
}
