i {
    margin-right:0.325rem;
}

@media (width<360px) {
    .reduce {
        display:none;
    }
}

.logo {
    width:min(50vw,14rem);
    height:2rem;
    background: url('/nwhelogo.png') no-repeat;
    background-size: contain;
    margin-bottom:2rem;

}
.logo::after{
    font: 400 min(7vw, 2rem) Arvo;
    content: '| HOME ED';
    margin-left:105%;
    white-space: nowrap;
}

.block-logo {
    width:10rem;
    margin-bottom: 1rem;
}

ul.nw-plain-list {
    list-style-type: none;
    padding:0;
}
ul.nw-plain-list li {
    padding: 0.5em;
    margin: 0.5em;
}

ul.nw-highlighting-list {
    list-style-type: none;
    padding:0;
}
ul.nw-highlighting-list li {
    padding:0.5em;
    margin:0.5em;
    border: 5px solid var(--nw-p-white);
}
ul.nw-highlighting-list li:has( :checked){
    border-color:var(--nw-p-green);
}

ul.nw-shaded-list {
    list-style-type: none;
    padding:0;
}
ul.nw-shaded-list li {
    padding: 0.2em;
    margin: 0.4em;
    background-color: #ddd;
}

ul.nw-alternate-shaded-list {
    list-style-type: none;
    padding: 0;
}
ul.nw-alternate-shaded-list li {
    padding: 0.2em;
    margin : 0.2em;
}
ul.nw-alternate-shaded-list li:nth-child(even) {
    background-color: #ddd;
}

ul.nw-table li {
    display:flex;
}

:root {
    --nw-p-cyan:   #64dee3;
    --nw-p-white:  #f6f6f6;
    --nw-p-black:  #272120;
    --nw-p-green:  #adf345;
    --nw-ks-eyfs:  #b659c6;
    --nw-ks-1:     #68c97c;
    --nw-ks-l2:    #d7cd6c;
    --nw-ks-u2:    #5484b2;
    --nw-ks-3:     #e7645e;
    --nw-ks-gcse:  #4739a6;
    --nw-ks-multi: #e6a761;
    --nw-s-blue:   #3f9aa9;
    --nw-s-red:    #a74438;
    --nw-s-brown:  #b08355;
    --nw-s-green:  #b4c64f;
    --nw-announce: #e7645e;
    --nw-text-white: #f6f6f6;
    --nw-text-dark: #212529;
    --nw-overlay-box-padding: 5%;
    --bs-body-bg: #eaeaea;

    --nw-bar-width: 0.4em;
    --nw-left-bar-padding: 0.7em;
    --nw-left-bar-margin: calc((var(--nw-bar-width) + var(--nw-left-bar-padding))*-1);

    --bs-breadcrumb-divider: '>';
}

[data-bs-theme=dark] {
    --bs-body-bg: #333;
}
[data-bs-theme=dark] .nw-btn {
    border-color: var(--nw-p-white);
}

[data-bs-theme=light] {
    --bs-body-bg: #eaeaea;
}
[data-bs-theme=light] .nw-btn {
    border-color: var(--nw-p-black);
}
main {
    container-type: inline-size;
}

.bg-nw-red {
    background-color: var(--nw-s-red)!important;
    color: var(--nw-text-white)!important;
}

.bg-nw-blue {
    background-color: var(--nw-s-blue)!important;
    color: var(--nw-text-dark)!important;
}

.bg-nw-cyan {
    background-color: var(--nw-p-cyan)!important;
    color: var(--nw-text-dark)!important;
}

.bg-nw-green {
    background-color: var(--nw-p-green)!important;
    color: var(--nw-text-dark)!important;
}

.bg-nw-olive {
    background-color: var(--nw-s-green)!important;
    color: var(--nw-text-dark)!important;
}

.bg-nw-brown {
    background-color: var(--nw-s-brown)!important;
    color: var(--nw-text-white)!important;
}

.bg-nw-ks-eyfs {
    background-color: var(--nw-ks-eyfs)!important;
    color: var(--nw-text-white)!important;
}

.bg-nw-ks-1 {
    background-color: var(--nw-ks-1)!important;
    color: var(--nw-text-dark)!important;
}

.bg-nw-ks-l2 {
    background-color: var(--nw-ks-l2)!important;
    color: var(--nw-text-dark)!important;
}

.bg-nw-ks-u2 {
    background-color: var(--nw-ks-u2)!important;
    color: var(--nw-text-white)!important;
}

.bg-nw-ks-3 {
    background-color: var(--nw-ks-3)!important;
    color: var(--nw-text-white)!important;
}

.bg-nw-ks-gcse {
    background-color: var(--nw-ks-gcse)!important;
    color: var(--nw-text-white)!important;
}

.bg-nw-ks-multi {
    background-color: var(--nw-ks-multi)!important;
    color: var(--nw-text-dark)!important;
}

.bg-nw-announce {
    background-color: var(--nw-announce)!important;
    color: var(--nw-text-white)!important;
}

.bg-nw-announce a {
    color: #9ec2f9;
}

h1, h2, h3, h4, h5, h6, a {
    font-family: Arvo;
    font-weight: 600;
}

p {
    font-family: Lato;
}

.overlay-box, .overlay-header {
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    display:flex;
    flex-direction: column;
}

.overlay-box { 
    margin-bottom:1em;
}
@media (width>576px) {
    .overlay-box {
        width: var(--width);
    }   
}

.overlay-box section {
    background-color: var(--nw-p-white);
    font-family: Lato;
    margin:var(--nw-overlay-box-padding);
    padding:1.7rem 0.6rem;
    color: var(--nw-text-dark);
    border-top: var(--nw-bar-width) solid var(--nw-p-cyan);
    border-bottom: var(--nw-bar-width) solid var(--nw-p-black);
    position:static;
}
.overlay-box section h4 {
    font-family: Lato;
}
.overlay-box section label {
    color: var(--bs-body-color);
}
@media (width > 576px) {
    .overlay-box section {
        position:relative;
        margin-top: var(--margin-top, var(--nw-overlay-box-padding));
        margin-left: var(--margin-left, var(--nw-overlay-box-padding));
    }
}

.overlay-header {
    text-align: center;
    justify-content: center;
    padding:0;
    margin-bottom:5%;
    height:15cqw;
    -webkit-text-stroke: 1px #555;
}
.overlay-header h4 {
    font-size: 5cqw;
}

.overlay-cards {
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    display:grid;
    grid-template-columns: repeat(auto-fit, minmax(19em, 1fr));
    grid-gap: 1rem;
    padding: 1rem;
}
.overlay-cards section {
    padding: 0.5em;
    border: 1px solid var(--bs-border-color);
    background-color: var(--nw-p-white);
    color: var(--nw-text-dark);
}
.overlay-cards section .pic {
    margin: -0.5em -0.5em 0.5em -0.5em;
    height:19em;
    background-size: cover;
}
.overlay-cards .buttons {
    display:flex;
    justify-content: space-between;
    flex-wrap: wrap;
    flex-direction: row;
}
.overlay-cards h6 {
    grid-column: 1 / -1;
    background-color: var(--nw-p-white);
    font-family: Lato;
    margin:var(--nw-overlay-box-padding);
    padding:1.7rem 0.6rem;
    color: var(--nw-text-dark);
    border-top: var(--nw-bar-width) solid var(--nw-p-cyan);
    border-bottom: var(--nw-bar-width) solid var(--nw-p-black);
} 
.overlay-cards div.alert {
    grid-column: 1 / -1;
}

.banner-heading .pic {
    background-position: center;
    background-size: cover;
    height: 9em;
    margin-bottom: 2em;
}

.card-scroller {
    background-color: var(--nw-p-white);
    font-family: Lato;
    margin:var(--nw-overlay-box-padding);
    padding:1.7rem 0.6rem;
    color: var(--nw-text-dark);
    border-top: var(--nw-bar-width) solid var(--nw-p-cyan);
    border-bottom: var(--nw-bar-width) solid var(--nw-p-black);
}
.card-scroller .scroll-container {
    position: relative;    
}
.card-scroller .scroll-container .scroller {
    overflow-x: scroll;
    scrollbar-width: none;
    scroll-behavior: smooth;
}
.card-scroller .grid {
    display:flex;
    margin: 0 3em;

}
.card-scroller .grid section {
    padding: 0.5em;
    flex: 0 0 15em;
    margin:1em;
    border-top: var(--nw-bar-width) solid var(--nw-p-green);
    border-left: 0.2rem solid var(--nw-p-black);
    background-color: var(--nw-p-white);
    color: var(--nw-text-dark);
    box-shadow: 5px 5px 10px #aaa;
}
.card-scroller .grid section .buttons {
    display:flex;
    justify-content: space-between;
    flex-wrap: wrap;
    flex-direction: row;

}

.card-scroller h6 {
    font-family: Lato;
    margin:var(--nw-overlay-box-padding);
    padding:1.7rem 0.6rem;
} 

.card-scroller .scroll-container .left-arrow {
    display:flex;
    align-items: center;
    justify-content: center;
    font-size: 3rem;
    position: absolute;
    top:0;
    bottom: 0;
    left:0;
}

.card-scroller .scroll-container .right-arrow {
    display:flex;
    align-items: center;
    justify-content: center;
    font-size: 3rem;
    position: absolute;
    top:0;
    bottom: 0;
    right:0;
}
.card-scroller .scroll-container .right-arrow button, .card-scroller .scroll-container .left-arrow button {
    background: none;
    border: none;
    color: #88888888;
}

.container-box { 
    margin-bottom:1em;
}
.container-box section {
    background-color: var(--nw-p-white);
    font-family: Lato;
    margin:0.4em 0;
    padding:1.7rem min(2.6em, 5%);
    color: var(--nw-text-dark);
    border-top: var(--nw-bar-width) solid var(--nw-p-cyan);
    border-bottom: var(--nw-bar-width) solid var(--nw-p-black);
}
.container-box section h4 {
    font-family: Lato;
}

.container-box .no-indent{
    margin-left: var(--nw-left-bar-margin);
}

.callout {
    background-color: var(--nw-p-white);
    padding:0.75em;
    font: 3cqw Arvo;
    border-top:0.15em solid var(--nw-p-black);
    width: fit-content;
    position: relative;
    bottom: calc(100%*-0.4);
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 0.6em;
    color: var(--nw-text-dark);
}
.callout button, .callout a {
    margin-left:auto;
    margin-right:auto;
}
@media (width > 576px) {
    .callout {
        width:100%;
        text-align: left;
        margin-bottom: 0;        
    }
    .callout button, .callout a {
        position:absolute;
        right:0;
        top:0;
        padding:0.75em 0.5em;
        margin:0;
    }
}

.side-bar {
    border-left:var(--nw-bar-width) solid var(--nw-p-cyan);
    margin-left:var(--nw-left-bar-margin);
    padding: var(--nw-left-bar-padding);
}

.banner-list {
    width:100%;
    font-size:calc(1rem + 1.4vw);
}
.banner-list ul {
    padding:0;
}
.banner-list ul li {
    list-style: none;
    padding:1em;
    position:relative;
}
.banner-list ul li button {
    font-size:0.8em;
    padding:0.4em;
    background-color: var(--nw-p-black);
    color:var(--nw-p-white);
    float:right;
}
.banner-list ul li:nth-child(n+2) {
    border-top: 1px solid var(--nw-text-dark);
}
.banner-list .drop {
    font-size:0.6em;
    font-weight:500;
}
@media (width<576px) {
    .banner-list ul li {
        padding:0.7em;
    }
    .banner-list ul li button {
        float:none;
        display:block;
        width:100%;
        margin-top:1em;
    }
    .banner-list .drop {
        display:none;
    }
}

.jumbo-pad {
    padding:2.5rem;
}

.big-fig {
    font: 14cqw Arvo;
    color: var(--nw-p-blue);
    position: relative;
    text-align: center;
}
.big-fig div {
    position:absolute;
    right:0;
    border-top: var(--nw-bar-width) solid var(--nw-p-cyan);
    font-size:.2em;
    background-color: var(--bs-body-bg);
    width:min-content;
    text-align: left;
}
@media (width<576px) {
    .big-fig {
        display:block;
        width:100%;
        margin-bottom:0.5em;
    }
    .big-fig div {
        display:block;
        position:static;
        width:100%;
        text-align:center;
    }
}

.quoted {
    font-size:0.6em;
    font-weight: 300;
    margin-left: 4em;
}

.stories {
    font: 500 4cqw "Lato";
    padding: 2em;
}

ul.nw-list {
    list-style-type: none;
    padding: 0.5em;
}
ul.nw-list li {
    display: flex;
    flex-direction: row;
    margin-bottom: 0.5em;
    padding: 0.5em;
}
ul.nw-list li>a {
    display:flex;
    flex-direction: row;
    flex-grow:1;
    color: var(--nw-text-dark);
    text-decoration: none;
}
ul.nw-list li>a .pic {
    background-size: cover;
    height: 4em;
    width: 4em;
    margin-right: 0.5em;
}
ul.nw-list li>div {
    text-align: right;
    width: min-content;
}
@media (width < 576px) {
    ul.nw-list li {
        flex-direction: column;
    }
    ul.nw-list li>div {
        width:fit-content;
    }
}
ul.nw-list li.highlight {
    background-color: var(--nw-p-green);
}

.student-badge {
    background-color: var(--nw-s-green);
    color: var(--nw-text-white);
    padding: 0.3em 0.5em;
    margin: 2px;
    max-height: 2.3em;
    border-radius: 0.4em;
}

.nw-btn {
    display: inline-block;
    background-color: var(--nw-p-black);
    color: var(--nw-p-white)!important;
    border: 1px solid var(--nw-p-black);
    padding:0.3em 0.6em;
    white-space: nowrap;
    text-decoration: none;
    margin:0.25em;
}

.nw-link {
    margin:.4em;
    font-weight: 600;
}

.x-scroller {
    width:100%;
    overflow-x: scroll;
}

.calendar {
    position:relative;
    min-width:35em;
    width:100%;
}
.calendar .calRow {
    display:flex;
    height:2em;
}
.calendar .calRow div {
    width: 11.1%;
    flex: none;
    background-color: #aaa;
    padding:0.2em;
    border: solid 1px var(--nw-text-dark);
    color: var(--nw-text-dark);
}
.calendar .calRow .dayColumn {
    width: 11.1%;
    flex: none;
} 
.calendar .lesson, .calendar .conflict {
    position: absolute;
    height: 2em;
    overflow: clip;
    padding: 0.2em;
    border: solid 1px var(--nw-text-dark);
    font-weight: 400;
    text-decoration: none;
}
.calendar .lesson.self-led {
    border: dashed 2px yellow;
}
.calendar .conflict {
    content:repeating-linear-gradient(-45deg,transparent 0 8px, white 8px 10px);
    background-color: #ff000030;
    border: solid 1px transparent;
    pointer-events: none;
}

.warning {
    visibility: hidden;
    color: var(--nw-s-brown);
}
.warning.show {
    visibility: visible;
}

.floating-ctl {
    float:right;
    margin-left: 0.5em;
    padding:0.5em;
    border: 1px solid var(--nw-text-dark);
    border-radius: 0.4em;
}

.timed-show {
    opacity: 0.1;
    transform: opacity 0.4s;
    pointer-events: none;
}
.timed-show.show {
    opacity: 1;
    pointer-events: auto;
}

.btn-flat {
    border: none;
    border-radius: 1.3em;
    padding: 0.6em;
    text-decoration: none;
    color: var(--bs-body-color);
    background-color: #88888815;
    transition: background-color .6s;
}
.btn-flat:hover {
    background-color: #888888;
}

span.underline {
    text-decoration: underline;
}

.iconic {
    display: flex;
    align-items: center;
}
.iconic div.icon {
    width: 2em;
    height: 3em;
    background-size: contain;
    background-repeat: no-repeat;
}

img.iconic {
    display:inline-block;
    width: 2em;
    height: 3em;
}

.icon-booksfall {
    background-image: url(/icon/booksfall.png);
}
.icon-faq {
    background-image: url(/icon/faq.png);
}
.icon-factsheets {
    background-image: url(/icon/factsheets.png);
}
.icon-books {
    background-image: url(/icon/books.png);
}
.icon-www {
    background-image: url(/icon/www.png);
}
.icon-pencil {
    background-image: url(/icon/pencil.png);
}
.icon-trash {
    background-image: url(/icon/trash.png);
}
