@font-face {
	font-family: 'Roboto-Regular';
	src: url('fonts/Roboto-Regular.ttf') format('truetype');
	font-weight: 700;
}

* {
    box-sizing: border-box;
	font-family: roboto, Arial, sans-serif;
	font-size: 16px;
}

.message {
    position: fixed;
    top: 20px;
    right: 20px;
    transform: translateX(-50%);
    padding: 10px 20px;
    border-radius: 5px;
    color: #fff;
    font-weight: bold;
    z-index: 1000;
}

.error {
    background-color: #ff3333;
}

.success {
    background-color: #33cc33;
}

html {
	height: 100%;
}

body {
	color: #485371;
	background: #f8f9fa;
	display: flex;
    flex-direction: column;
    align-items: center;
	padding: 0px;
	margin: 0px;
	min-height: 100vh;
}

main {
	background-color: #fff;
	width: 1050px;
	flex:1;
	display: flex;
}

.header {
	width: 100%;
	display: flex;
	padding-bottom: 32px;
}

.logo {
	display: flex;
	align-items: center;
}

.contacts {
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 15% 100%);
    flex-grow: 1;
	display: flex;
	background-image: url("header.jpg");
	background-color: #00afad;
    background-position: 10% 50%;
	background-repeat: no-repeat; 
	background-size: cover;
}


.contacts .menu {
	padding: 16px 64px;
	flex: 1;
	display: flex;
    justify-content: flex-end;
    flex-direction: row;
    flex-wrap: nowrap;
    align-content: center;
    align-items: center;
}
.contacts .menu a {
	text-decoration: none;
	color: #fff;
}
main .content {
	width: 100%;
	padding: 32px 32px 64px 32px;
}

main .tabs {
  display: flex;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  background-color: #00afad;
  z-index: 100;
}

main .tabs a {
  display: flex;
  text-decoration: none;
  padding: 12px 15px;
  border: 0;
  color: #fff;
  font-weight: 500;
  font-size: 14px;
  flex-grow: 1;
  align-items: center;
  justify-content: center;
}

main .tabs a:hover {
  background-color: #4ddddc;
}

main .tabs a.active {
  color: #4a5361;
  background-color: #fff;
}

main .tab-content {
  display: none;
}

main .tab-content.active {
  display: block;
}

main .responsive-width-100 {
	display: flex;
	flex-direction: column;
	gap: 32px;
	padding: 32px 0px;
}


main .form-group {
	display: flex;
	flex-direction: column;
	gap: 4px;
	flex-grow: 1;
}

main .button {
	min-height: 30px;
	min-width: 100px;
	padding: 8px 16px;
	background-color: #00afad;
	color: #fff;
	text-align: center;
	border: 0px;
}

main .button:hover {
	cursor: pointer;
}

main .flex {
	display: flex;
}

main .column {
	flex-direction: column;
}

main .gap-32 {
	gap: 8px 32px;
}

main .gap32 {
	gap: 32px;
}

main .gap16 {
	gap: 16px 8px;
}

main .block-50 {
	display: flex;
	flex-direction: column;
	gap: 16px;
	width: 50%;
}

main .form-group label {
	font-size: 12px;
}

main .form-group input, main .form-group select, main .form-group textarea  {
	border: 0;
	background: #f1f1f161;
	color: #343a40;
	border-bottom: 1px solid #343a40;
	padding: 8px 16px;
	font-size: 15px;
	font-weight: 500px;
}

main .form-group input.red-border, main .form-group select.red-border, main .form-group textarea.red-border  { 
	border: 1px solid red;
}

main .form-group input::placeholder, main .form-group textarea::placeholder {
	color: #343a40;
	font-weight: 500px;
}

main .select-container {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

main .select-content {
	display: none;
}

footer {
	width: 100%;
	background-color: #343a40;
    color: #fff;
	display: flex;
    flex-direction: column;
    align-items: center;
	
}

footer .footer {
	width: 1050px;
	display: flex;
    flex-direction: column;
	padding: 16px 32px;
	font-size: 12px;
	letter-spacing: 0.5px;
}

h1, h2, h3, h4, h5 {
  color: #394352;
}

h1, h2 {
	text-align: center;

}

.form2 .insert table {
	min-width: 350px;
	border-collapse: collapse;
	margin-bottom: 20px;
	background-color: #fff;
	box-shadow: 0 2px 3px rgba(0, 0, 0, 0.1);
}
.form2 .insert th, .form2 .insert td {
	padding: 12px 15px;
	text-align: left;
	border-bottom: 1px solid #ddd;
}
.form2 .insert th {
	background-color: #f8f8f8;
	color: #333;
	font-weight: bold;
}
.form2 .insert tr:nth-child(even) {
	background-color: #f2f2f2;
}

.form2 .insert tr:nth-child(odd) {
	background-color: #f1f1f170;
}


.form2 .insert tr:hover {
	background-color: #e1e1e1;
}

@media screen and (max-width: 1050px) {
	main {
		width: 100%;
		flex-direction: column;
	}

	footer .footer {
		width: 100%;
		padding: 16px;
	}

	.contacts {
		clip-path: none;
		flex-direction: column;
		background-position: center;
		display: none;
	}

	.contacts .menu {
		padding: 16px;
		justify-content: center;
		flex-wrap: wrap;
	}

	.header {
		flex-direction: column;
		align-items: center;
	}
}

@media screen and (max-width: 768px) {
	body {
		padding: 0 16px;
	}

	main .block-50 {
		width: 100%;
	}

	main .flex {
		flex-direction: column;
	}

	main .gap-32,
	main .gap32,
	main .gap16 {
		gap: 16px;
	}

	main .tabs a {
		font-size: 13px;
		padding: 10px;
	}

	.message {
		width: 90%;
		left: 50%;
		right: auto;
		transform: translateX(-50%);
	}
}

@media screen and (max-width: 480px) {
	main .tabs {
		flex-direction: column;
	}

	main .tabs a {
		flex-grow: unset;
		justify-content: flex-start;
	}

	.contacts .menu {
		flex-direction: column;
		align-items: center;
		gap: 10px;
	}

	main .form-group input,
	main .form-group select,
	main .form-group textarea {
		font-size: 14px;
		padding: 8px;
	}

	footer .footer {
		font-size: 10px;
	}
}


#survey-container {
	display:flex;
	gap: 16px;
	flex-direction: column;
}

#survey-container h2 {
	text-align: left;
	font-size: 20px;
}

/* Base survey form */
.survey-form {
    width: 100%;
    padding: 2rem;
    border: 1px solid #ddd;
    border-radius: 12px;
    background-color: #fdfdfd;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
    font-family: 'Segoe UI', sans-serif;
}

/* Question block wrapper */
.question-block {
    margin-bottom: 1rem;
}

.question-block.label {
	margin-top: 2rem;
    margin-bottom: 0.5rem;
}

.question-block label {
    display: block;
    font-weight: 300;
    font-size: 1.0rem;
    margin-bottom: 0.6rem;
    color: #333;
}

/* Question label */
.question-block .label {
    display: block;
    font-weight: 500;
    font-size: 1.1rem;
    margin-bottom: 0.3rem;
    color: #333;
}

/* Select input styling */
.question-block select {
    width: 100%;
    padding: 0.5rem 0.75rem;
    border-radius: 8px;
    border: 1px solid #ccc;
    font-size: 1rem;
    background-color: #fff;
    transition: border-color 0.3s ease;
}

.question-block select:focus {
    outline: none;
    border-color: #2c7be5;
    box-shadow: 0 0 0 2px rgba(44, 123, 229, 0.2);
}

/* Radio button options */
.question-block div {
    display: flex;
    align-items: center;
    margin-bottom: 0.5rem;
    gap: 0.5rem;
}

/* Radio buttons and text inputs */
.question-block input[type="radio"] {
    accent-color: #2c7be5;
    transform: scale(1.2);
}

.question-block input[type="text"] {
    padding: 0.4rem 0.6rem;
    border: 1px solid #ccc;
    border-radius: 6px;
    font-size: 0.95rem;
    flex: 1;
	width: 100%;
}

.question-block input[type="text"]:disabled {
    background-color: #f3f3f3;
    cursor: not-allowed;
}

/* Submit button */
.survey-form .btn {
    background-color: #f2ae24;
    color: #fff;
    padding: 0.75rem 1.5rem;
    font-size: 1rem;
    font-weight: bold;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    transition: background-color 0.3s ease;
}

.survey-form .btn:hover {
    background-color: #1a5fc1;
}

@media (max-width: 600px) {
    .survey-form {
        padding: 1.2rem;
    }
    .question-block label {
        font-size: 1rem;
    }
}

.star-rating-wrapper {
    display: flex;
    gap: 4px;
    font-size: 24px;
    cursor: pointer;
}
.star-rating-wrapper .star {
    user-select: none;
	font-size: 30px;
	color: #f2ae24;
}
