i {
    margin-right:0.325rem;
}

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

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

    &::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;
    li {
        padding: 0.5em;
        margin: 0.5em;
    }
}

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

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

ul.nw-alternate-shaded-list {
    list-style-type: none;
    padding: 0;
    li {
        padding: 0.2em;
        margin : 0.2em;
    }
    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);
}

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

[data-bs-theme=light] {
    --bs-body-bg: #eaeaea;
    .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;
}

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;
    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;
        h4 {
            font-family: Lato;
        }
        label {
            color: var(--bs-body-color);
        }
        @media (width > 576px) {
            position:relative;
            margin-top: var(--margin-top, var(--nw-overlay-box-padding));
            margin-left: var(--margin-left, var(--nw-overlay-box-padding));
        }
    }
    @media (width>576px) {
        width: var(--width);
    }
}

.overlay-header {
    text-align: center;
    justify-content: center;
    padding:0;
    margin-bottom:5%;
    height:15cqw;
    -webkit-text-stroke: 1px #555;
    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;

    section {
        padding: 0.5em;
        border: 1px solid var(--bs-border-color);
        background-color: var(--nw-p-white);
        color: var(--nw-text-dark);
        .pic {
            margin: -0.5em -0.5em 0.5em -0.5em;
            height:19em;
            background-size: cover;
        }
        .buttons {
            display:flex;
            justify-content: space-between;
            flex-wrap: wrap;
            flex-direction: row;

        }
    }

    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);
    } 

    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);

    .scroll-container {
        position: relative;
        
        .scroller {
            overflow-x: scroll;
            scrollbar-width: none;
            scroll-behavior: smooth;

            .grid {
                display:flex;
                margin: 0 3em;

                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;
                    .buttons {
                        display:flex;
                        justify-content: space-between;
                        flex-wrap: wrap;
                        flex-direction: row;

                    }
                }
            }

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

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

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

.container-box { 
    margin-bottom:1em;
    section {
        background-color: var(--nw-p-white);
        font-family: Lato;
        margin:0.4em 0;
        padding:1.7rem 2.6em;
        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);
        h4 {
            font-family: Lato;
        }
    }

    .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);
    button, a {
        margin-left:auto;
        margin-right:auto;
    }
    @media (width > 576px) {
        width:100%;
        text-align: left;
        margin-bottom: 0;
        button, 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);
    ul {
        padding:0;
        li {
            list-style: none;
            padding:1em;
            position:relative;
            button {
                font-size:0.8em;
                padding:0.4em;
                background-color: var(--nw-p-black);
                color:var(--nw-p-white);
                float:right;
            }
            &:nth-child(n+2) {
                border-top: 1px solid var(--nw-text-dark);
            }
        }
    }
    .drop {
        font-size:0.6em;
        font-weight:500;
    }
    @media (width<576px) {
        ul li {
            padding:0.7em;
            button {
                float:none;
                display:block;
                width:100%;
                margin-top:1em;
            }
        }
        .drop {
            display:none;
        }
    }
}

.jumbo-pad {
    padding:2.5rem;
}

.big-fig {
    font: 14cqw Arvo;
    color: var(--nw-p-blue);
    position: relative;
    text-align: center;
    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) {
        display:block;
        width:100%;
        margin-bottom:0.5em;
        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;
    li {
        display: flex;
        flex-direction: row;
        margin-bottom: 0.5em;
        padding: 0.5em;
        &>a {
            display:flex;
            flex-direction: row;
            flex-grow:1;
            color: var(--nw-text-dark);
            text-decoration: none;
            .pic {
                background-size: cover;
                height: 4em;
                width: 4em;
                margin-right: 0.5em;
            }
        }
        &>div {
            text-align: right;
            width: min-content;
        }
        @media (width < 576px) {
            flex-direction: column;
            &>div {
                width:fit-content;
            }
        }
        &.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;
}

.chat{
    border: 1px solid #aaa;
    border-radius: .65em;
    padding: .5em;
    display:flex;
    flex-direction: column;
    list-style: none;
    div {
        width:fit-content;
        max-width:75%;
        background-color: #77777740;
        border-radius: 0.4em;
        padding: .2em 1em;
        margin: .2em 1em;
        span.name {
            display:block;
            font-size:.7em;
            font-weight:800;
        }
    }
    div.me {
        align-self:end;
        background-color: var(--nw-s-blue);
    }
}

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

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

.warning {
    visibility: hidden;
    color: var(--nw-s-brown);
    &.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;
    &.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;
    &:hover {
        background-color: #888888;
    }
}

span.strike {
    text-decoration: line-through;
}

.iconic {
    display: flex;
    align-items: center;
    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);
}
