/* WSCRA Portal — elderly-friendly styling
   Principles: large type, high contrast, generous spacing, clear affordances. */

:root {
    --ink:        #1a1a1a;
    --ink-soft:   #3b3b3b;
    --paper:      #faf7f2;
    --paper-edge: #ede7d9;
    --sage:       #4a6b5c;
    --sage-dark:  #34503f;
    --sage-bg:    #e8efe9;
    --warn:       #8a4a2a;
    --rule:       #d6cfbf;
    --shadow:     0 1px 3px rgba(0,0,0,0.06);

    --radius:     6px;
    --pad:        1.25rem;
}

* { box-sizing: border-box; }

html {
    font-size: 20px; /* elderly-friendly base */
    -webkit-text-size-adjust: 100%;
    scroll-behavior: smooth;
}
html.font-large  { font-size: 22px; }
html.font-xlarge { font-size: 25px; }

body {
    margin: 0;
    background: var(--paper);
    color: var(--ink);
    font-family: Georgia, "Liberation Serif", "Times New Roman", serif;
    line-height: 1.65;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.skip-link {
    position: absolute;
    top: -100px;
    left: 0;
    background: var(--ink);
    color: var(--paper);
    padding: 0.75rem 1rem;
    z-index: 100;
}
.skip-link:focus { top: 0; }

/* Header */
.site-header {
    background: var(--sage-dark);
    color: #fff;
    border-bottom: 4px solid var(--sage);
}
.site-header__inner {
    max-width: 860px;
    margin: 0 auto;
    padding: 1.75rem var(--pad) 1rem;
}
.site-header__title {
    margin: 0;
    color: #fff;                    /* override h1 dark colour so it's readable on the dark header */
    font-size: 1.6rem;
    font-weight: normal;
    letter-spacing: 0.01em;
}
.site-header__tag {
    margin: 0.15rem 0 0;
    color: rgba(255,255,255,0.92);
    font-size: 0.9rem;
    font-style: italic;
}

/* Top nav */
.nav {
    background: var(--sage);
    border-bottom: 1px solid var(--sage-dark);
}
.nav__inner {
    max-width: 860px;
    margin: 0 auto;
    padding: 0 var(--pad);
    display: flex;
    flex-wrap: wrap;
    gap: 0;
}
.nav a,
.nav a:visited {
    display: inline-flex;
    align-items: center;
    min-height: 56px;
    padding: 0.5rem 1.1rem;
    color: #fff;                    /* lock white text on dark nav in every state */
    text-decoration: none;
    font-weight: 600;
    border-bottom: 3px solid transparent;
}
.nav a:hover,
.nav a:focus,
.nav a:active {
    color: #fff;                    /* explicit: never goes dark */
    background: rgba(255,255,255,0.14);
    outline: none;
    border-bottom-color: #fff;
}
.nav a.is-active,
.nav a.is-active:hover,
.nav a.is-active:focus,
.nav a.is-active:visited {
    background: var(--paper);
    color: var(--sage-dark);        /* dark text on light active tab */
    border-bottom-color: var(--paper);
}
.nav .nav__right { margin-left: auto; }

/* Font-size toggle in nav */
.font-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.15rem;
    padding-right: 0.5rem;
}
.font-toggle__label {
    color: rgba(255,255,255,0.85);
    font-size: 0.85rem;
    font-weight: normal;
    margin-right: 0.35rem;
}
.font-toggle a,
.font-toggle a:visited {
    min-height: 40px;
    padding: 0.25rem 0.55rem;
    color: #fff;
    font-weight: bold;
    border-radius: 4px;
    line-height: 1;
    border-bottom: none !important;
    background: transparent;
}
.font-toggle a:hover,
.font-toggle a:focus {
    background: rgba(255,255,255,0.14);
    color: #fff;
    border-bottom: none !important;
}
.font-toggle a.is-active,
.font-toggle a.is-active:hover,
.font-toggle a.is-active:focus {
    background: #fff;
    color: var(--sage-dark);
}
.font-toggle__signout {
    margin-left: 0.5rem;
    padding-left: 0.8rem !important;
    border-left: 1px solid rgba(255,255,255,0.25);
}
@media (max-width: 540px) {
    .font-toggle__label { display: none; }
    .font-toggle a { padding: 0.25rem 0.45rem; }
}

/* Main */
main {
    flex: 1;
    max-width: 860px;
    width: 100%;
    margin: 0 auto;
    padding: 2rem var(--pad) 3rem;
}

h1, h2, h3 { color: var(--ink); line-height: 1.3; }
h1 {
    font-size: 2rem;
    margin: 0 0 0.75rem;
    font-weight: normal;
}
h2 {
    font-size: 1.45rem;
    margin: 2rem 0 0.75rem;
    padding-bottom: 0.4rem;
    border-bottom: 2px solid var(--rule);
    font-weight: normal;
}
h3 {
    font-size: 1.15rem;
    margin: 1.4rem 0 0.4rem;
    font-weight: bold;
}

p { margin: 0 0 1rem; }

a { color: var(--sage-dark); }
a:hover, a:focus { color: var(--ink); }

/* Cards */
.card {
    background: #fff;
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    padding: 1.25rem 1.35rem;
    margin: 0 0 1rem;
    box-shadow: var(--shadow);
}
.card h3 {
    margin-top: 0;
}
.card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
    font-size: 0.85rem;
    color: var(--ink-soft);
}

.badge {
    display: inline-block;
    padding: 0.15rem 0.55rem;
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: bold;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    font-family: -apple-system, "Segoe UI", Helvetica, Arial, sans-serif;
}
.badge--completed  { background: var(--sage-bg); color: var(--sage-dark); }
.badge--progress   { background: #fff3dc; color: #7a5418; }
.badge--upcoming   { background: #e8eef6; color: #2e4a72; }
.badge--idea       { background: #f3eaf9; color: #5b2e7a; }
.badge--hs         { background: #fde3df; color: #8a2010; }

.card--priority {
    border-left: 5px solid #8a2010;
}
.section-intro {
    color: var(--ink-soft);
    font-style: italic;
    margin: -0.5rem 0 1rem;
}

/* Forms */
form { margin: 0; }
label {
    display: block;
    font-weight: bold;
    margin-bottom: 0.4rem;
    font-size: 1rem;
}
.form-row { margin-bottom: 1.25rem; }
.form-help {
    color: var(--ink-soft);
    font-size: 0.9rem;
    font-style: italic;
    margin-top: 0.3rem;
}
input[type="text"],
input[type="password"],
input[type="email"],
input[type="tel"],
textarea {
    display: block;
    width: 100%;
    min-height: 52px;
    font-family: inherit;
    font-size: 1rem;
    padding: 0.6rem 0.85rem;
    border: 2px solid var(--rule);
    border-radius: var(--radius);
    background: #fff;
    color: var(--ink);
}
input:focus, textarea:focus {
    outline: none;
    border-color: var(--sage);
    box-shadow: 0 0 0 3px rgba(74,107,92,0.2);
}

.btn,
a.btn,
a.btn:visited,
a.btn:any-link {
    display: inline-block;
    min-height: 56px;
    padding: 0.75rem 1.5rem;
    font-family: inherit;
    font-size: 1.05rem;
    font-weight: bold;
    color: #fff !important;           /* hard-pin against cascade surprises */
    background: var(--sage-dark);
    border: 2px solid var(--sage-dark);
    border-radius: var(--radius);
    cursor: pointer;
    text-decoration: none;
    line-height: 1.2;
    -webkit-tap-highlight-color: transparent;
}
.btn:hover, .btn:focus, .btn:active,
a.btn:hover, a.btn:focus, a.btn:active {
    color: #fff !important;
    background: var(--ink);
    border-color: var(--ink);
    outline: none;
}
.btn--secondary,
a.btn--secondary,
a.btn--secondary:visited,
a.btn--secondary:any-link {
    background: #fff;
    color: var(--sage-dark) !important;  /* hard-pin against cascade surprises */
    border-color: var(--rule);
}
.btn--secondary:hover, .btn--secondary:focus, .btn--secondary:active,
a.btn--secondary:hover, a.btn--secondary:focus, a.btn--secondary:active {
    background: var(--paper);
    color: var(--ink) !important;
    border-color: var(--ink);
}

/* Radio group (used for floor selection) */
.radio-group {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    margin-top: 0.2rem;
}
.radio-option {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    min-height: 52px;
    padding: 0.35rem 0.85rem;
    font-weight: normal;
    background: #fff;
    border: 2px solid var(--rule);
    border-radius: var(--radius);
    cursor: pointer;
    margin: 0;
}
.radio-option input[type="radio"] {
    width: 22px;
    height: 22px;
    margin: 0;
    accent-color: var(--sage-dark);
}
.radio-option:has(input:checked) {
    border-color: var(--sage);
    background: var(--sage-bg);
}

/* Field-level errors (below individual inputs) */
.field-error {
    color: #8a2020;
    background: #fdecec;
    border-left: 4px solid #b03030;
    padding: 0.5rem 0.75rem;
    margin: 0.45rem 0 0;
    border-radius: 0 4px 4px 0;
    font-size: 0.95rem;
}

/* Alerts */
.alert {
    padding: 0.9rem 1.1rem;
    border-radius: var(--radius);
    margin: 0 0 1.25rem;
    border-left: 5px solid;
}
.alert--error   { background: #fdecec; border-color: #b03030; color: #5a1414; }
.alert--info    { background: var(--sage-bg); border-color: var(--sage); color: var(--sage-dark); }

/* Subtle meta line under welcome */
.subtle-meta {
    color: var(--ink-soft);
    font-size: 0.95rem;
    margin-top: -0.5rem;
    margin-bottom: 1rem;
}

.h2-meta {
    font-size: 0.85rem;
    color: var(--ink-soft);
    font-weight: normal;
    font-style: italic;
}

/* Small button variant */
.btn--small {
    min-height: 44px;
    padding: 0.45rem 0.9rem;
    font-size: 0.95rem;
}

/* Page TOC (Info page jump links) */
.page-toc {
    background: #fff;
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    padding: 0.85rem 1.1rem;
    margin: 0 0 1.75rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem 1rem;
    align-items: center;
}
.page-toc strong { margin-right: 0.25rem; }
.page-toc ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1rem;
}
.page-toc ul a {
    display: inline-block;
    padding: 0.2rem 0;
    text-decoration: underline;
    text-underline-offset: 3px;
}
.page-toc .btn { margin-left: auto; }
@media (max-width: 540px) {
    .page-toc .btn { margin-left: 0; width: 100%; }
}

/* Info boxes (for gate code etc) */
.info-tile {
    background: #fff;
    border: 1px solid var(--rule);
    border-left: 5px solid var(--sage);
    border-radius: var(--radius);
    padding: 1rem 1.25rem;
    margin: 0 0 1rem;
}
.info-tile h3 { margin: 0 0 0.35rem; font-size: 1.1rem; }
.info-tile .code {
    display: inline-block;
    padding: 0.35rem 0.7rem;
    margin: 0.25rem 0;
    font-family: Menlo, "Courier New", monospace;
    font-size: 1.3rem;
    background: var(--paper-edge);
    border-radius: 4px;
    letter-spacing: 0.05em;
}

/* Footer */
.site-footer {
    background: var(--paper-edge);
    border-top: 1px solid var(--rule);
    color: var(--ink-soft);
    padding: 1.5rem var(--pad);
    text-align: center;
    font-size: 0.9rem;
}
.site-footer a { color: var(--ink-soft); }

/* Login page layout */
.login-hero {
    max-width: 460px;
    margin: 2.5rem auto;
    padding: 2rem 1.75rem;
    background: #fff;
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
}
.login-hero h1 { margin-top: 0; text-align: center; }
.login-hero .form-help { text-align: center; }

/* Small screens */
@media (max-width: 540px) {
    html { font-size: 18px; }
    .site-header__inner { padding: 1.25rem 1rem 0.75rem; }
    .nav__inner { padding: 0; }
    .nav a { padding: 0.5rem 0.9rem; min-height: 52px; }
    .nav .nav__right { margin-left: 0; }
    main { padding: 1.25rem 1rem 2rem; }
    h1 { font-size: 1.7rem; }
    h2 { font-size: 1.3rem; }
}

/* Admin stats grid */
.admin-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 1rem;
    margin: 1.5rem 0 2rem;
}
.stat-card {
    background: #fff;
    border: 1px solid var(--rule);
    border-left: 5px solid var(--sage);
    border-radius: var(--radius);
    padding: 1rem 1.1rem;
    text-align: left;
}
.stat-num {
    font-size: 2rem;
    font-weight: bold;
    color: var(--sage-dark);
    line-height: 1.1;
}
.stat-label {
    color: var(--ink-soft);
    font-size: 0.9rem;
    margin-top: 0.15rem;
}

/* Data tables (admin) */
.table-wrap {
    overflow-x: auto;
    margin: 0 0 2rem;
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    background: #fff;
}
.data-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.95rem;
}
.data-table th,
.data-table td {
    text-align: left;
    padding: 0.6rem 0.8rem;
    border-bottom: 1px solid var(--rule);
    vertical-align: top;
}
.data-table th {
    background: var(--paper-edge);
    font-weight: bold;
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--ink-soft);
}
.data-table tr:last-child td { border-bottom: none; }
.data-table--compact td,
.data-table--compact th { padding: 0.4rem 0.75rem; font-size: 0.9rem; }
.data-table small { display: block; color: var(--ink-soft); font-size: 0.8rem; }

.muted-list { color: var(--ink-soft); }

/* Select dropdown */
select {
    display: block;
    width: 100%;
    min-height: 52px;
    font-family: inherit;
    font-size: 1rem;
    padding: 0.6rem 0.85rem;
    border: 2px solid var(--rule);
    border-radius: var(--radius);
    background: #fff;
    color: var(--ink);
}
select:focus {
    outline: none;
    border-color: var(--sage);
    box-shadow: 0 0 0 3px rgba(74,107,92,0.2);
}

/* Welcome hint banner */
.welcome-hint {
    background: var(--sage-bg);
    border: 1px solid var(--sage);
    border-radius: var(--radius);
    padding: 1rem 1.25rem;
    margin: 0 0 1.5rem;
    position: relative;
}
.welcome-hint h2 {
    margin: 0 0 0.35rem;
    border: none;
    padding: 0;
    font-size: 1.1rem;
    color: var(--sage-dark);
}
.welcome-hint p { margin: 0 0 0.35rem; font-size: 0.95rem; }
.welcome-hint .dismiss {
    position: absolute;
    top: 0.5rem; right: 0.5rem;
    background: transparent;
    border: none;
    color: var(--sage-dark);
    font-size: 1.3rem;
    cursor: pointer;
    line-height: 1;
    padding: 0.3rem 0.5rem;
}

/* Voting controls on idea cards */
.vote-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.8rem 1.2rem;
    margin-top: 0.75rem;
    padding-top: 0.75rem;
    border-top: 1px solid var(--rule);
}
.vote-form { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.btn-vote {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    min-height: 44px;
    padding: 0.4rem 0.9rem;
    font-family: inherit;
    font-size: 0.95rem;
    background: #fff;
    color: var(--ink);
    border: 2px solid var(--rule);
    border-radius: var(--radius);
    cursor: pointer;
    font-weight: bold;
}
.btn-vote:hover, .btn-vote:focus {
    border-color: var(--sage);
    background: var(--sage-bg);
}
.btn-vote--for:hover,  .btn-vote--for:focus  { border-color: #2b662b; background: #e7f2e7; }
.btn-vote--against:hover, .btn-vote--against:focus { border-color: #8a3030; background: #fce7e7; }
.btn-vote--retract {
    background: transparent;
    border: none;
    padding: 0.3rem 0.5rem;
    color: var(--ink-soft);
    text-decoration: underline;
    font-weight: normal;
    font-size: 0.9rem;
    min-height: auto;
}
.vote-mine { font-weight: bold; }
.vote-mine--for     { color: #2b662b; }
.vote-mine--against { color: #8a3030; }
.vote-tally {
    color: var(--ink-soft);
    font-size: 0.95rem;
    margin-left: auto;
}
@media (max-width: 540px) {
    .vote-tally { margin-left: 0; width: 100%; }
}

/* ======= Flats page — building elevation layout ======= */
.buildings {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
    margin-top: 1.5rem;
}
@media (min-width: 780px) {
    .buildings {
        grid-template-columns: 1fr 1fr;
    }
}
.building {
    background: var(--paper-edge);
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    padding: 1rem 1.1rem 1.25rem;
}
.building h2 {
    margin: 0 0 0.75rem;
    border-bottom: none;
    padding-bottom: 0;
    font-size: 1.15rem;
}
.elevation {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    background: #fff;
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    overflow: hidden;
}
.floor {
    display: grid;
    grid-template-columns: 92px 1fr;   /* wider so "Ground" never overflows */
    align-items: stretch;
    border-bottom: 1px solid var(--rule);
    background: #fdfbf7;
}
.floor:last-child { border-bottom: none; }
.floor--ground { background: #f5efe3; }
.floor__label {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.5rem 0.6rem;
    background: var(--paper-edge);
    border-right: 1px solid var(--rule);
    font-size: 0.9rem;
    color: var(--ink-soft);
    font-weight: bold;                 /* no uppercase, no letter-spacing */
    text-align: center;
    white-space: nowrap;
}
.floor__flats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 1px;
    background: var(--rule);
}
.flat {
    background: #fff;
    padding: 0.65rem 0.85rem;
    position: relative;
    min-height: 76px;
}
.flat--live  { background: #fff; }
.flat--empty { background: #faf7f2; color: var(--ink-soft); }
.flat--mine  { outline: 3px solid var(--sage); outline-offset: -3px; }
.flat__header {
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 0.4rem 0.5rem;
    margin-bottom: 0.2rem;
}
.flat__num {
    font-weight: bold;
    font-size: 1rem;
    color: var(--ink);
}
.flat__director {
    color: #8a6a10;
    font-size: 0.7rem;
    font-weight: bold;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.flat__me {
    background: var(--sage);
    color: #fff;
    font-size: 0.65rem;
    font-weight: bold;
    padding: 0.08rem 0.45rem;
    border-radius: 999px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.flat__name {
    font-weight: 600;
    font-size: 0.95rem;
    line-height: 1.2;
}
.flat__name--muted {
    color: var(--ink-soft);
    font-weight: normal;
    font-style: italic;
    font-size: 0.85rem;
}
.flat__email {
    font-size: 0.8rem;
    margin-top: 0.2rem;
    word-break: break-all;
    color: var(--ink-soft);
}
.flat__email a { color: var(--sage-dark); }

/* Homepage hero photo */
.hero {
    margin: 0 0 1.5rem;
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow);
    background: var(--paper-edge);
    position: relative;
}
.hero img {
    display: block;
    width: 100%;
    max-height: 420px;
    object-fit: cover;
}
.hero figcaption {
    padding: 0.5rem 1rem;
    font-size: 0.9rem;
    color: var(--ink-soft);
    font-style: italic;
    background: #fff;
    border-top: 1px solid var(--rule);
}

/* Poll option cards */
.poll-options {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
    margin: 1.5rem 0;
}
@media (min-width: 720px) {
    .poll-options { grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); }
}
.poll-option {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 1rem;
    background: #fff;
    border: 2px solid var(--rule);
    border-radius: var(--radius);
    padding: 1rem 1.2rem;
    cursor: pointer;
    align-items: start;
    box-shadow: var(--shadow);
}
.poll-option:has(input[type="radio"]:checked),
.poll-option--mine {
    border-color: var(--sage);
    background: var(--sage-bg);
}
.poll-option:hover { border-color: var(--sage); }
.poll-option input[type="radio"] {
    width: 22px;
    height: 22px;
    margin-top: 0.2rem;
    accent-color: var(--sage-dark);
}
.poll-option__photo {
    grid-column: 1 / -1;
    margin-bottom: 0.5rem;
}
.poll-option__photo img {
    width: 100%;
    max-height: 220px;
    object-fit: cover;
    border-radius: 4px;
    display: block;
}
.poll-option__body { min-width: 0; }
.poll-option__label { font-weight: bold; font-size: 1.1rem; margin-bottom: 0.3rem; }
.poll-option__desc  { color: var(--ink-soft); font-size: 0.95rem; margin-bottom: 0.6rem; }
.poll-option__bar {
    background: var(--paper-edge);
    height: 10px;
    border-radius: 5px;
    overflow: hidden;
    margin: 0.4rem 0 0.3rem;
}
.poll-option__bar-fill {
    background: var(--sage);
    height: 100%;
    transition: width 0.4s ease;
}
.poll-option__tally {
    font-size: 0.9rem;
    color: var(--ink-soft);
}
.poll-option__you { font-weight: bold; color: var(--sage-dark); }

/* Admin — multi-option builder */
.poll-option-form {
    background: var(--paper);
    border: 1px dashed var(--rule);
    border-radius: var(--radius);
    padding: 0.75rem 1rem 0.2rem;
    margin-bottom: 1rem;
}
.poll-option-form .form-row { margin-bottom: 0.75rem; }

/* Admin photo grid */
.photo-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 1rem;
    margin: 1rem 0 2rem;
}
.photo-card {
    background: #fff;
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.photo-card img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    display: block;
}
.photo-card__meta {
    padding: 0.6rem 0.8rem;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    font-size: 0.9rem;
}
.photo-card__meta small { color: var(--ink-soft); font-size: 0.8rem; }
.photo-card__actions {
    display: flex;
    gap: 0.5rem;
    margin-top: 0.4rem;
    align-items: center;
}
.photo-card__actions select {
    min-height: 36px;
    font-size: 0.85rem;
    padding: 0.25rem 0.4rem;
    width: auto;
    flex: 1;
}

/* Report photos thumbnails (admin) */
.report-photos {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    margin-top: 0.5rem;
}
.report-photos img {
    width: 80px;
    height: 80px;
    object-fit: cover;
    border-radius: 4px;
    border: 1px solid var(--rule);
}

/* Print friendly */
@media print {
    .nav, .site-footer, .skip-link { display: none; }
    body { background: #fff; }
}
