/* version 28/11/2023 */

/* my link blue #30f -->

/* general site-wide stuff */
:root {
	--bg-clr:	#eff;
	--blue-clr:	#30f;
}

html	{
	/* font-family: Tahoma; */
	font-family: system-ui, sans-serif;
	font-size: 16px;
	scroll-behavior: smooth;
}
body	{
	background-color:var(--bg-clr);
	background-image:url(images/bg-effect1.svg);
	background-repeat:repeat;
	color: black;
}
h1	{
	display: none;
}
.logozone	{
	position:absolute; top: 0; left: 0; height: 95px; width: 124px;
}

.contactdeets	{
	background-color: var(--bg-clr);
	position: absolute; top: 95px; left: 0; height: 50px; width: 124px;
	text-align: center;
	border-radius: 0.5em;
}
.deets	{
	display:block;
	color: var(--blue-clr);
	text-decoration: none;
	font-size: 0.8em;
}
.imagedeets	{
	width: 100%;
	height: 20px;
	display: none;
}

.headliner	{
	position: absolute; top: 0px; left: 124px;
	height: 145px;
	width: calc( 100% - 248px );
	display: table;
}
.headline	{
	font-size:2em;
	font-weight:bold;
	text-shadow:0 0 0.33em var(--bg-clr);
	display: table-cell;
	vertical-align: middle;
	text-align: center;
}
.content	{
	position: absolute; top: 145px; left: 64px;
	width: calc( 100% - 128px );
}
.wide-content	{
	position: absolute; top: 145px; left: 4px;
	width: calc( 100% - 8px );
}

main {
	position:absolute; top: 145px; left: 0;
}

/* single pixel marker */
.a1	{
	height: 1px; width: 1px;
}
.extratext	{
	display: none;
}

a	{
	color: var(--blue-clr);	
}

a.menubutton	{
	display: block;
	position: relative;
	top: 1em;
	padding: 1em;
	border: 1px solid black;
	border-style: inset;
	border-radius: 0.5em;
	background-color: #dff;
	margin: 0;
	text-decoration: none;
	font-size: 10pt;
	font-weight: bold;
	color: var(--blue-clr);
	min-height: 20px;
	box-shadow: 0 0.2rem 0.6rem 0 rgba(0,0,0,0.3);
}
a.menubutton:hover,	a.menubutton:active	{
	background-color: #fff;
	text-decoration: underline;
	color: var(--blue-clr);
	box-shadow: 0 0.2rem 0.6rem 0 rgba(0,0,0,0.7);
}
form.formbox	{
	display: inline-block;
	position: relative;
	padding: 0.5rem;
	border: 1px solid black;
	border-style: inset;
	border-radius: 8px;
	background-color: #dfd;
	box-shadow: 0 0.2rem 0.6rem 0 rgba(0,0,0,0.3);
}
form.formbox label {
	padding-left: 0.25em;
	color: var(--blue-clr);
}
form.formbox button {
	font-weight: bold;
	border: 2px solid #88f;
	border-radius: 4px;
	background-color: white;
	color: var(--blue-clr);
}
.iconbutton	{
	display: inline-block;
	position: relative;
	padding: 0.5rem;
	border: 1px solid black;
	border-style: inset;
	border-radius: 8px;
	background-color: #dff;
	text-decoration: none;
	font-size: 10pt;
	font-weight: bold;
	color: var(--blue-clr);
	box-shadow: 0 0.2rem 0.6rem 0 rgba(0,0,0,0.3);
	cursor: pointer;
}
.iconbutton:hover,	.iconbutton:active	{
	background-color: #fff;
	color: var(--blue-clr);
	box-shadow: 0 0.2rem 0.6rem 0 rgba(0,0,0,0.7);
}
.buttonicon	{
	vertical-align: middle;
	padding-left: 0.5rem;
	padding-right: 0.5rem;
}

.mailto	{
	font-size: 18pt;
	font-weight: 600;
}
.tripinfo	{
	padding-top: 0.5em;
	padding-bottom: 0.5em;
	font-size: 1rem;
}
.break3	{
	height: 3rem;
}
.availability-modal,
.track-modal,
.menu-modal	{
	background: var(--bg-clr);
	border: 0;
	border-radius: 3px;
	padding: 3px 4px 3px;
	box-shadow: 0 0.2rem 0.6rem 0 rgba(0,0,0,0.3);
}
c19modal	{
	box-shadow: 0 0.2rem 0.6rem 0 rgba(0,0,0,0.3);
}
.menu-modal ul	{
	list-style-image: url('images/YH-licon.svg');
	padding: 0 1.5rem 0;
}
.menu-modal li	{
	line-height: 2;
}
.availability-modal::backdrop,
.c19modal::backdrop,
.track-modal::backdrop,
.menu-modal::backdrop	{
	background: #0027;
}
.availabilitycuebox	{
	display: inline-block;
}
.boxout {
	margin: 1em;
	border: 2px solid black;
	padding: 1rem;
	font-weight: bolder;
}
.alertbox {
	position: fixed;
	top: 20%;
	right: 10%;
	width: 80%;
	height: 60%;
	border: 4px solid #000;
	padding: 6px;
	background: #8f2;
	z-index: 2000;
	text-align: center;
	font-size: 12pt;
}
.alertminibox {
	position: fixed;
	top: 144px;
	width: 96px;
	height: 36px;
	border: 2px solid #000;
	padding: 0;
	background: #8f2;
	z-index: 2000;
	text-align:center;
	font-weight: bold;
}
.menu	{
	position:absolute; top: 0; left: 0;
}
.map	{
	width:100%;
	height:33vh;
	padding-left: 3px;
	padding-right: 0;
	text-align:center;
	box-shadow: 0 0.2rem 0.6rem 0 rgba(0,0,0,0.3);
}
.bigmap	{
    min-height: 300px;
    min-width: 300px;
	width: calc(100% - 1.2rem);
	height:calc(100svh - 18rem);
	padding-left: 0.6rem;
	padding-right: 0.6rem;
	text-align:center;
	box-shadow: 0 0.2rem 0.6rem 0 rgba(0,0,0,0.3);
}
.map_search {
	font-size: 0.8em;
	margin: 0;
}
.map_search label {
	display: inline-block;
	width: 3rem;
	text-align: right;
}
.map_search input {
	min-width: 16rem;
	max-width: 48rem;
	width: 24rem;
}
.inset	{
	display: block;
	text-align: center;
	padding-left: 125px;
	padding-right: 125px;
	padding-top: 32px;
	height: 63px;
}
.rubric	p	{
	background-color: white;
	padding-left: 0.75em;
	padding-right: 0.75em;
	padding-top: 0.5em;
	padding-bottom: 0.5em;
	border-radius: 0.35em;
	font-size: 0.9em;
	box-shadow: 0 0.2rem 0.6rem 0 rgba(0,0,0,0.3);
}
.contact	{
	display: grid;
	gap: 0.1em;
	grid-template-columns: repeat(auto-fit, minmax(192px, 1fr));
	padding-top: 2pt;
	padding-bottom: 2em;
	margin-top: 5em;
}

/* expanding menu display */
.menucuebox	{
	display: inline-block;
}
.menudisplaybox	{
	display: none;
	gap: 0.4rem;
	grid-template-columns: repeat(auto-fit, minmax(192px, 1fr));
	padding-top: 0.125rem;
	padding-bottom: 2rem;
}

img.mypic	{
	height:300px; width: 400px; margin-left: 0; margin-top: 0;
	border-style: solid;
	border-color: white;
	border-width: 0.5em;
	box-shadow: 0 0.2rem 0.6rem 0 rgba(0,0,0,0.7);
}
img.spinner	{
	margin: 0;
	position: absolute;
	left: 50%;
	top: 50%;
	z-index: 500;
	transform: translate(-50%,-50%);
	-ms-transform: translate(-50%,-50%);
	/* display: block; */
	opacity: 100%;
	transition: opacity 1s;
	pointer-events: none;
}
.mygallery	{
	height:316px; width: 420px; margin-left: 0; margin-top: 0;
}
.qthumb	{
	max-width: 128px;
	max-height: 128px;
	vertical-align: center;
	text-align: center;
	margin: 2px;
	box-shadow: 0 0.2rem 0.6rem 0 rgba(0,0,0,0.3);
}
.qthumb:hover, .qthumb:active	{
	margin: 3px;
	box-shadow: 0 0.2rem 0.6rem 0 rgba(0,0,0,0.7);
	cursor: pointer;
}
.c0	{
	list-style-type: none;
	list-style-image: none;
	font-weight: 600;
}
.c1	{
	list-style-type: square;
	list-style-image: url('images/list-check.png');
	font-weight: normal;
	vertical-align: text-top;
}
.c2	{
	list-style-type: square;
	list-style-image: url('images/list-advise.png');
	font-weight: normal;
	vertical-align: text-top;
}
.c3	{
	list-style-type: square;
	list-style-image: none;
	font-weight: normal;
}

.curvelogo	{
	width: 360px;
	height: 90px;
	margin-top: 8px;
}

.headstrap	{
	font-family: Gill Sans;
	font-weight: normal;
	color: #f03;
	text-transform: uppercase;
	font-size: smaller;
}

.strapline	{
	font-size: smaller;
}
.section	{
	font-size: 1.25em;
	font-weight: bold;
}
span.bolder	{
	font-weight: bold;
}
.question {
	font-style: italic;
	font-weight: bold;
	line-height:1.5;
}

@media only screen and (max-width: 768px)   {
	/* For mobile phones: */
	html	{
		font-family: Tahoma;
		font-size: 12px;
		scroll-behavior: smooth;
	}
	img.mypic	{
		width: 256px; height: 180px; margin-left: 0; margin-top: 0;
		border-style: solid;
		border-color: white;
		border-width: 0.4rem;
		box-shadow: 0 0.2rem 0.6rem 0 rgba(0,0,0,0.7);
	}
	.mygallery	{
		height:180px; width: 239px; margin-left: 0; margin-top: 0;
	}
	.curvelogo	{
		width: 128px;
		height: 32px;
		margin-top: 1px;
	}
	.section	{
		font-size: 1em;
		font-weight: bold;
	}
	.logozone	{
		position:absolute; top: 0; left: 0; height: 74px; width: 96px;
	}
	.headliner	{
		position: absolute; top: 20px; left: 96px;
		height: 54px;
		width: calc( 100% - 192px );
		display: table;
	}
	.headline   {
		font-size: 16px;
		font-weight: bold;
		display: table-cell;
		text-align: center;
		vertical-align: middle;
	}
	.content	{
		position: absolute; top: 74px; left: 16px;
		width: calc( 100% - 32px );
	}
	.wide-content	{
		position: absolute; top: 74px; left: 2px;
		width: calc( 100% - 4px );
	}
	main {
		position:absolute; top: 75px; left: 0;
	}
	.inset	{
		display: block;
		text-align: center;
		padding-left: 6rem;
		padding-right: 1rem;
		padding-top: 1rem;
		height: 3rem;
	}
	.contactdeets	{
		position: absolute; top: 0; left: 75px;
		height: 0px; width: calc( 100% - 75px );
		text-align: left;
		border-radius:0.5em;
	}
	.deets	{
		display: inline-block;
		color: var(--blue-clr);
		text-decoration: none;
		font-size: 12px;
		margin-right: 3px;
		display: none;
	}
	.imagedeets	{
		position: absolute; top: 0; left: 75px;
		height: 20px; width: calc( 100% - 75px );
		display: inline-block;
	}
	.c19-box {
		width: 75%;
		border: 4px solid #000;
		padding-top: 2em;
		padding-bottom: 2em;
		padding-left: 0.5em;
		padding-right: 0.5em;
		background: #efe;
		z-index: 6000;
		text-align: center;
		font-size: 1rem;
		line-height: 1.5;
	}
	.break3	{
		height: 0;
	}
}

@media only screen 
  and (min-device-width: 800px) 
  and (max-device-width: 1280px) 
  and (-webkit-min-device-pixel-ratio: 1.5) {
	/* trying for a generic tablet and doing f-all about it: 
	img.mypic
	*/
	.mypixx  {
		width: 128px; height: 90px; margin-left: 0; margin-top: 0;
		border-style: solid;
		border-color: white;
		border-width: 0.4rem;
		box-shadow: 1px 1px 3px black;
	}
}

.facebook	{
	display: inline-block;
	position: relative;
	top: 1rem;
	padding: 0.25rem;
	margin: 0;
	height: 3.25rem;	width: 3.25rem;
}
.facebook img	{
	vertical-align:text-top;
}
.contactline {
	padding-top: 1rem;
	width: 320px;
}
p.bolder {
	font-weight: 500;
}
.canalplan	{
	font-size: 0.7rem;
	text-align: center;
}
.testimonial {
	background-color: #fff;
	padding: 0.5rem;
	box-shadow: 0 0.2rem 0.6rem 0 rgba(0,0,0,0.3);
}
.gallery	{
	padding-top: 0.5em;
	padding-bottom: 0.5em;
	text-align: center;
}

