/* CSS Reset by Josh Comeau https://www.joshwcomeau.com/css/custom-css-reset/ */ *, *::before, *::after { box-sizing: border-box; } * { margin: 0; } body { line-height: 1.5; -webkit-font-smoothing: antialiased; } img, picture, video, canvas, svg { display: block; max-width: 100%; } input, button, textarea, select { font: inherit; } p, h1, h2, h3, h4, h5, h6 { overflow-wrap: break-word; } #root, #__next { isolation: isolate; } /* End of CSS Reset */ *{ font-size: 1.04em; letter-spacing: 0.05em; font-family: url="font/Gidole-Regular.ttf"; } :root { --ve-light-violett: #A458AE; /* <= safe for WCAG AA */ /* original: #aa69b5; */ --ve-heavy-violett: #5d2169; --ve-vanilla: #faefdd; --ve-vanilla-heavy: #e4cba1; } @font-face { font-family: "gidole"; src: url("../font/Gidole-Regular.ttf"); } body { width: 100%; height: 100vh; background-color: var(--ve-vanilla); font-family: "gidole", sans-serif; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='380' height='380' viewBox='0 0 800 800'%3E%3Cg fill='none' stroke='%23E4CBA1' stroke-width='1'%3E%3Cpath d='M769 229L1037 260.9M927 880L731 737 520 660 309 538 40 599 295 764 126.5 879.5 40 599-197 493 102 382-31 229 126.5 79.5-69-63'/%3E%3Cpath d='M-31 229L237 261 390 382 603 493 308.5 537.5 101.5 381.5M370 905L295 764'/%3E%3Cpath d='M520 660L578 842 731 737 840 599 603 493 520 660 295 764 309 538 390 382 539 269 769 229 577.5 41.5 370 105 295 -36 126.5 79.5 237 261 102 382 40 599 -69 737 127 880'/%3E%3Cpath d='M520-140L578.5 42.5 731-63M603 493L539 269 237 261 370 105M902 382L539 269M390 382L102 382'/%3E%3Cpath d='M-222 42L126.5 79.5 370 105 539 269 577.5 41.5 927 80 769 229 902 382 603 493 731 737M295-36L577.5 41.5M578 842L295 764M40-201L127 80M102 382L-261 269'/%3E%3C/g%3E%3Cg fill='%2398886B'%3E%3Ccircle cx='769' cy='229' r='5'/%3E%3Ccircle cx='539' cy='269' r='5'/%3E%3Ccircle cx='603' cy='493' r='5'/%3E%3Ccircle cx='731' cy='737' r='5'/%3E%3Ccircle cx='520' cy='660' r='5'/%3E%3Ccircle cx='309' cy='538' r='5'/%3E%3Ccircle cx='295' cy='764' r='5'/%3E%3Ccircle cx='40' cy='599' r='5'/%3E%3Ccircle cx='102' cy='382' r='5'/%3E%3Ccircle cx='127' cy='80' r='5'/%3E%3Ccircle cx='370' cy='105' r='5'/%3E%3Ccircle cx='578' cy='42' r='5'/%3E%3Ccircle cx='237' cy='261' r='5'/%3E%3Ccircle cx='390' cy='382' r='5'/%3E%3C/g%3E%3C/svg%3E"); background-attachment: fixed; } .skiplink { border: 0; clip: rect(1px,1px,1px,1px); clip-path: inset(50%); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute !important; width: 1px; word-wrap: normal !important; } .skiplink:focus { background-color: #eee; clip: auto !important; clip-path: none; color: #444; display: block; font-size: 1em; height: auto; left: 5px; line-height: normal; padding: 15px 23px 14px; text-decoration: none; top: 5px; width: auto; z-index: 100000; } #outerwrapper { max-width: 97%; margin: auto; border: 1px solid var(--ve-heavy-violett); } header { height: 100vh; max-width: 100%; margin: auto; padding: 3rem; z-index: 1; background: url(../img/cover-image.jpg) top center no-repeat; background-size: 100%; object-fit: cover; } header h1, header h4 { font-family: "gidole", sans-serif; font-weight: 700; color: var(--ve-heavy-violett); text-wrap: balance; } header h1 { font-size: calc(3vw + 1.4rem); margin-bottom: 0.7em; } header h4 { font-size: calc(2vw + 1.1rem); } header p { margin-left: 13vw; word-wrap: normal; } header p span { display: block; width: 86%; font-size: calc(0.5vw + 1rem); background-color: var(--ve-heavy-violett); color: var(--ve-vanilla); padding: 0.5rem; } header p span strong { color: var(--ve-vanilla); } header img { display: block; height: calc(7vw + 1.3rem); padding-top: 0 !important; margin-top: -1rem !important; } #header-sm { width: 100%; height: 200px; background: url(../img/cover-image_sm.jpg) center center no-repeat; } #header-sm img#logo_sm { display: inline; height: 6.5rem; margin-top: 1rem; margin-left: 22rem; padding-top: 0.5rem; } #header-sm h4 { display: inline; font-family: "gidole", sans-serif; font-size: calc(1vw + 1.1rem); font-weight: 700; color: var(--ve-heavy-violett); text-wrap: balance; } /* START Hamburger Menu */ #menu__toggle { opacity: 0; } #menu__toggle:checked + .menu__btn > span { transform: rotate(45deg); } #menu__toggle:checked + .menu__btn > span::before { top: 0; transform: rotate(0deg); } #menu__toggle:checked + .menu__btn > span::after { top: 0; transform: rotate(90deg); } #menu__toggle:checked ~ .menu__box { left: 0 !important; } .menu__btn { position: fixed; top: 50px; left: 3.5%; width: 40px; height: 50px; cursor: pointer; z-index: 1; } .menu__btn > span, .menu__btn > span::before, .menu__btn > span::after { display: block; position: absolute; width: 100%; height: 2px; background-color: var(--ve-heavy-violett); transition-duration: .3s; } .menu__btn > span::before { content: ''; top: -8px; } .menu__btn > span::after { content: ''; top: 8px; } .menu__box { display: block; position: fixed; top: 0; left: -100%; width: 300px; height: 100%; margin: 0; padding: 110px 35px; list-style: none; background-color: var(--ve-light-violett); box-shadow: 2px 2px 6px rgba(0, 0, 0, .4); transition-duration: .3s; } .menu__item { display: block; padding: 12px 24px; color: var(--ve-vanilla); font-family: "gidole", sans-serif; font-size: 20px; font-weight: 600; text-decoration: none; transition-duration: .3s; } .menu__item:hover { background-color: var(--ve-heavy-violett); color: var(--ve-vanilla); } /* END Hamburger Menu */ aside { background-color: var(--ve-light-violett); /* min-width: 360px; */ margin-bottom: 0.5rem; margin-right: 0.3rem; position: sticky; top: 5.5rem; } aside > nav { padding: 0.5rem; margin-top: -3.75em; background-color: var(--ve-light-violett); } aside > nav ul, footer ul { padding: 0; } aside > nav ul li, footer ul li { list-style-type: none; } aside > nav ul li a:link, aside > nav ul li a:visited { display: block; text-decoration: none; color: white; border: 7px solid var(--ve-light-violett); padding: 0.5rem; } aside > nav ul li a:hover, aside > nav ul li a:focus { border: 7px solid var(--ve-heavy-violett); transform: translate(0.15em, 0.15em); transition: transform 0.3s ease-out; } aside > nav ul li a.active { border: 7px solid var(--ve-vanilla); } .subnavi { margin-left: 2rem; font-size: 1.3rem; } .content { padding: 2rem; background-color: var(--ve-light-violett); } .content hr { margin: 4rem 0; clear: both; } .content hr.hidden { position: relative; left: -10000px; margin: 2rem 0; } .content img { margin: 0.5rem 0 1rem 0; } .content img#baugruppe_tranz, .content img#baugruppe_ex { background-color: var(--ve-vanilla); } .content h2, .content h3, .content h4, .content h5, .content h6, .content > #vorteile h2, .content > section h2, .content > section h3 { font-family: "gidole", sans-serif; margin-bottom: 1rem; } .content h2, .content h3, .content > #vorteile h2, .content > section h2, .content > section h3, .accordion ul li h3 { font-size: calc(1.5vw + 1.4rem); } .content > #vorteile h4 { margin-top: 2rem; font-size: calc(1.1vw + 1.1rem); } .content section { margin-bottom: 5rem; } .content #imp section h2 { margin: 5rem 0 0.5rem 0; } .content > #vorteile, .content .accordion { background-color: var(--ve-vanilla); color: var(--ve-heavy-violett); margin-top: 5rem; padding: 2rem; border: 0.25rem var(--ve-heavy-violett) dashed; } .content .violett { background-color: var(--ve-light-violett); color: var(--ve-vanilla); padding: 0 !important; border: none !important; } .content > ul#vorteile li, .content ul#parts li, .content .prod_info ul li { margin-left: -1rem; } .content ul#parts li a:link, .content ul#parts li a:visited { color: var(--ve-vanilla); text-decoration: none; } .content dl#vorteile_parts { margin-bottom: 3rem; } .content dl#vorteile_parts dt { margin-top: 3rem; font-weight: 700; } .content dl#vorteile_parts dd { margin: 1rem 0; } .content img.prod_pic { float: left; width: 62%; margin-right: 0.5rem; } .content .prod_info { margin-top: 3rem; padding: 0.5rem; border: 1px solid var(--ve-vanilla); } .content p#gruender-edgar span { font-size: calc(3vw + 1.4rem); } #bestellung, #eg { background-color: var(--ve-vanilla); color: var(--ve-heavy-violett); padding: 1rem 0.5rem 0 0.5rem; } #bestellung a:link, #bestellung a:visited { color: var(--ve-heavy-violett); } #newsgrid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.5rem; } #newsgrid > article.newsitem:first-child { grid-column: 1 / 3; background-color: var(--ve-vanilla); color: var(--ve-heavy-violett); margin-bottom: 1.5rem; padding: 2rem; border: 0.25rem var(--ve-heavy-violett) dashed; } #newsgrid > article.newsitem { padding: 0.5rem; border: 1px solid var(--ve-heavy-violett); } #newsgrid > article.newsitem h3 { font-size: calc(1vw + 1.1rem); } /* Now, onto the styling of the read more component .read-more { /* You can update this variable directly in the html by adding a style property to the .read-more element --line-clamp: 3; display: flex; flex-direction: column; align-items: start; margin-bottom: 5rem; } .read-more__text { display: -webkit-box; -webkit-line-clamp: var(--line-clamp); -webkit-box-orient: vertical; overflow: hidden; } .read-more__checkbox { clip: rect(0 0 0 0); clip-path: inset(100%); height: 1px; overflow: hidden; position: absolute; white-space: nowrap; width: 1px; } .read-more__checkbox ~ .read-more__label { cursor: pointer; font-size: 1em; font-weight: 700; text-decoration: underline; padding-top: 0.5rem; } /* Don't forget focus and hover styles for accessibility! .read-more__checkbox:focus ~ .read-more__label { box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.5); } .read-more__checkbox:hover ~ .read-more__label { text-decoration: none; } .read-more__checkbox ~ .read-more__label::before { content: attr(data-read-more); } .read-more__checkbox:checked ~ .read-more__label::before { content: attr(data-read-less); } .read-more__checkbox:checked ~ .read-more__text { --line-clamp: none; -webkit-line-clamp: var(--line-clamp); } End read more component styles */ /* article { margin-bottom: 3rem; position: relative; *zoom: 1; } article:before, article:after { content: ""; display: table; } article:after { clear: both } article figure { float: left; width: 32.5%; } article section:first-of-type { float: right; width: 62.5%; } article section:last-of-type { display: none; visibility: hidden; } section { -webkit-transition: .125s linear; -moz-transition: .125s linear; -ms-transition: .125s linear; -o-transition: .125s linear; transition: .125s linear; } input[type=checkbox] { border: 0; clip: rect(0 0 0 0); height: 1px; width: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; } [for="read_more_mainbed"] { position: absolute; bottom: -3rem; left: 0; width: 100%; text-align: center; padding: .65rem; box-shadow: inset 1px 1px rgba(0, 0, 0, 0.1), inset -1px -1px rgba(0, 0, 0, 0.1); } [for="read_more_kidsbed"] { position: absolute; bottom: -3rem; left: 0; width: 100%; text-align: center; padding: .65rem; box-shadow: inset 1px 1px rgba(0, 0, 0, 0.1), inset -1px -1px rgba(0, 0, 0, 0.1); } [for="read_more_storage"] { position: absolute; bottom: -3rem; left: 0; width: 100%; text-align: center; padding: .65rem; box-shadow: inset 1px 1px rgba(0, 0, 0, 0.1), inset -1px -1px rgba(0, 0, 0, 0.1); } [for="read_more_kitchen"] { position: absolute; bottom: -3rem; left: 0; width: 100%; text-align: center; padding: .65rem; box-shadow: inset 1px 1px rgba(0, 0, 0, 0.1), inset -1px -1px rgba(0, 0, 0, 0.1); } [for="read_more_techspace"] { position: absolute; bottom: -3rem; left: 0; width: 100%; text-align: center; padding: .65rem; box-shadow: inset 1px 1px rgba(0, 0, 0, 0.1), inset -1px -1px rgba(0, 0, 0, 0.1); } [for="read_more_mainbed"]:hover { background: rgba(0,0,0,.5); color: rgb(255,255,255); } [for="read_more_kidsbed"]:hover { background: rgba(0,0,0,.5); color: rgb(255,255,255); } [for="read_more_storage"]:hover { background: rgba(0,0,0,.5); color: rgb(255,255,255); } [for="read_more_kitchen"]:hover { background: rgba(0,0,0,.5); color: rgb(255,255,255); } [for="read_more_techspace"]:hover { background: rgba(0,0,0,.5); color: rgb(255,255,255); } [for="read_more_mainbed"] span:last-of-type { display: none; visibility: hidden; } [for="read_more_kidsbed"] span:last-of-type { display: none; visibility: hidden; } [for="read_more_storage"] span:last-of-type { display: none; visibility: hidden; } [for="read_more_kitchen"] span:last-of-type { display: none; visibility: hidden; } [for="read_more_techspace"] span:last-of-type { display: none; visibility: hidden; } input[type=checkbox]:checked ~ section { display: block; visibility: visible; width: 100%; } input[type=checkbox]:checked ~ figure { width: 100% } input[type=checkbox]:checked ~ [for="read_more_mainbed"] span:first-of-type { display: none; visibility: hidden; } input[type=checkbox]:checked ~ [for="read_more_kidsbed"] span:first-of-type { display: none; visibility: hidden; } input[type=checkbox]:checked ~ [for="read_more_storage"] span:first-of-type { display: none; visibility: hidden; } input[type=checkbox]:checked ~ [for="read_more_kitchen"] span:first-of-type { display: none; visibility: hidden; } input[type=checkbox]:checked ~ [for="read_more_techspace"] span:first-of-type { display: none; visibility: hidden; } input[type=checkbox]:checked ~ [for="read_more_mainbed"] span:last-of-type { display: block; visibility: visible; } input[type=checkbox]:checked ~ [for="read_more_kidsbed"] span:last-of-type { display: block; visibility: visible; } input[type=checkbox]:checked ~ [for="read_more_storage"] span:last-of-type { display: block; visibility: visible; } input[type=checkbox]:checked ~ [for="read_more_kitchen"] span:last-of-type { display: block; visibility: visible; } input[type=checkbox]:checked ~ [for="read_more_techspace"] span:last-of-type { display: block; visibility: visible; } */ .main_with_sidebar { display: flex; flex-wrap: wrap; align-items: start; gap: 0.2rem; } .main_with_sidebar > :first-child { flex-basis: 37%; flex-grow: 1; } main { flex-basis: 62%; flex-grow: 9999; color: var(--ve-vanilla); } .wrapper { width: 75%; max-width: 1326px; padding: 0.5rem; margin: auto; } #contact { width: 100%; margin-top: 0.5rem; padding: 2rem; color: var(--ve-vanilla); background-color: var(--ve-light-violett); } #contact img.icon { display: inline; float: left; margin-right: 0.5rem; padding: 0.2rem 0; width: 2rem; } #contact h3 { font-size: calc(1.5vw + 1.3rem); margin-bottom: 1rem; } #contact p a:link, #contact p a:visited, .content p a:link, .content p a:visited { color: var(--ve-vanilla); } address { font-style: normal; } footer { height: 7rem; line-height: 7rem; text-align: center; color: var(--ve-vanilla); background-color: var(--ve-heavy-violett); } footer a:link, footer a:visited { display: inline; text-decoration: none; color: var(--ve-vanilla); } footer a:hover, footer a:focus { text-decoration: underline; } /* media-queries for small screen > 767px viewport */ @media screen and (max-width: 767px) { header { padding-right: 0 !important; } header h4 { margin-top: 1rem !important; margin-bottom: 2rem; font-size: calc(1.5vw + 1.0rem); } header p { margin-left: 0 !important; } header img { margin-bottom: 0 !important; } #header-sm img#logo_sm { display:inline !important; margin: 1rem 0 0 3rem; } #header-sm h4 { display:inline !important; font-family: "gidole", sans-serif; font-size: calc(2vw + 1.1rem); font-weight: 700; color: var(--ve-heavy-violett); text-wrap: balance; } .content { padding: 0.5rem !important; margin-right: 0 !important; } .content h2, .content h3, .content > #vorteile h2, .content > section h2, .content > section h3 { font-size: calc(1.3vw + 1.2rem) !important; } .content > #vorteile { margin-top: 3rem !important; padding: 0.5rem !important; } .content hr { margin: 2rem 0 !important; clear: both; } #newsgrid { display: grid; grid-template-columns: repeat(1, 1fr); gap: 0.5rem; } #newsgrid > article.newsitem:first-child { grid-column: 1 / 2; } .wrapper { width: 86%; margin-left: 2.6rem !important; } #contact { font-size: 1.02rem; padding: 0.5rem !important; } #contact img.icon { width: 0.7rem !important; } footer { height: auto !important; } } /* media-queries for large screen > 1199px viewport */ @media screen and (max-width: 1199px) { aside > #sidebar-menu { display: none; } .hamburger-menu { display: inline; } .main_with_sidebar { display:block; width: 100%; margin: auto; } } @media screen and (min-width: 1200px) { .hamburger-menu { display: none; } }