/* -- INNEHÅLLSFÖRTECKNING --

        VARIABLER
        RESET
		
		TYPOGRAFI
		LÄNKAR
		BILDER
		FORMULÄR
		TABELLER
		
		LAYOUT
		SIDHUVUD
		SIDFOT

------------------------------ */

:root {
    --clr-primary-hsl: 0, 0%, 93%;
    --clr-primary-c-hsl: 0, 0%, 20%;
    --clr-secondary-hsl: 0, 0%, 80%;
    --clr-secondary-c-hsl: 0, 0%, 20%;

    --clr-primary: hsl(0, 0%, 93%);
    --clr-primary-c: hsl(0, 0%, 20%);
    --clr-secondary: hsl(0, 0%, 80%);
    --clr-secondary-c: hsl(0, 0%, 20%);

    --clr-accent-1: hsl(240, 40%, 33%);
    --clr-accent-2: hsl(240, 20%, 50%);
    --clr-accent-3: hsl(240, 71%, 53%);

    --margin-default: 1rem;
    --margin-small: .5rem;
    --padding-default: 1rem;
    --padding-small: .5rem;

    --font-size-default: 1rem;
    --font-size-xl: 1.5rem;
    --font-size-l: 1.125rem;
    --font-size-m: var(--font-size-default);
    --font-size-s: .875rem;
    --font-size-xs: .75rem;

    --line-height-default: 1.5;
    --line-height-double: 3;
    --line-height-xl: calc(var(--line-height-double) / 1.125);
    --line-height-l: calc(var(--line-height-default) / 1.125);
    --line-height-m: calc(var(--line-height-default) / 1);
    --line-height-s: calc(var(--line-height-default) / .875);
    --line-height-xs: calc(var(--line-height-default) / .75);
}

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

* {
    margin: 0;
    padding: 0;
    font: inherit;
}

.gallery-film iframe,
img,
svg {
    display: block;
    max-width: 100%;
    height: auto;
}

body {
    padding: var(--padding-default);
    background: var(--clr-primary-c);
    font-family: "Lucida Bright", Lucidabright, Georgia, "Bitstream Vera Serif", serif;
    font-size: var(--font-size-default);
    font-size-adjust: 0.55;
    line-height: var(--line-height-default);
}

.header-img-title,
.main-menu,
table,
footer {
    font-family: "Lucida Grande", "Lucida Sans", "Lucida Sans Unicode", Lucida, Verdana, "Bitstream Vera Sans", sans-serif;
}

/*
** TYPOGRAFI
*/

h1, h2, h3 { 
	font-weight: bold; 
	clear: both; 
}

h1 {
    font-size: var(--font-size-xl);
    line-height: var(--line-height-m);
}

h2 {
    font-size: var(--font-size-l);
    line-height: var(--line-height-l);
    margin-top: 1.133333rem;
    margin-bottom: .2rem;
}

h3 { 
    font-size: var(--font-size-m); 
    line-height: var(--line-height-m); 
    margin-top: 1.5rem; 
    margin-bottom: 0; 
}

h3.datum {  
    font-weight: normal;  
    margin-top: 0; 
    margin-bottom: 1.375rem; 
}

h2+h3 { 
    margin-top: 1.75rem; 
}

#hem h3 { 
    margin-top: 0; 
}

#hem h2.updated { 
    margin-bottom: -.25rem; 
    border-top: 1px solid #aaa; 
    padding-top: .7rem; 
}

em, cite { 
    font-style: italic; 
}

strong { 
    font-weight: bold; 
}

ins { 
    text-decoration: none; 
    border-bottom: thin dotted var(--clr-primary-c); 
}

del { 
    text-decoration: line-through; 
}

abbr[title] { 
    border-bottom: thin dotted var(--clr-primary-c); 
    cursor: help; 
}

code, 
kbd, 
samp, 
var { 
    font: normal 1rem/1.5 "Lucida Console", "Andale Mono", "monotype.com", "Bitstream Vera Sans Mono", monospace; 
}

blockquote, 
q {	
    quotes: none; 
}

blockquote {
    margin: var(--margin-default) calc(var(--margin-default) * 2); 
    font-style: italic; 
}

blockquote:before, 
blockquote:after, 
q:before, 
q:after { 
    content: "\201D"; 
}

small, 
sub, 
sup { 
    font-size: var(--font-size-s); 
}

sub { 
    vertical-align: sub; 
}

sup { 
    vertical-align: super; 
}

p { 
    margin-bottom: var(--margin-default); 
}

p.arkiv { 
    text-align: right; 
}

p.datum { 
    clear: both; 
}

p.path { 
    font-size: var(--font-size-xs);
}

#hem p.datum { 
    margin-top: 2rem; 
    margin-bottom: 0; 
    font-size: var(--font-size-xs); 
    line-height: 2; 
    font-style: italic; 
}

.prev-next {
    text-align: center;
}

dl, dd, ol, ul { margin-bottom: var(--margin-default); }
ol, ul { list-style: disc; }
dt { font-weight: bold; }
li { margin-bottom: .5rem; }

.nyheter { list-style-type: none; }
.nyheter { position: relative; margin-left: 0; }
.nyheter h2 { margin-left: 6.2rem; }
.nyheter p { margin-left: 7rem; }

.nyheter p.datum {
    position: absolute;
    margin-left: 0;
    top: 0;
    left: 0;
    font-weight: bold;
    font-size: var(--font-size-l);
    line-height: var(--line-height-l);
}

/*
** LÄNKAR
*/

a:link {
    background: inherit;
    color: var(--clr-accent-1);
}

a:visited {
    color: var(--clr-accent-2);
}

a:hover,
a:active,
a:focus-visible {
    color: var(--clr-accent-3);
}

a:active, 
a:focus,
a:focus-visible { 
    outline: thin dotted var(--clr-primary-c); 
}

/*
** BILDER
*/

a img { border: 1px solid var(--clr-primary-c); }
a:hover img { border: 1px solid var(--clr-primary); }

.bildtext img { margin-bottom: 0; }
.bildtext p { font-size: .857rem; line-height: 1.75; text-align: right; }

img.img-large { border: 1px solid var(--clr-primary-c); }
img.left { float: left;	margin: .2rem 1.5rem 4rem 0; }

.drawing-large {
    display: flex;
    justify-content: center;
    border: 1px solid var(--clr-primary-c); 
    background:#fff; 
}

.gallery { 
    display: grid;
    grid-template-columns: repeat(auto-fit, 120px);
    gap: var(--margin-default);
    list-style: none;
}

.gallery-film { 
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: var(--margin-default);
    list-style: none;
}

#teckning .gallery { 
    grid-template-columns: repeat(auto-fit, 100px);
}

.gallery-item-link {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.gallery img {
    width: 120px;
    height: 90px;
}

#teckning .gallery img,
.gallery.drawing img {
    width: 100px;
    height: 149px;
}

.gallery figcaption { 
    font-size: var(--font-size-s); 
    text-align: center;
}

/* #hem .gallery ul { margin-top: -.5rem; }
#hem .gallery li { margin: 0 0 1rem 2.375rem; }
#hem .gallery li.first { margin-left: 0; } */

.updated li { position: relative; }
.updated li span { 
	position: absolute; 
	bottom: 1px; 
	left: 1px;
    right: 1px;
	height: 1.5rem; 
	width: 118px;
    font-size: var(--font-size-s);
    text-align: center;
	text-decoration: none; 
	background: rgba(238, 238, 238, 0.9); 
	color: var(--clr-primary-c); 
}

#teckning .updated li span {
    width: 98px;
}

.updated li span.new, .new { 
    text-transform: uppercase; 
    color: #b00;
}

/*
** FORMULÄR
*/

fieldset { border: 2px groove #c0c0c0; padding: .75em; }
fieldset fieldset { padding: 0; }
label { display: block; }
input, select, textarea { margin-bottom: var(--margin-default); }
label { font-weight: bold; margin-top: var(--margin-small); }
legend { color: var(--clr-primary-c); }

label.explain, #antispam { margin-bottom: 0; display: inline; }
input.button { margin-top: var(--margin-default); margin-bottom: 0; }

/* 
** TABELLER
*/

table { 
    border-collapse: collapse;
    border-spacing: 0;
    margin-bottom: var(--margin-default);
    width: 100%;
}
    
caption {
    text-align: center;
    font-weight: bold;
}
  
th, td {
    border: 1px solid #c0c0c0;
    padding: var(--padding-small);
    font-size: var(--font-size-xs);
}
    
th { 
    background: var(--clr-primary-c);
    color: var(--clr-primary);
    text-align: center;
    vertical-align: top;
}

td { 
    background: var(--clr-secondary);
    color: var(--clr-secondary-c);
    vertical-align: middle;
}
  
td.nummer, td.h, td.distans { text-align: right; }
td.c { text-align: center; }

/*
** LAYOUT
*/

.site-container {
    max-width: 53.125rem;
    margin: 0 auto;
    background: var(--clr-primary);
    color: var(--clr-primary-c);
}

main {
    padding: var(--padding-default);
}

@media screen and (min-width: 888px) {
    .page-container {
        display: flex;
    }
    
    .page-container>* {
        flex: 1;
    }
    
    .main-col {
        padding-right: 1rem;
        border-right: 1px solid var(--clr-secondary);
    }
    
    .sub-col {
        padding-left: 1rem;
    }    
}

.latest-img-container {
    display: flex;
    flex-wrap: wrap;
    gap: .625rem;
}

.latest-img {
    margin-bottom: 0;
    font-size: var(--font-size-s);
    line-height: var(--line-height-s);
}

dt.latest-img {
    min-width: 120px;
}

.latest-img-title {
    font-size: var(--font-size-m);
    font-weight: 700;
    line-height: var(--line-height-m);
}

.latest-img .published {
    font-size: var(--font-size-xs);
    line-height: var(--line-height-xs);
    text-transform: uppercase;
    letter-spacing: .1rem;
}

/*
** SIDHUVUD
*/

header {
    position: relative;
}

.site-title,
.site-title a {
    position: absolute;
    top: 0;
    left: 0;
    padding-right: var(--padding-small);
    background: var(--clr-primary-c);
    color: var(--clr-primary);
    font-size: 2rem;
    text-decoration: none;
}

.header-img {
    height: 155px;
    object-fit: cover;
    border: none;
}

.header-img:hover {
    border: none;
}

.header-img-info {
    padding: .5rem;
    background: hsl(var(--clr-primary-hsl), 0.75);
    font-size: var(--font-size-s);
}

@media screen and (min-width: 500px) {
    .header-img-info {
        position: absolute;
        bottom: .5rem;
        right: .5rem;
    }
}

.header-img-info dt {
    font-weight: 300;
    text-transform: uppercase;
    letter-spacing: .2rem;
}

.header-img-info dd {
    margin: var(--margin-small) 0 0;
}

.header-img-title a:link,
.header-img-title a:visited {
    color: var(--clr-primary-c);
    text-decoration: none;
}

.header-img-title a:hover,
.header-img-title a:focus-visible {
    color: var(--clr-primary-c);
    text-decoration: underline;
}

.header-img-title {
    font-weight: 700;
}

.main-menu {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 0;
    list-style: none;
}

.menu-item {
    flex: 1 1 0;
    margin-bottom: 0;
}

.current-page,
.menu-item a {
    display: block;
    padding: var(--padding-small);
    background: var(--clr-secondary);
    color: var(--clr-secondary-c);
    text-align: center;
    text-decoration: none;
}

.current-page,
.current-page a,
.menu-item a:hover,
.menu-item a:active,
.menu-item a:focus-visible {
    background: var(--clr-primary-c);
    color: var(--clr-primary);
}

.current-page a {
    padding: 0;
}

/*
** SIDFOT
*/

footer {
    padding: var(--padding-small);
    background: var(--clr-secondary);
    color: var(--clr-secondary-c);
    font-size: .875rem;
    text-align: center;
}