@import url('https://fonts.googleapis.com/css2?family=Abril+Fatface&family=Arbutus+Slab&family=Lato:wght@400;600;700&family=Montserrat:wght@500;600&display=swap');

:root {
    --color-brand: #a4ab32;
    --color-brand-soft: #d7e578;
    --color-brand-deep: #7f8720;
    --color-olive-950: #283124;
    --color-olive-900: #364232;
    --color-olive-800: #4a4f32;
    --color-olive-700: #66724d;
    --color-olive-500: var(--color-brand);
    --color-olive-200: #dce1bf;
    --color-olive-100: #f0f3e3;
    --color-cream: #f7f4ec;
    --color-paper: #fffdfa;
    --color-ink: #20241c;
    --color-muted: #5a6253;
    --color-soft-ink: #2a3025;
    --color-on-image: #f6f3eb;
    --color-on-image-muted: rgba(246, 243, 235, 0.84);
    --color-line: rgba(74, 79, 50, 0.16);
    --color-shadow: rgba(19, 25, 18, 0.18);
    --hero-overlay: linear-gradient(135deg, rgba(28, 33, 24, 0.74), rgba(55, 66, 50, 0.38));
    --radius-lg: 28px;
    --radius-md: 18px;
    --radius-sm: 12px;
    --shadow-lg: 0 28px 80px rgba(23, 29, 20, 0.22);
    --shadow-md: 0 14px 34px rgba(23, 29, 20, 0.14);
    --shadow-sm: 0 8px 20px rgba(23, 29, 20, 0.08);
    --container-width: 1240px;
    --sidebar-width: 250px;
    --content-width: 760px;
}

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

html {
    min-height: 100%;
    background: #dfe4ce;
}

body {
    position: relative;
    margin: 0;
    min-height: 100vh;
    color: var(--color-ink);
    background: #dfe4ce;
    font-family: "Lato", Arial, sans-serif;
    font-size: 16px;
    line-height: 1.65;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    isolation: isolate;
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    background:
        linear-gradient(180deg, rgba(21, 27, 19, 0.56), rgba(21, 27, 19, 0.42) 26%, rgba(21, 27, 19, 0.26) 58%, rgba(21, 27, 19, 0.38) 100%),
        var(--page-background-image, url("../img/wp-reference/IMG_3875.jpg")) center center / cover no-repeat;
    z-index: -1;
}

img {
    max-width: 100%;
    height: auto;
}

a {
    color: var(--color-olive-700);
    text-decoration-thickness: 1px;
    text-underline-offset: 0.18em;
}

a:hover {
    color: var(--color-olive-500);
}

p,
li,
td {
    color: var(--color-soft-ink);
    line-height: 1.72;
}

p {
    margin: 0 0 1.05rem;
}

h1,
h2,
h3,
h4 {
    margin: 0 0 0.8rem;
    line-height: 1.12;
}

table {
    max-width: 100%;
}

input,
textarea,
select,
button {
    font: inherit;
}

.text10,
.text11,
.text12,
.text13,
.text14,
.text16,
.text18,
.head,
body,
td {
    font-family: "Lato", Arial, sans-serif;
}

.text10 { font-size: 0.78rem; line-height: 1.5; }
.text11 { font-size: 0.85rem; line-height: 1.56; }
.text12, body, td { font-size: 1rem; line-height: 1.7; }
.text13 { font-size: 1.04rem; line-height: 1.7; }
.text14 { font-size: 1.12rem; line-height: 1.65; }
.text16 { font-size: 1.24rem; line-height: 1.5; }
.text18 { font-size: 1.65rem; line-height: 1.25; }
.head {
    font-family: "Arbutus Slab", serif;
    font-size: 2rem;
    line-height: 1.1;
}

.lgreen { color: var(--color-olive-500); }
.llgreen { color: var(--color-olive-100); }
.dgreen { color: var(--color-olive-800); }
.oliv { color: #939878; }
.bold { font-weight: 700; }

.imenu,
.isub {
    color: var(--color-olive-800);
}

.amenu,
.asub {
    color: var(--color-olive-500);
}

.imenu,
.amenu {
    line-height: 1.35;
    font-size: 1.02rem;
}
