@charset "UTF-8";
@import url("hero-styles.css");

/* =============================================
   BASE
   ============================================= */

*, *::before, *::after {
	box-sizing: border-box;
	margin: 0;
}

body, html {
	height: 100%;
	margin: 0;
	font-family: "Poppins", sans-serif;
}

h1 {
	font-family: "Mulish", sans-serif;
	font-weight: 600;
	font-style: normal;
}

h2 {
	font-family: "Mulish", sans-serif;
	font-optical-sizing: auto;
	font-weight: 800;
	font-style: normal;
}

p {
	font-size: 0.85em;
	text-align: justify;
}

label {
	margin-left: 12px;
}


/* =============================================
   BACKGROUNDS
   ============================================= */

.bg-home,
.bg-about {
	background-image: url("../img/bg-all.svg");
}

.bg-color,
.bg-doodles {
	background-image: url("../img/bg-doodles.svg");
}

.bg-theme {
	background-image: url("../img/bg-theme.svg");
}

.bg-quickies {
	background-image: url("../img/bg-none.svg");
}

.bg-contact {
	background-image: url("../img/bg-contact.svg");
}

.bg-404 {
	background-image: url("../img/bg-404.svg");
}

/* bg-bw heeft geen achtergrondafbeelding (uitgecommentarieerd) */
.bg-bw,
.bg-home,
.bg-about,
.bg-color,
.bg-doodles,
.bg-theme,
.bg-quickies,
.bg-contact,
.bg-404 {
	width: 100vw;
	height: auto;
	background-repeat: no-repeat;
}


/* =============================================
   LAYOUT – HEADER & FOOTER
   ============================================= */

header {
	width: 100%;
	height: 180px;
	display: grid;
	grid-template-columns: 1fr minmax(auto, 1200px) 1fr;
	grid-template-areas: ". content .";
	align-items: center;
	justify-items: center;
	background-color: #ffffff;
	background-image: url("../img/header-180-theme-doodle.png");
	background-position: center;
	padding: 0 25px;
}

header h1 {
	font-family: "Titan One", sans-serif;
	font-weight: 300;
	font-style: normal;
	font-size: 4em;
	color: white;
	text-shadow: 4px 4px hsla(207, 100%, 16%, 0.70);
}

header h3 {
	font-family: "Titan One", sans-serif;
	font-weight: 100;
	font-size: 1.7em;
	color: white;
	padding-bottom: 15px;
	text-shadow: 4px 4px hsla(207, 100%, 16%, 0.70);
}

.logo {
	grid-area: content;
	font-weight: 400;
	color: white;
	justify-self: right;
	text-shadow: 2px 2px hsla(207, 100%, 16%, 0.70);
}

.gifjelogo {
	width: 600px;
}

.subject {
	font-family: "Delicious Handrawn", cursive;
	font-weight: 400;
	font-style: normal;
	font-size: 3.5em;
}

div.transbox {
	font-family: Impact, "Franklin Gothic Bold", "Arial Black", sans-serif;
	font-size: 2em;
	font-weight: 400;
	color: rgba(68, 123, 231, 1);
	background-color: rgba(255, 255, 255, 0.4);
	-webkit-backdrop-filter: blur(5px);
	backdrop-filter: blur(5px);
	padding: 10px 20px;
	margin: 30px;
	border-radius: 8px;
}

.footer {
	left: 0;
	bottom: 0;
	width: 100%;
	background-color: #231f17;
	color: #fff;
	padding: 20px 0;
	text-align: center;
}

.footer h2,
.footer p,
.footer-bottom,
.footer-section p {
	color: #d1b05c;
}

.footer-content {
	display: flex;
	justify-content: space-around;
	margin: 15px;
	flex-wrap: wrap;
}

.footer-section {
	flex: 1;
	padding: 10px;
	margin-bottom: 30px;
	min-width: 200px;
}

.footer-section h2 {
	margin-bottom: 15px;
	font-family: "Poppins", sans-serif;
	font-size: 1.2em;
}

.footer-section ul {
	list-style: none;
	padding: 0;
	margin-bottom: 10px;
}

.footer-section ul li {
	display: inline;
	padding: 10px;
	margin-bottom: 10px;
}

.footer-section ul li a {
	color: #fff;
	text-decoration: none;
}

.footer-bottom {
	margin-top: 20px;
	font-family: "Poppins", sans-serif;
	font-size: 0.8em;
}

.footer-bw {
	left: 0;
	bottom: 0;
	width: 100%;
	background-color: #060606;
	color: #fff;
	padding: 20px 0;
	text-align: center;
}

/* Social icons */
.fa-facebook-square,
.fa-instagram,
.fa-flickr,
.fa-pinterest-square {
	color: #d1b05c;
}

.fa-facebook-square:hover,
.fa-instagram:hover,
.fa-flickr:hover,
.fa-pinterest-square:hover {
	color: #ecdcb3;
}

.footer-content .disclaimer p {
	text-align: justify;
	font-family: "Poppins", sans-serif;
	font-size: 0.8em;
}

.footer-content .contact p {
	text-align: center;
	font-family: "Poppins", sans-serif;
	font-size: 0.8em;
	text-decoration: none;
}

.footer-content .contact a {
	text-align: center;
	font-family: "Poppins", sans-serif;
	color: #d1b05c;
	text-decoration: none;
}

.footer-content .contact a:hover {
	color: #ecdcb3;
}


/* =============================================
   NAVIGATION
   ============================================= */

.topnav,
.topnav-bw {
	overflow: hidden;
	z-index: 1;
}

.topnav    { background-color: #231f17; }
.topnav-bw { background-color: #000; }

.topnav a,
.topnav-bw a {
	float: left;
	display: block;
	text-align: center;
	padding: 8px 14px;
	text-decoration: none;
	font-size: 14px;
}

.topnav a    { color: #d1b05c; }
.topnav-bw a { color: #f2f2f2; }

.topnav a:hover {
	background-color: hsla(38, 47%, 89%, 1);
	color: #231f17;
	transition: background-color 0.4s;
}

.topnav-bw a:hover {
	background-color: hsla(205, 57%, 91%, 1);
	color: #000;
	transition: background-color 0.4s;
}

.topnav a.active    { background-color: #d1b05c; color: #231f17; }
.topnav-bw a.active { background-color: rgba(237, 252, 90, 1); color: #000; }

.topnav .icon,
.topnav-bw .icon {
	display: none;
}

.subnavbtn {
	font-family: "Poppins", sans-serif;
	font-size: 0.8em;
	color: #000;
	background-color: hsla(204, 57%, 91%, 1);
	padding: 3px 10px;
	border: none;
	border-radius: 3px;
	text-decoration: none;
}

.subnavbtn:hover {
	background-color: hsla(42, 64%, 57%, 1);
	color: #000;
	transition: background-color 0.4s;
}


/* =============================================
   NEWS SITE LAYOUT
   ============================================= */

.container-news {
	display: flex;
	background: white;
	justify-content: space-between;
	padding: 35px 15px 15px;
}

main {
	flex: 2;
	margin: 0 8px;
}

aside {
	flex: 1;
	color: #000;
	text-align: center;
	margin: 0 8px;
	padding: 20px;
	border-radius: 8px;
}

.aside-theme {
	background: linear-gradient(to bottom, hsla(224, 26%, 39%, 1) 0%, hsla(221, 25%, 78%, 1) 100%);
}

.aside-contact {
	background: linear-gradient(to bottom, hsla(0, 0%, 89%, 1) 0%, hsla(0, 0%, 100%, 1) 100%);
}

aside h1 { font-size: 2em; padding: 15px; }
aside h2 { padding: 15px; }
aside p  { font-size: 0.9em; text-align: center; padding-bottom: 20px; }

.poem { display: inline-flex; }


/* =============================================
   GRID SYSTEM (col-*)
   ============================================= */

.row::after {
	content: "";
	clear: both;
	display: table;
}

[class*="col-"] {
	float: left;
	padding: 15px;
}

.col-1  { width: 8.33%; }
.col-2  { width: 16.66%; }
.col-3  { width: 25%; }
.col-4  { width: 33.33%; }
.col-5  { width: 41.66%; }
.col-6  { width: 50%; }
.col-7  { width: 58.33%; }
.col-8  { width: 66.66%; }
.col-9  { width: 75%; }
.col-10 { width: 83.33%; }
.col-11 { width: 91.66%; }
.col-12 { width: 100%; }


/* =============================================
   COMPONENTS
   ============================================= */

/* Bar */
.bar {
	width: 100%;
	margin: 15px 0;
	padding: 10px;
	background-color: rgba(238, 231, 214, 1);
}

.bar h2 {
	font-size: 1.4em;
	text-align: center;
	color: #000;
}

/* Caption / figcaption */
.caption {
	font-size: 1.2em;
	margin-bottom: 10px;
}

figcaption {
	color: dimgrey;
	font-style: italic;
	font-size: 0.75em;
	padding: 2px;
	margin-bottom: 10px;
	text-align: left;
}

/* Links */
.linksimple {
	font-size: 0.9em;
	text-decoration: none;
	color: #fff;
}

.linksimpledark {
	display: block;
	text-align: center;
	background-color: #231f17;
	font-size: 0.9em;
	text-decoration: none;
	color: #efdeb5;
	margin: 10px 0;
	padding: 5px 10px;
	border-radius: 20px;
	box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}

.linksimpledark:hover {
	background-color: #fff;
	font-size: 0.95em;
	color: #231f17;
}

/* Buttons */
.btn {
	cursor: zoom-in;
	outline: none;
}

.btn:active { transform: scale(0.99); }

.btn:hover {
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1), 0 6px 20px rgba(0, 0, 0, 0.1);
}

.thisbtn {
	border-radius: 5px;
	border: 2px solid #005fad;
	outline: 0;
	display: inline-block;
	padding: 8px 20px;
	margin-top: 80px;
	text-decoration: none;
	font-size: 0.9em;
	color: #000;
	background-color: #e9fd26;
	text-align: center;
	cursor: pointer;
}

.thisbtn:hover {
	border-color: #e9fd26;
	background-color: #005fad;
	color: white;
}

.koopbutton {
	background-color: #2c5f2d;
	color: white;
	border: none;
	padding: 12px 25px;
	border-radius: 3px;
	cursor: pointer;
	font-size: 14px;
	margin-top: 15px;
}

.koopbutton:hover { background-color: #234d24; }

/* Modals */

/* Landscape */

.close-modal {
	background: none;
	border: none;
	font-size: 1.5rem;
}

.modal {
    opacity: 0;
    width: 55%;
    max-height: 90vh;          /* nooit hoger dan 90% van het scherm */
    overflow-y: auto;          /* scrollen als inhoud te hoog is */
    position: fixed;
    top: -80%;
    left: 50%;
    transform: translate(-50%, -50%);
    transition: top 0.6s ease-in-out;
    border: 1px solid #ccc;
    border-radius: 8px;
    z-index: 2;
    background-color: #fff;
}

.modal.active {
	opacity: 1;
	top: 50%;
}

.modal .header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	position: sticky;   /* header blijft zichtbaar bij scrollen */
    top: 0;
    z-index: 1;
	border-bottom: 1px solid #ccc;
	border-top-left-radius: 8px;
	border-top-right-radius: 8px;
	padding: 0.5rem 0.5rem 0.5rem 1rem;
	background-color: #fff;
}

.modal .body { padding: 0.75rem; }

.modal .body h4 {
	font-size: 0.85em;
	font-weight: 400;
	font-style: italic;
	padding-bottom: 10px;
}

/* Portrait */

.modal.portrait {
    width: 35%;            /* smaller, want afbeelding is hoog en smal */
    max-height: 95vh;
    overflow-y: auto;
}

.modal.portrait .body img {
    width: 100%;
    height: auto;
    display: block;
}

#overlay {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(36, 31, 22, 0.75);
	backdrop-filter: blur(4px);
}

#overlay.active { display: block; }

/* Subnav */
.subnav h2 {
	font-size: 1.8em;
	text-align: center;
	color: #000;
	padding: 20px 15px;
}

.subnav ul {
	list-style-type: none;
	font-size: 0.9em;
	text-align: center;
	margin: 0;
	padding: 0;
	width: 200px;
	border-radius: 15px;
}

.subnav li a {
	display: block;
	color: #efdeb5;
	background-color: #251f16;
	margin: 10px;
	padding: 2px;
	text-decoration: none;
	border-radius: 35px;
}

.subnav li a:hover {
	background-color: #ecdcb3;
	color: #241f16;
}

/* Badge & flag */
.portfolio-badge {
	background-color: #241f16;
	color: white;
	margin-left: 25px;
	padding: 5px 12px;
	text-align: center;
	border-radius: 35px;
}

.flag {
	width: 25px;
	height: auto;
	margin-right: 15px;
}


/* =============================================
   IMAGES
   ============================================= */

.img-center-variable {
	display: block;
	margin: 0 auto;
}

.img-center-fixed {
	display: block;
	width: 100%;
	height: auto;
	margin: 0 auto;
}

.img-center-item {
	display: block;
	width: 80%;
	margin: 0 auto;
	padding: 25px 25px 15px;
}

.centered-img {
	display: block;
	min-width: 200px;
	max-width: 450px;
	width: 100%;
	padding: 10px;
	margin: 1rem auto;
}

.centered-imgbig {
	display: block;
	min-width: 200px;
	width: 100%;
	padding: 10px 25px;
	margin: 1rem auto;
}

.explain-image {
	display: block;
	margin: 0 auto;
	width: 90%;
	padding: 20px;
	height: auto;
}

.intro-image {
	display: block;
	max-width: 350px;
	height: auto;
}

.breakingimage {
	display: block;
	width: 100%;
	height: auto;
}


/* =============================================
   GRID LAYOUTS
   ============================================= */

.grid {
	display: grid;
	margin: 10px;
	text-align: center;
	grid-column-gap: 10px;
	grid-row-gap: 10px;
	grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
	grid-auto-rows: auto;
	grid-auto-flow: dense;
}

.grid-explain {
	display: grid;
	grid-template-columns: auto auto;
	margin: 20px 0;
}

.grid-explain-2 {
	display: grid;
	grid-template-columns: auto 70%;
	margin: 20px 0;
}

.grid-intro {
	display: grid;
	grid-template-columns: auto auto auto;
	margin: 20px 0;
}

.about-grid-intro {
	display: grid;
	grid-template-columns: auto auto auto;
	margin: 20px 0;
}

/* Explain */
.explain-item {
	height: auto;
	text-align: center;
}

.explain-item h2 { font-size: 2em; }

.explain-column {
	display: block;
	padding: 5px 25px 20px;
	position: relative;
	min-height: 120px;
}

.explain-columntxt {
	padding: 25px 35px;
	text-align: left;
}

.explain-columntxt h1 {
	font-family: "Mulish", sans-serif;
	font-optical-sizing: auto;
	font-weight: 800;
	font-style: normal;
	font-size: 2em;
	padding-bottom: 35px;
}

.explain-columntxt h2 { font-size: 2em; padding-bottom: 20px; }
.explain-columntxt h3 { font-size: 1em; font-weight: 400; padding-bottom: 20px; }
.explain-columntxt p  { font-size: 1em; font-weight: 400; padding-bottom: 20px; }

/* Intro */
.intro-item { height: auto; }

.intro-item h1 {
	font-family: "Mulish", sans-serif;
	font-optical-sizing: auto;
	font-weight: 800;
	font-style: normal;
	font-size: 2em;
	padding-bottom: 35px;
}

.intro-item h2 { font-size: 1.8em; }

.intro-column {
	display: block;
	padding: 5px 25px 20px;
	position: relative;
	min-height: 120px;
}

.intro-columntxt { padding: 25px 35px; }

.intro-columntxt h1 {
	font-family: "Mulish", sans-serif;
	font-optical-sizing: auto;
	font-weight: 800;
	font-style: normal;
	font-size: 2em;
	padding-bottom: 35px;
}

.intro-columntxt h2 { font-size: 2em; padding-bottom: 20px; }
.intro-columntxt h3 { font-size: 1em; font-weight: 400; padding-bottom: 20px; }
.intro-columntxt p  { font-size: 1em; font-weight: 400; padding-bottom: 20px; }

.intro-mailtxt h1 {
	font-family: "Mulish", sans-serif;
	font-optical-sizing: auto;
	font-weight: 800;
	font-style: normal;
	font-size: 2em;
	margin-top: 10px;
	padding-bottom: 35px;
}

/* Quote blocks */
.intro-quote,
.intro-quote-bw {
	display: block;
	text-align: center;
	position: relative;
	min-height: 120px;
	max-width: 100%;
	margin: 20px 35px 35px;
	border-radius: 8px;
	background: linear-gradient(to bottom, hsla(0, 0%, 70%, 1) 0%, hsla(0, 0%, 100%, 1) 15%);
}

.intro-alert {
	display: block;
	text-align: center;
	position: relative;
	min-height: 120px;
	max-width: 100%;
	margin: 0 35px 35px;
	border-left: 0.75px solid #333;
}

.intro-quotetxt {
	color: #000;
	padding: 20px 25px;
}

.intro-quotetxt h2 {
	font-size: 1.8em;
	text-align: center;
	padding: 20px 15px;
}

.intro-quotetxt p  { font-size: 0.9em; font-weight: 400; padding-bottom: 20px; }
.intro-quotetxt li { font-size: 0.9em; font-weight: 600; }

ul.bulletssubject {
	display: inline-block;
	text-align: center;
	padding-bottom: 20px;
}

ul.bullets {
	display: inline-block;
	text-align: left;
	padding-bottom: 20px;
}


/* =============================================
   HERO / HALF-PAGE IMAGE
   ============================================= */

.bg {
	background-image: url("../portfolio/Quickies/quickie.jpg");
	height: 55%;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}

.text-block {
	position: absolute;
	bottom: 20px;
	left: 20px;
	background-color: #000;
	color: white;
	padding: 0 20px;
}

.hero-image-fp {
	background-image: linear-gradient(rgba(0, 93, 167, 0.5), rgba(0, 0, 0, 0)),
	                  url("../portfolio/color/france-vaucluse-les-dentelles-de-montmirail-watercolor-01.jpg");
	height: 100%;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	position: relative;
}

.hero-text-fp {
	text-align: center;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	color: white;
}

.hero-text-fp h1 {
	font-family: "Mulish", sans-serif;
	font-optical-sizing: auto;
	font-weight: 800;
	font-style: normal;
	font-size: 2em;
}

.hero-text-fp p {
	text-align: center;
	margin-top: 30px;
	font-size: 1em;
}

.about-image {
	background-image: linear-gradient(rgba(108, 179, 236, 1), rgba(0, 0, 0, 0)),
	                  url("../img/Background.jpg");
	height: 50%;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	position: relative;
}

.about-text {
	text-align: center;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -30%);
	color: white;
}

.about-text h1 { font-size: 3em; color: white; }

.about-text p {
	text-align: center;
	margin-top: 30px;
	font-size: 1.2em;
}


/* =============================================
   ABOUT
   ============================================= */

.about-column {
	display: grid;
	margin: 35px auto 16px;
	max-width: 800px;
	padding: 0 8px;
}

.about-column h2 { font-size: 2.2em; padding: 15px; }
.about-column p  { padding: 15px; }

.about-card {
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
	margin: 10px;
}

.about-container {
	padding: 0 16px;
	content: "";
	clear: both;
	display: table;
}

.about-title { color: grey; }

.about-item-none,
.about-item-img1,
.about-item-img2 {
	display: block;
	padding: 25px 25px 15px;
}

.about-item-none { height: auto; }

.about-quote {
	display: block;
	text-align: center;
	position: relative;
	min-height: 120px;
	max-width: 100%;
	margin: 20px 35px 35px;
	padding: 5px;
	background: linear-gradient(to bottom, hsla(207, 100%, 34%, 1) 0%, hsla(201, 70%, 61%, 1) 100%);
	border-radius: 8px;
}

.about-quotetxt {
	color: white;
	padding: 20px 25px;
}

.about-quotetxt h2 {
	font-size: 2.2em;
	text-align: center;
	padding: 20px 15px;
}

.about-quotetxt li { font-size: 0.9em; font-weight: 600; }

ul.aboutbullets {
	display: inline-block;
	text-align: left;
	padding-bottom: 20px;
}


/* =============================================
   PORTFOLIO
   ============================================= */

.portfolio-item,
.portfolio-item-none {
	display: block;
	padding: 25px 25px 15px;
	border-radius: 8px;
	background-color: white;
}

.portfolio-item h2,
.portfolio-item-none h2 {
	padding-bottom: 10px;
}

.portfolio-item h4,
.portfolio-item-none h4 {
	font-size: 0.85em;
	font-weight: 400;
	font-style: italic;
	padding-bottom: 10px;
}

.portfolio-item p,
.portfolio-item-none p {
	font-size: 0.9em;
	padding-top: 5px;
}

.specs {
	font-size: 0.9em;
	background-color: #f4f4f4;
	margin-top: 10px;
	padding: 5px 10px 10px;
	border-left: 3px solid #bcbcbc;
}

.date {
	font-size: 0.75em;
	font-style: italic;
	text-align: end;
	padding-top: 10px;
	color: dimgrey;
	margin-bottom: 5px;
}

.year,
.tech {
	text-align: start;
	margin-top: 2px;
	color: gray;
}

.tekst-container {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 10px;
}


/* =============================================
   ARTICLE & BLOG
   ============================================= */

.article {
	display: grid;
	margin: 25px 0 35px;
	padding: 0 20px;
	background-color: hsla(38, 47%, 89%, 1);
}

.article h2 {
	font-family: "Poppins", sans-serif;
	font-weight: 600;
	font-size: 1.4em;
	margin: 20px 15px 10px;
}

.blog {
	padding-bottom: 5px;
	margin: 20px 15px;
	column-count: 4;
	column-gap: 40px;
	column-rule: 1px solid #000;
}

.break { margin-top: 35px; }


/* =============================================
   BREAKING
   ============================================= */

.breaking {
	display: grid;
	position: relative;
	grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
	grid-column-gap: 10px;
}

.breakingcontainer {
	display: block;
	position: relative;
	min-height: 120px;
	max-width: 100%;
	margin: 10px 0 20px;
}

.breakingcontainertxt { padding: 15px 15% 5px; }

.overlay {
	position: absolute;
	bottom: 0;
	background: rgba(36, 31, 22, 0.5);
	color: #f1f1f1;
	width: 100%;
	transition: opacity 0.5s ease;
	opacity: 0;
	padding: 15px;
}

.overlay h3 { color: white; text-align: center; padding: 0 35px; }
.overlay p  { color: white; text-align: center; padding: 0 35px; }

.breakingcontainer:hover .overlay { opacity: 1; }


/* =============================================
   SLIDER
   ============================================= */

.slider {
	margin: 5px auto;
	width: 100%;
	overflow: hidden;
}

.slides {
	display: flex;
	transition: transform 0.4s ease-in-out;
}

.slide {
	min-width: 100%;
	height: auto;
	box-sizing: border-box;
}

.slide img {
	width: 100%;
	border-radius: 0;
}


/* =============================================
   PARALLAX
   ============================================= */

.parallax1,
.parallax2,
.parallax3,
.parallax4 {
	min-height: 500px;
	background-color: rgba(255, 200, 127, 1);
	background-attachment: fixed;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}

.parallax1 { background-image: url("../portfolio/toned/01-square.jpg"); }
.parallax2 { background-image: url("../portfolio/toned/02-square.jpg"); }
.parallax3 { background-image: url("../portfolio/toned/03-square.jpg"); }
.parallax4 { background-image: url("../portfolio/toned/04-square.jpg"); }

.content1,
.content2,
.content3,
.content4 {
	min-height: 300px;
	text-align: center;
	color: white;
	padding: 30px;
}

.content1 { background-color: rgba(168, 162, 143, 1); }
.content2 { background-color: rgba(154, 154, 154, 1); }
.content3 { background-color: rgba(106, 146, 162, 1); }
.content4 { background-color: rgba(171, 130, 92, 1); }

.contenttxt { text-align: center; margin-top: 15px; }


/* =============================================
   CONTACT FORM
   ============================================= */

input[type=text],
input[type=email],
select,
textarea {
	width: 100%;
	padding: 12px;
	border: 1px solid #bbb;
	border-radius: 4px;
	box-sizing: border-box;
	margin-top: 6px;
	margin-bottom: 16px;
	resize: vertical;
	background-color: rgba(255, 255, 255, 0.8);
}

button[type=submit] {
	background-color: #241f16;
	color: #e0ac33;
	padding: 10px 20px;
	border: none;
	border-radius: 4px;
	cursor: pointer;
}

button[type=submit]:hover {
	background-color: hsla(42, 64%, 57%, 1);
	color: #241f16;
}

.container-contact {
	display: grid;
	margin: 25px auto 0;
	background-color: #fff;
	border-radius: 8px;
	padding: 20px;
	box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
	max-width: 800px;
}

.container-contact h1 {
	font-family: "Mulish", sans-serif;
	font-optical-sizing: auto;
	font-weight: 800;
	font-style: normal;
	font-size: 2em;
	padding-bottom: 35px;
}

.insertField,
.insertSubject {
	font-family: "Poppins", sans-serif;
	font-size: 0.9em;
}

.insertMessage {
	font-family: "Poppins", sans-serif;
	font-size: 0.9em;
	height: 120px;
}


/* =============================================
   COOKIES
   ============================================= */

.cookiecontainer {
	display: grid;
	margin: 10px;
	border-radius: 5px;
	padding: 10px;
}

.cookiesubcontainer {
	width: 85%;
	margin: auto;
}

#cookies {
	width: 100%;
	position: fixed;
	bottom: 0;
	color: white;
	background-color: rgba(36, 31, 22, 1);
	z-index: 1;
	display: none;
}

.cookies {
	min-height: 80px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 10px;
}

.cookies a { font-size: 0.9rem; color: #d8ae4c; font-weight: 400; text-decoration: none; }
.cookies p { font-size: 0.9rem; color: white; font-weight: 400; }

#cookies-btn {
	border-radius: 5px;
	padding: 8px 10px;
	font-size: 0.9rem;
	font-family: inherit;
	cursor: pointer;
	border: 2px solid #d8ae4c;
	background-color: rgba(37, 31, 22, 1);
	color: white;
}

#cookies-btn:hover {
	border-color: #fff;
	background-color: rgba(216, 174, 76, 1);
	color: #241f16;
}


/* =============================================
   ARTWORK FRANCE START
   ============================================= */

/* ---------- MAP ---------- */

	
/*
.map-section {
	display: flex;
	justify-content: center;
	margin: 0 auto;
	padding: 30px 0;
	position: relative;
}

.map-wrapper {
  width: 95%;
  max-width: 1000px;
}
*/

/* standaard */
/*
.map-wrapper svg path {
  fill: #D2C5AE;
  stroke: #ffffff;
  stroke-width: 1;
  transition: fill 0.2s ease, opacity 0.2s ease;
}
*/

/* klikbare */
/*
.map-wrapper svg path.has-content {
  cursor: pointer;
  fill: #E0D9CE;
}
*/

/*
.map-wrapper svg path.has-content:hover {
  fill: #D1B05C;
}
*/

/* geen content */
/*
.map-wrapper svg path.no-content {
  opacity: 0.35;
}
*/

/* ---------- TOOLTIP ---------- */

/*
.tooltip {
  position: absolute;
  background: #2e2e2e;
  color: #fff;
  padding: 6px 10px;
  font-size: 13px;
  border-radius: 3px;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.2s ease;
  transform: translate(-50%, -120%);
}
*/

/* ---------- GALERIJ ---------- */

/*
.gallery {
  width: 80%;
  max-width: 1100px;
  margin: 80px auto;
}

.dept-section {
  margin-bottom: 120px;
}

.dept-section h2 {
  font-weight: 400;
  border-bottom: 1px solid #ddd;
  padding-bottom: 10px;
  margin-bottom: 30px;
}

.dept-section h3 {
  font-family: "Poppins", sans-serif;
  font-size: 1em;
  font-weight: 400;
  padding-bottom: 10px;
  margin-bottom: 30px;
}

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(400px, 1fr));
  gap: 20px;
}

.gallery-grid img {
  width: 100%;
  height: auto;
  display: block;
	transition: transform 0.3s ease;
}
*/

/* =============================================
   ARTWORK FRANCE END
   ============================================= */


/* =============================================
   MEDIA QUERIES
   ============================================= */

/* Tablet & touch devices: disable parallax fixed attachment */
@media only screen and (max-device-width: 1366px) {
	.parallax1,
	.parallax2,
	.parallax3,
	.parallax4 {
		background-attachment: scroll;
	}
}

@media screen and (max-width: 1020px) {
	.intro-image    { display: none; }
	.blog           { column-count: 3; }
	.modal          { width: 80%; }
	.container-contact { max-width: 90%; }
	.poem           { display: block; }

	.grid-explain   { grid-template-columns: auto 50%; }
	.grid-explain-2 { grid-template-columns: auto 65%; }

	.explain-image  { width: 100%; padding: 10px; }
}

@media screen and (max-width: 729px) {

	.subject        { display: none; }

	/* News layout */
	.container-news { flex-direction: column; padding: 15px 10px; }
	main            { margin: 0; padding: 5px; }
	aside           { margin: 20px 5px 30px; }

	/* Modals disabled on small screens */
	.modal,
	#overlay.active { display: none; }
	.btn            { cursor: default; }
	.btn:hover      { box-shadow: none; }

	/* Grids */
	.grid-intro     { grid-template-columns: auto auto; }
	.grid-explain,
	.grid-explain-2 { display: block; }

	/* Spacing tweaks */
	.intro-columntxt  { padding: 25px; }
	.explain-columntxt { padding: 25px; }
	.intro-quote,
	.intro-quote-bw   { margin: 20px 25px 35px; padding: 5px; }
	.intro-alert      { margin: 20px 25px 35px; padding: 5px; border-left: none; }
	.intro-quotetxt   { padding: 20px 25px; }
	.centered-img,
	.centered-imgbig  { padding: 0; }
	.about-quote      { margin: 20px 15px 35px; padding: 5px; }
	.about-quotetxt   { padding: 20px 0; }
	.about-item-none  { padding: 25px 15px 15px; }
	.about-text h1    { font-size: 2.3em; }
	.about-column     { width: 100%; display: block; }

	/* Article */
	.article          { margin: 30px 0; padding: 0 10px; }
	.blog             { column-count: 2; }

	/* Portfolio */
	.portfolio-item,
	.portfolio-item-none { padding: 15px; }
	.portfolio-item h2   { border-top: 2px solid #bcbcbc; padding-top: 15px; }

	/* Footer */
	.footer-content,
	.footer-content-bw { flex-direction: column; align-items: center; }

	/* Grid columns → 50% on medium-small screens */
	.col-1, .col-2, .col-3, .col-4,
	.col-5, .col-6, .col-7, .col-8,
	.col-9, .col-10, .col-11, .col-12 { width: 50%; }
}


@media screen and (max-width: 600px) {

	.grid,
	.grid-intro { display: block; }

	header      { height: 120px; }
	.gifjelogo  { width: 350px; }

	/* Hamburger nav */
	.topnav a:not(:first-child),
	.topnav-bw a:not(:first-child) { display: none; }

	.topnav a.icon,
	.topnav-bw a.icon {
		color: white;
		float: right;
		display: block;
	}

	.topnav a.icon:hover,
	.topnav-bw a.icon:hover { color: #000; }

	.topnav.responsive,
	.topnav-bw.responsive { position: relative; }

	.topnav.responsive .icon,
	.topnav-bw.responsive .icon {
		color: white;
		position: absolute;
		right: 0;
		top: 0;
	}

	.topnav.responsive a,
	.topnav-bw.responsive a {
		float: none;
		display: block;
		text-align: left;
	}

	.blog        { column-count: 1; }
	.cookies     { padding: 10px 0; }

	/* Grid columns → 100% on mobile */
	.col-1, .col-2, .col-3, .col-4,
	.col-5, .col-6, .col-7, .col-8,
	.col-9, .col-10, .col-11, .col-12 { width: 100%; }
	
	/* Gallery */
	.gallery-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
	gap: 20px;
}
	
}
