@font-face {
  font-family: 'Fontawesome';
  font-style: normal;
  font-weight: 400;
  font-display: block;
  src: url("//thedevelopers.blob.core.windows.net/fonts-fa-pro-6-3-0/fa-regular-400.woff2") format("woff2"), url("//thedevelopers.blob.core.windows.net/fonts-fa-pro-6-3-0/fa-regular-400.ttf") format("truetype");
}

:root {
	--c-text: #404040;
	--c-input-text: #404040;
	--c-input-border: #9fc8df;
	--c-input-invalid-border: #e85252;
}

html { font-family: Proxima-Nova, Arial, Helvetica, sans-serif; font-size: 14px; }

@media (min-width: 768px) {
	html { font-size: 16px; }
}

html { position: relative; min-height: 100%; }
body { margin: 0; padding: 0; background: #fff; color: var(--c-text); }

input, textarea, select { font-family: Proxima-Nova, Arial, Helvetica, sans-serif; }
a { text-decoration: none; line-height: 1; }
h1 { margin: 0; font-size: 56px; font-weight: 700; line-height: 1; }
h2 { margin: 30px 0 0; font-size: 40px; font-weight: 700; line-height: 1; }
h2 .weak { color: #a1a1a1; }
p { margin: 10px 0; font-size: 24px; line-height: 1; }

header {}

header .bar { position: absolute; width: 100%; height: 42px; line-height: 42px; background: #6F9FBD80; }
header .bar a { padding: 8px 5px; color: #fff; }
header .bar a.login { float: right; }
header .bar .icon { margin: 0 5px; vertical-align: middle; font-family: Fontawesome; font-size: 24px; }

header .menu { display: none; }
header .menu.show { display: block; box-sizing: border-box; position: absolute; width: 100%; padding: 10px; background: #6f9fbdf7; color: #fff; font-size: 20px; }
header .menu a {}
header .menu .icon { vertical-align: middle; font-family: Fontawesome; }
header .menu .close { color: #fff; }
header .menu .close .icon { margin-right: 8px; font-size: 25px; }
header .menu .content { margin: 20px auto; width: 100%; max-width: 460px; }
header .menu .content img { display: block; width: 460px; max-width: 100%; }
header .menu .content .separator { margin: 10px 30px; height: 1px; background: #fff; }
header .menu .content a { display: block; margin: 0 60px; line-height: 35px; color: #fff; }
header .menu .content a .icon { margin-left: 8px; font-size: 22px; }

.top { aspect-ratio: 2.5; padding: 80px 50px 50px; background-color: #eee; background-size: cover; background-position: 70%; color: #fff; }
.top img { width: 500px; max-width: 100%; }
.top .block { padding: 60px 0 20px 30px; text-shadow: 0 0 4px #00000060; }
.top p { font-size: 24px; line-height: 1; }
.top .buttons { margin: 30px 0; max-width: 800px; display: flex; flex-wrap: wrap; gap: 30px;}
.top .buttons a { width: 290px; height: 50px; background: #ccc; line-height: 50px; text-align: center; font-size: 24px; color: #404040; }
.top .buttons .warranties { background: #f6f6f6; }
.top .buttons .report { background: #f9cb70; }

.main { padding: 40px 80px; }
.main h2 { max-width: 800px; }
.main p { max-width: 800px; }

.main .cooperations { margin: 20px 0 ; display: flex; align-items: center; gap: 20px; flex-wrap: wrap; }
.main .cooperations img {}

.panel { background: #f3f3f3; display: flow-root; }
.panel .product { display: grid; }
.panel .product > * { background: #fff; padding: 30px; }
.panel .product .image * { grid-row: 1; border-radius: 50%; }
.panel .product .image div { background: #d6e702; width: 340px; height: 340px; text-align: center; line-height: 340px; color: #fff; font-size: 160px; font-weight: 700; }
.panel .product .text { grid-row: 1; }
.panel .product .text h2 { margin: 30px 0 0; }
.panel .product .text p { margin: 20px 0; }
.panel .product .text a { font-size: 24px; color: #6f9fbd; }
.panel .product:nth-child(2n+1) { margin: 40px 40px 40px 0; grid-template-columns: 1fr 400px; }
.panel .product:nth-child(2n+1) .text { grid-column: 1; padding-left: 200px; }
.panel .product:nth-child(2n+1) .image { grid-column: 2; border-radius: 0 200px 200px 0; }
.panel .product:nth-child(2n) { margin: 40px 0 40px 40px; grid-template-columns: 400px 1fr; }
.panel .product:nth-child(2n) .text { grid-column: 2; padding-right: 200px; }
.panel .product:nth-child(2n) .image { grid-column: 1; border-radius: 200px 0 0 200px; }
.panel .product .pdf { display: grid; grid-template-columns: 30px 1fr; grid-template-rows: 22px 25px; }
.panel .product .pdf .icon { grid-row: 1/3; margin-bottom: 11px; font-family: Fontawesome; font-size: 24px; color: #d30e0e; align-self: center; }
.panel .product .pdf .name { font-size: 16px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.panel .product .pdf .info { font-size: 13px; color: var(--c-text); }

.Form {}
.Form .item { position: relative; margin: 1.11em 0 0; font-size: 18px; overflow: hidden; transition-property: margin,height; transition-duration: 0.1s; }
.Form .item .label { position: absolute; left: 1.11em; top: 1em; color: #808080; pointer-events: none; transition-property: left,top,font-size; transition-duration: 0.05s; }
.Form .item.moved .label { font-size: 0.78em; left: 1.5em; top: 0.5em; }
.Form .item.invalid .label { color: #e64040; }
.Form .item .select-label { display: none; }
.Form .item.moved .select-label { display: block; }
.Form .item select { border: 1px solid #909090; border-radius: 0.56em; width: 100%; height: 3.22em; font-size: 1em; padding: 0 1.11em; outline: none; color: #808080; appearance: none; }
.Form .item .arrow { position: absolute; right: 1.11em; top: 1.11em; font-family: Fontawesome; color: var(--c-input-text); pointer-events: none; }
.Form .item select:focus { border: 0.167em solid var(--c-input-border); padding: 0 1em; }
.Form .item.moved select { padding: 1.39em 1.11em 0.5em; }
.Form .item.invalid select { border-color: var(--c-input-invalid-border); color: #e64040; }
.Form .item input[type=text] { box-sizing: border-box; border: 1px solid #909090; border-radius: 0.56em; width: 100%; height: 3.22em; font-size: 1em; padding: 1.33em 1.11em 0.44em; color: var(--c-input-text); outline: none; }
.Form .item input[type=text]:focus { border: 0.167em solid var(--c-input-border); padding: 1.22em 1em 0.33em; }
.Form .item.invalid input[type=text] { border-color: var(--c-input-invalid-border); }
.Form .item textarea { box-sizing: border-box; display: block; border: 1px solid #909090; border-radius: 0.56em; width: 100%; height: 11.11em; font-size: 1em; padding: 1.39em 1.11em 0.44em; color: var(--c-input-text); outline: none; resize: none; }
.Form .item textarea:focus { border: 0.167em solid var(--c-input-border); padding: 1.22em 1em 0.33em; }
.Form .item.invalid textarea { border-color: var(--c-input-invalid-border); }
.Form .item.radio { display: block; }
.Form .item.radio input { margin: 0 10px 0 0; width: 25px; height: 25px; vertical-align: -5px; }
.Form .item.radio span {}
.Form .item.radio {}
.Form .item-separator { height:20px; }
.Form .item .message { display: none; position: absolute; right: 0.7em; top: 0.5em; font-size: 0.78em; font-weight: 600; color: #e85252; }
.Form .item.invalid .message { display: block; }

.Form .item.calendar { border: 1px solid #909090; border-radius: 0.56em; padding: 2px; }
.Form .item.calendar input { border: none; }
.Form .item.calendar input:focus { border: none; padding: 1.33em 1.11em 0.44em; }
.Form .item.calendar:has(input:focus) { border: 0.167em solid var(--c-input-border); padding: 0; }
.Form .item.calendar:has(input:focus) .label { left: 1.35em; top: 0.3em; }
.Form .item .calendar { margin: 5px 15px 20px; width: 250px; }
.Form .item .calendar .month { margin: 5px; display: grid; grid-template-columns: 30px 1fr 30px; grid-gap: 5px; }
.Form .item .calendar .days { margin: 5px; display: grid; grid-template-columns: repeat(7,30px); grid-gap: 5px; }
.Form .item .calendar span { text-align: center; line-height: 30px; }
.Form .item .calendar .days span { line-height: 20px; font-size: 14px; color: #808080; }
.Form .item .calendar a { border-radius: 6px; background: #f1f1f1; text-align: center; line-height: 30px; color: var(--c-input-text); }
.Form .item .calendar .days span:nth-child(7n) { color: #b55; }
.Form .item .calendar .days a:nth-child(7n) { color: #933; }
.Form .item .calendar .days a.active { background: #3e97ff; color: #fff; }

.Report .steps { margin-bottom: 10px; display: grid; grid-template-columns: 50px 50px 50px 50px; grid-template-rows: 50px; grid-gap: 20px; justify-content: end; }
.Report .steps span { position: relative; border-radius: 50%; background: #f1f1f1; color: #fff; font-size: 24px; font-weight: 600; text-align: center; align-content: center; }
.Report .steps span:nth-child(1n+2):after { content: ''; position: absolute; left: -20px; top: 22px; width: 20px; height: 7px; background: #eee; }
.Report .steps span.active { background: #3e97ff; }
.Report .steps span:nth-child(1n+2).active:after { background: #3e97ff; }

.Report .step { display: none; margin-bottom: 50px; }
.Report .step.step1 { display: block; }

.Report .step h2 {}
.Report .step h2 .regno { color: #a1a1a1; }
.Report .step p { margin: 20px 0; font-size: 24px; line-height: 1.16; }

.Report .cols { display: flex; flex-wrap: wrap; gap: 40px; }
.Report .cols > div { width: 300px; flex-grow: 1; }

.Form .buttons { margin: 20px 0; display: flex; justify-content: flex-end; gap: 10px; }
.Form .buttons a { border-radius: 6px; min-width: 100px; height: 58px; padding: 0 20px; background: #3e97ff; color: #fff; text-align: center; align-content: center; font-size: 14px; font-weight: 600; }
.Form .buttons input { border-radius: 6px; border: none; min-width: 100px; height: 58px; padding: 0 20px; background: #3e97ff; color: #fff; text-align: center; align-content: center; font-size: 14px; font-weight: 600; }

.Report .step .buttons { margin: 0; }
.Report .step .buttons a {}
.Report .step .buttons a.back { background: #f1f1f2; color: #a1a5b7; }
.Report .step .buttons a.disabled { background: #f1f1f2; color: #999; }
.Report .step .buttons a.final { flex-grow: 1; }
.Report .step .form-message { margin-top: 20px; visibility: hidden; height: 2em; text-align: right; line-height: 2; color: #e64040; font-weight: 600; }
.Report .step .form-message.invalid { visibility: visible; }

.Report .item .input-button { position: absolute; right: 9px; top: 9px; border-radius: 6px; width: 80px; height: 40px; background: #3e97ff; color: #fff; text-align: center; line-height: 40px; }

.Report a { font-size: 16px; }

.Report .prop { margin: 20px; font-size: 24px; font-weight: 600; }
.Report .prop > div:not(.car):not(.description) { display: grid; grid-template-columns: 150px 1fr; }
.Report .prop .car { margin: 10px 0; }
.Report .prop label { color: #a6a6a6; }
.Report .prop span { }

.Report p.report-description { margin: 0 0 30px 20px; }

.Report .step1 .response { display: none; }

.Report .files { margin: 20px 0 0; }
.Report .files > div { display: grid; grid-template-columns: 30px 1fr 30px; line-height: 37px }
.Report .files div .icon { font-family: Fontawesome; font-size: 28px; color: #d30e0e; }
.Report .files div .name { font-size: 24px; font-weight: 600; color: #6f9fbd; }
.Report .files div a { font-family: Fontawesome; font-size: 28px; color: #e64040; cursor: pointer; }
.Report .files.summary a { display: none; }
.Report .files.summary:not(:has(div)):after { content: 'Inga dokument'; font-size: 24px; color: #a6a6a6; }

.Report [name=UploadFrame] { display: none; }
.Report .UploadForm { display: none; }

footer { padding: 40px; background: #6f9fbd; color: #fff; font-size: 20px; }
footer img { width: 500px; max-width: 100%; }
footer h2 { margin: 30px 0 10px; font-size: 24px; font-weight: 600; }
footer a { display: block; line-height: 1.4; color: #fff; }
footer .columns { margin: 0 60px; display: flex; flex-wrap: wrap; gap: 20px; }
footer .columns > div { width: 210px; flex-grow: 1; }
footer .times { display: grid; grid-template-columns: 90px 1fr; }

@media (max-width: 1000px) {

	.panel .product:nth-child(2n+1) { margin: 30px 30px 30px 0; grid-template-columns: 1fr 230px; }
	.panel .product:nth-child(2n+1) .text { padding-left: 60px; }
	.panel .product:nth-child(2n+1) .image { border-radius: 0 120px 120px 0; }
	.panel .product:nth-child(2n) { margin: 30px 0 30px 30px; grid-template-columns: 230px 1fr; }
	.panel .product:nth-child(2n) .text { padding-right: 60px; }
	.panel .product:nth-child(2n) .image { border-radius: 120px 0 0 120px; }
	.panel .product .image * { width: 170px; height: 170px; }
	.panel .product .image div { width: 170px; height: 170px; line-height: 170px; font-size: 90px; }

}

@media (max-width: 700px) {

	.top { padding: 80px 25px 25px; }
	.top .block { padding: 30px 0 10px 15px; }
	.top p { font-size: 18px; }
	.top .buttons a { width: 200px; height: 40px; line-height: 40px; font-size: 18px; }
	h1 { font-size: 42px; }
	.main { padding: 20px 40px; }
	h2 { font-size: 30px; }
	p { margin: 10px 0; font-size: 18px; }
	footer { padding: 30px; font-size: 15px; }
	footer h2 { margin: 20px 0 10px; font-size: 18px; }
	footer .columns { margin: 0 20px; gap: 10px; }

	.main .cooperations img { max-width: 200px; }

	.panel .product:nth-child(2n+1) { margin: 30px 30px 30px 0; grid-template-columns: 1fr 115px; }
	.panel .product:nth-child(2n+1) .text { padding-left: 30px; }
	.panel .product:nth-child(2n+1) .image { padding-right: 20px; border-radius: 0 60px 60px 0; }
	.panel .product:nth-child(2n) { margin: 30px 0 30px 30px; grid-template-columns: 115px 1fr; }
	.panel .product:nth-child(2n) .text { padding-right: 30px; }
	.panel .product:nth-child(2n) .image { padding-left: 20px; border-radius: 60px 0 0 60px; }
	.panel .product .image * { width: 85px; height: 85px; }
	.panel .product .image div { width: 85px; height: 85px; line-height: 85px; font-size: 50px; }

	.panel .product > * { padding: 20px 10px; }
	.panel .product .text h2 { margin: 0; }
	.panel .product .text p { margin: 10px 0; }
	.panel .product .text a { font-size: 18px; }

	.Report .step p { font-size: 18px; }
	.Report .prop { font-size: 18px; }
	.Report .files.summary:not(:has(div)):after { font-size: 18px; }

}

