/* ============================================================
   ZEROPOINT — UNIFIED THEME (dark default, light via data-theme)
   ============================================================
   Structure:
   - Font faces
   - Theme variables (:root = dark, [data-theme="light"] = light)
   - Base / global
   - Brand (.zeropoint, .fw, .menu-selection)
   - Navbar (top nav, mobile breakpoint, hamburger)
   - Links (general, .zen, .quiet, .noline, nav-specific)
   - Dropdowns (media/articles menus)
   - Search & form controls (.search input in navbar)
   - Theme toggle (dark/light slider button)
   - Footer (.bg-footer, .copyright)
   - Typography (h5, .subtitle, .tinytext, .text-small, .author)
   - Cards (generic .card, titles, headings, header/body/footer)
   - Card background tints (.card-bg-green, -blue, -pink, etc.)
   - Article cards (article .card-header/body, grid-layout, single-layout)
   - Sidebar cards (aside.sidebar .card-header/body/footer)
   - Utility classes (.zbot, .zpbot, .zpadbot, .zpadtop, etc.)
   - Go-to-top links (.gotop)
   - Zoom Search Engine results (search.php output)
   ============================================================ */


/* ----------------------------------------------------------
   FONT FACES
   Loaded from /css/fonts/ — four weights: regular, italic,
   semibold, semibold-italic. Used site-wide via body rule.
   ---------------------------------------------------------- */
@font-face {
  font-family: "opensans";
  src: url("/css/fonts/opensans-regular-webfont.woff2") format("woff2"),
    url("/css/fonts/opensans-regular-webfont.woff") format("woff");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "opensans";
  src: url("/css/fonts/opensans-italic-webfont.woff2") format("woff2"),
    url("/css/fonts/opensans-italic-webfont.woff") format("woff");
  font-weight: normal;
  font-style: italic;
}
@font-face {
  font-family: "opensans";
  src: url("/css/fonts/opensans-semibold-webfont.woff2") format("woff2"),
    url("/css/fonts/opensans-semibold-webfont.woff") format("woff");
  font-weight: bold;
  font-style: normal;
}
@font-face {
  font-family: "opensans";
  src: url("/css/fonts/opensans-semibolditalic-webfont.woff2") format("woff2"),
    url("/css/fonts/opensans-semibolditalic-webfont.woff") format("woff");
  font-weight: bold;
  font-style: italic;
}

/* ----------------------------------------------------------
   THEME VARIABLES — DARK (default)
   Applied to :root so all var() references resolve to dark
   values unless [data-theme="light"] is set on <html>.
   ---------------------------------------------------------- */
:root {
  /* <body> background & text */
  --body-color: #999;
  --body-bg: #111;
  --body-bg-image: url("/images/common/zeropoint_bg.gif");

  /* Brand: .zeropoint text in navbar-brand, .fw featured word,
     .menu-selection highlighted nav item */
  --zeropoint-color: #444;
  --brand-hover: #37e01a;
  --fw-color: gold;
  --fw-weight: 200;
  --menu-selection-color: #f73a98;

  /* <footer> bar at bottom (.bg-footer) */
  --footer-bg: #222;
  --footer-color: #999;
  --footer-shadow: 0 0px 4px rgba(255, 255, 255, 0.5);

  /* Global a:link / a:hover */
  --link-color: #2a9fff;
  --link-hover: #f73a98;

  /* Top navbar: nav a links, background, shadow, active page */
  --nav-link-color: #2a9fff;
  --nav-hover: #37e01a;
  --navbar-bg: #222;
  --navbar-shadow: 0 0 4px 0 rgba(255, 255, 255, 0.5);
  --nav-active-color: #ffd700;                 /* .nav-active class */

  /* Dropdown menus (media / articles) */
  --dropdown-bg: #222;
  --dropdown-item-color: #2a9fff;
  --dropdown-hover-bg: #333;
  --dropdown-hover-color: #fff;
  --dropdown-toggle-color: #2a9fff;

  /* Search input in navbar (.form-control.search) */
  --search-bg: #333;
  --search-border: #666;
  --search-focus-bg: #444;
  --search-focus-border: #666;
  --search-placeholder-color: #999;

  /* Generic form controls (contact forms, etc.) */
  --form-control-bg: #000;
  --form-control-border: #666;
  --form-control-color: #999;

  /* Footer copyright text (.copyright) */
  --copyright-color: #999;

  /* Card titles: h1–h4.card-title, .card h4/h5 headings */
  --card-title-color: #f73a98;
  --card-heading-color: #f73a98;
  --card-border-color: #555;

  /* Card structural parts (.card-header/body/footer) — generic */
  --card-header-color: #999;
  --card-body-color: #999;
  --card-body-bg: #222;
  --card-footer-color: #999;

  /* Article page cards (article .card-header/body) */
  --article-card-header-bg: #222;
  --article-card-body-bg: #222;

  /* Article grid cards — two-column video grid on index
     (article.grid-layout .card-header/body/footer) */
  --grid-header-color: #999;
  --grid-header-bg: #222;
  --grid-body-color: #999;
  --grid-body-bg: #222;
  --grid-footer-color: #999;
  --grid-footer-bg: #222;
  --grid-footer-heading-bg: #000;

  /* Sidebar cards (aside.sidebar .card-header/body/footer) */
  --sidebar-header-color: #f73a98;
  --sidebar-header-bg: #222;
  --sidebar-body-color: #999;
  --sidebar-body-bg: #222;
  --sidebar-footer-color: #999;
  --sidebar-footer-bg: #222;

  /* .subtitle span used under headings */
  --subtitle-color: #999;

  /* Card background tints — applied via .card-bg-* classes
     on card-header/body/footer to colour-code content areas */
  --card-bg-green: #26321B;
  --card-bg-blue: #1A2632;
  --card-bg-blue-dk: #171A35;
  --card-bg-pink: #4D002D;
  --card-bg-pink-dk: #371529;
  --card-bg-purple: #1A2732;
  --card-bg-tint-dk: #262626;

  /* Misc */
  --description-color: #999;                   /* Zoom search .description */
  --searchheading-color: #999;                 /* Zoom search .searchheading */
  --hamburger-icon: url("/images/common/hamburger_green_dk.svg");
  --quiet-link-opacity: 1;                     /* a.quiet link opacity */
  --del-color: #666;                           /* <del> in card-body */
}

/* ----------------------------------------------------------
   THEME VARIABLES — LIGHT OVERRIDES
   Set via data-theme="light" on <html> by the theme toggle JS.
   Only values that differ from dark are listed here.
   ---------------------------------------------------------- */
[data-theme="light"] {
  --body-color: #222;
  --body-bg: #fff;
  --body-bg-image: url("/images/common/zeropoint_bg3.gif");

  --zeropoint-color: #c9c9c9;
  --brand-hover: #2a9d4a;
  --fw-color: #e9358f;
  --fw-weight: 400;
  --menu-selection-color: #e9358f;

  --footer-bg: #f1eee2;
  --footer-color: #555;
  --footer-shadow: 0 -2px 4px rgba(119, 119, 119, 0.4);

  --link-color: #0c89f0;
  --link-hover: #e9358f;

  --nav-link-color: #0c89f0;
  --nav-hover: #e9358f;
  --navbar-bg: #f1eee2;
  --navbar-shadow: 0 0 4px 0 rgba(0, 0, 0, 0.4);
  --nav-active-color: #e9358f;

  --dropdown-bg: #f1eee2;
  --dropdown-item-color: #0c89f0;
  --dropdown-hover-bg: #d1cfc5;
  --dropdown-hover-color: #0c89f0;
  --dropdown-toggle-color: #0c89f0;

  --search-bg: #d1cfc5;
  --search-border: #837b68;
  --search-focus-bg: #d1cfc5;
  --search-focus-border: #b6b5af;
  --search-placeholder-color: inherit;

  --form-control-bg: #fff;
  --form-control-border: #ced4da;
  --form-control-color: #222;

  --copyright-color: #555;

  --card-title-color: #3f3f3f;
  --card-heading-color: inherit;
  --card-border-color: rgba(0, 0, 0, 0.125);

  --card-header-color: inherit;
  --card-body-color: inherit;
  --card-body-bg: inherit;
  --card-footer-color: inherit;

  --article-card-header-bg: #dfdacc;
  --article-card-body-bg: #f1eee2;

  --grid-header-color: inherit;
  --grid-header-bg: #f1eee2;
  --grid-body-color: inherit;
  --grid-body-bg: #cac8bf;
  --grid-footer-color: inherit;
  --grid-footer-bg: #f1eee2;
  --grid-footer-heading-bg: #dfdacc;

  --sidebar-header-color: inherit;
  --sidebar-header-bg: #ffcfaf;
  --sidebar-body-color: inherit;
  --sidebar-body-bg: #f1eee2;
  --sidebar-footer-color: inherit;
  --sidebar-footer-bg: #f1eee2;

  --subtitle-color: #2d3748;

  --card-bg-green: #deeee5;
  --card-bg-blue: #dee6ee;
  --card-bg-blue-dk: #c6d6e6;
  --card-bg-pink: #ffe5f4;
  --card-bg-pink-dk: #f0d8e6;
  --card-bg-purple: #e5deee;
  --card-bg-tint-dk: #dddbd1;

  --description-color: #555;
  --searchheading-color: inherit;
  --hamburger-icon: url("/images/common/hamburger_green_lt.svg");
  --quiet-link-opacity: 0.7;
  --del-color: #666;
}

/* ----------------------------------------------------------
   BASE / GLOBAL
   Applied to <body> which has .d-flex .flex-column .min-vh-100
   ---------------------------------------------------------- */
html {
  scroll-behavior: smooth;
}
body {
  overflow-x: hidden;
  color: var(--body-color);
  font-family: "opensans", sans-serif;
  font-size: 18px;
  line-height: 110%;
  background-color: var(--body-bg);
  background-image: var(--body-bg-image);
  background-repeat: repeat;
}
.container-fluid {
  margin-right: auto;
  margin-left: auto;
  max-width: 1110px;
}
iframe {
  border: none;
}
/* Slightly dims images — used on book covers and magazine
   covers in the sidebar, e.g. <img class="img-fluid dim"> */
img.dim {
  filter: brightness(0.9);
}

/* ----------------------------------------------------------
   BRAND
   .zeropoint  — the "zeropoint" text in <a class="navbar-brand">
   .fw         — featured/highlighted word (e.g. gold accent)
   .menu-selection — bordered highlight on active nav item
   ---------------------------------------------------------- */
.zeropoint {
  font-weight: 200;
  margin-left: 5px;
  background-color: var(--body-bg);
  background-size: cover;
  -webkit-background-clip: text;
  background-clip: text;
  color: var(--zeropoint-color);
}
.fw {
  color: var(--fw-color) !important;
  font-weight: var(--fw-weight);
  font-size: 1.2em;
}
/* Circumpunct logo beside brand text — rendered via CSS
   background-image (data URI SVG). Two versions needed because
   currentColor doesn't work in background-image; colours are
   hardcoded to match --zeropoint-color per theme. */
.zp-logo {
  display: inline-block;
  width: 32px;
  height: 32px;
  vertical-align: middle;
  background-size: contain;
  background-repeat: no-repeat;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cdefs%3E%3Cfilter id='glow' x='-30%25' y='-30%25' width='160%25' height='160%25'%3E%3CfeGaussianBlur in='SourceGraphic' stdDeviation='3' result='blur'/%3E%3CfeMerge%3E%3CfeMergeNode in='blur'/%3E%3CfeMergeNode in='SourceGraphic'/%3E%3C/feMerge%3E%3C/filter%3E%3C/defs%3E%3Cg filter='url(%23glow)'%3E%3Ccircle cx='50' cy='50' r='42' fill='none' stroke='%23575757' stroke-width='2'/%3E%3Ccircle cx='50' cy='50' r='4' fill='%23575757'/%3E%3C/g%3E%3C/svg%3E");
}
[data-theme="light"] .zp-logo {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cdefs%3E%3Cfilter id='glow' x='-30%25' y='-30%25' width='160%25' height='160%25'%3E%3CfeGaussianBlur in='SourceGraphic' stdDeviation='3' result='blur'/%3E%3CfeMerge%3E%3CfeMergeNode in='blur'/%3E%3CfeMergeNode in='SourceGraphic'/%3E%3C/feMerge%3E%3C/filter%3E%3C/defs%3E%3Cg filter='url(%23glow)'%3E%3Ccircle cx='50' cy='50' r='42' fill='none' stroke='%23a1a1a1' stroke-width='2'/%3E%3Ccircle cx='50' cy='50' r='4' fill='%23a1a1a1'/%3E%3C/g%3E%3C/svg%3E");
}
.menu-selection {
  color: var(--menu-selection-color) !important;
  border: 1px solid var(--menu-selection-color);
  padding: 8px;
  margin-right: 20px;
  border-radius: 6px;
}

/* ----------------------------------------------------------
   NAVBAR
   <nav class="navbar navbar-expand-lg navbar-light navbar-shadow">
   Contains brand, hamburger toggler, nav links, search, toggle.
   ---------------------------------------------------------- */
.navbar-brand {
  font-size: 1.5em;
}
/* Brand text turns green on hover */
.navbar-brand:hover .zeropoint {
  color: var(--brand-hover) !important;
}
.navbar {
  font-size: 1.2em;
  background-color: var(--navbar-bg);
  padding: 20px;
}
.navbar-shadow {
  box-shadow: var(--navbar-shadow);
}
/* Custom hamburger icon (swapped per theme via variable) */
.navbar-light .navbar-toggler-icon {
  background-image: var(--hamburger-icon);
}
.navbar-toggler:focus {
  outline: none;
  box-shadow: none;
}
/* Applied to the current page's nav link */
.nav-active {
  color: var(--nav-active-color) !important;
}

/* ----------------------------------------------------------
   MOBILE NAVBAR
   Adjustments for screens < 992px (Bootstrap lg breakpoint).
   Controls hamburger menu layout and search input sizing.
   ---------------------------------------------------------- */
@media (max-width: 991.98px) {
  .mobile-toggle-container {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    flex-wrap: nowrap;
    width: 100%;
  }
  .mobile-toggle-container button {
    flex-shrink: 0;
  }
  .navbar-collapse .d-lg-none form {
    margin-bottom: 0;
  }
  .navbar-collapse .d-lg-none .form-control {
    height: calc(1.5em + .75rem + 2px);
  }
}

/* ----------------------------------------------------------
   LINKS
   Global link colours, plus special link classes:
   .zen   — inherits parent colour, no underline (invisible link)
   .quiet — inherits colour, opacity controlled per theme
   .noline — suppresses underline
   nav a  — navigation-specific colours with !important
   ---------------------------------------------------------- */
a:link,
a:visited {
  color: var(--link-color);
}
a:hover,
a:active {
  color: var(--link-hover);
}
a.zen:link,
a.zen:visited,
a.zen:hover,
a.zen:active {
  color: inherit;
  text-decoration: none;
}
a.quiet:link,
a.quiet:visited,
a.quiet:hover,
a.quiet:active {
  color: inherit;
  opacity: var(--quiet-link-opacity);
}
a.noline {
  text-decoration: none;
}
nav a:link,
nav a:visited {
  color: var(--nav-link-color);
  text-decoration: none;
}
nav a:hover,
nav a:active {
  color: var(--nav-hover) !important;
  text-decoration: none;
}

/* ----------------------------------------------------------
   DROPDOWNS
   Bootstrap dropdown menus under "media" and "articles" nav
   items. Overrides Bootstrap defaults for theme colours.
   ---------------------------------------------------------- */
.dropdown-menu {
  background-color: var(--dropdown-bg);
}
.dropdown-menu .dropdown-item {
  color: var(--dropdown-item-color) !important;
}
.dropdown-menu .dropdown-item:hover,
.dropdown-menu .dropdown-item:focus {
  background-color: var(--dropdown-hover-bg) !important;
  color: var(--dropdown-hover-color) !important;
}
.nav-item.dropdown > .nav-link.dropdown-toggle {
  color: var(--dropdown-toggle-color);
}

/* ----------------------------------------------------------
   SEARCH & FORM CONTROLS
   .form-control         — generic form inputs (contact, etc.)
   .form-control.search  — the search input in the navbar
   .hp-field             — honeypot field hidden off-screen
   ---------------------------------------------------------- */
.form-control {
  background-color: var(--form-control-bg);
  border-color: var(--form-control-border);
  color: var(--form-control-color);
}
.form-control.search {
  background-color: var(--search-bg);
  border: 1px solid var(--search-border);
  color: var(--form-control-color);
  min-width: 120px;
}
.form-control.search:focus {
  background-color: var(--search-focus-bg);
  outline: none;
  border: 2px solid var(--search-focus-border);
  box-shadow: 0 0 5px rgba(102, 102, 102, 0.5);
}
.form-control.search:hover {
  background-color: var(--search-bg);
}
.search::placeholder {
  color: var(--search-placeholder-color);
}
.hp-field {
  position: absolute;
  left: -9999px;
}

/* ----------------------------------------------------------
   THEME TOGGLE
   Dark/light slider button rendered as a pill with a sliding
   circle pseudo-element. Two instances in the navbar:
   #theme-toggle-desktop (visible lg+) and
   #theme-toggle-mobile (visible <lg).
   ---------------------------------------------------------- */
.theme-toggle {
  width: 28px;
  height: 18px;
  position: relative;
  background: #555;
  border-radius: 9px;
  transition: background 0.3s;
}
.theme-toggle::after {
  content: '';
  position: absolute;
  width: 14px;
  height: 14px;
  left: 2px;
  top: 2px;
  background: #aaa;
  border-radius: 50%;
  transition: transform 0.3s;
  transform: translateX(0);
}
.theme-toggle:hover {
  background: #666;
}
/* Light-mode state: pill shifts right */
.theme-toggle.light {
  background: #ccc;
}
.theme-toggle.light::after {
  transform: translateX(10px);
}
.theme-toggle.light:hover {
  background: #ccc;
}
.theme-toggle:focus {
  outline: none;
  box-shadow: none;
}

/* ----------------------------------------------------------
   FOOTER
   <footer class="mt-auto"> containing .bg-footer wrapper
   with .copyright paragraph. Sticks to bottom via flex layout.
   ---------------------------------------------------------- */
.bg-footer {
  bottom: 0;
  background-color: var(--footer-bg);
  color: var(--footer-color) !important;
  font-size: 0.9rem;
  box-shadow: var(--footer-shadow);
}
.copyright {
  color: var(--copyright-color);
  margin: 0;
  font-size: 1.2rem;
}

/* ----------------------------------------------------------
   TYPOGRAPHY
   h5        — used in card headings
   .subtitle — small text under headings
   .tinytext — very small text
   .text-small — 0.7em utility
   .author   — centred byline under article titles
   ---------------------------------------------------------- */
h5 {
  font-size: 1.2rem;
  line-height: 100%;
}
.subtitle {
  font-size: 60% !important;
  color: var(--subtitle-color);
}
p.tinytext {
  font-size: 50%;
}
.text-small {
  font-size: 0.7em;
}
.author {
  text-align: center;
  margin-top: 0;
  margin-bottom: 0.3em;
  font-size: 0.8em;
}

/* ----------------------------------------------------------
   CARDS — GENERIC
   Base Bootstrap .card overrides. Used throughout for video
   cards (article.grid-layout), sidebar info cards, and
   article-page content cards.
   ---------------------------------------------------------- */
.card {
  border-color: var(--card-border-color);
  border-width: 1px;
}
/* Card titles: h1–h4.card-title (pink in dark, muted in light) */
h1.card-title,
h2.card-title,
h3.card-title,
h4.card-title {
  margin-bottom: 0;
  color: var(--card-title-color);
}
h5.card-title {
  font-weight: bold;
}
/* Headings inside cards */
.card h4,
.card h5 {
  margin: 0;
  color: var(--card-heading-color);
}
.card-header {
  border-bottom: 0;
  color: var(--card-header-color);
}
.card-body {
  color: var(--card-body-color);
  background-color: var(--card-body-bg);
}
.card-footer {
  border-top: 0;
  color: var(--card-footer-color);
}
/* Strikethrough text in card bodies (e.g. "Websites to Avoid") */
.card-body del {
  color: var(--del-color);
}

/* Card background tints — applied as extra classes on
   card-header / card-body / card-footer to colour-code
   content sections, e.g. <div class="card-header card-bg-pink"> */
.card-bg-green { background-color: var(--card-bg-green) !important; }
.card-bg-blue { background-color: var(--card-bg-blue) !important; }
.card-bg-blue-dk { background-color: var(--card-bg-blue-dk) !important; }
.card-bg-pink { background-color: var(--card-bg-pink) !important; }
.card-bg-pink-dk { background-color: var(--card-bg-pink-dk) !important; }
.card-bg-purple { background-color: var(--card-bg-purple) !important; }
.card-bg-tint-dk { background-color: var(--card-bg-tint-dk) !important; }

/* ----------------------------------------------------------
   ARTICLE CARDS
   Used on article pages. <article> wraps the card.
   - article p / ol / ul — normalises line-height and padding
   - article .card-header/body — article-specific backgrounds
   ---------------------------------------------------------- */
article p {
  line-height: normal;
}
article ol,
article ul {
  line-height: normal;
  padding-bottom: 1rem;
  padding-left: 20px;
  margin: 0;
}
article ol > li::marker {
  font-weight: bold;
}
article .card-header {
  background-color: var(--article-card-header-bg);
}
article .card-body {
  background-color: var(--article-card-body-bg);
}

/* Article GRID cards — the two-column video grid on the
   index page. Each card is <article class="card grid-layout">
   with card-body (iframe), optional card-header, and
   card-footer (title + description text). */
article.grid-layout .card-header {
  color: var(--grid-header-color);
  margin: 0;
  padding: 6px 7px 2px 7px;
  background-color: var(--grid-header-bg);
}
article.grid-layout .card-body {
  color: var(--grid-body-color);
  margin: 0;
  padding: 0;
  font-size: 0.8em;
  background-color: var(--grid-body-bg);
}
article.grid-layout .card-footer {
  color: var(--grid-footer-color);
  margin: 0;
  padding: 4px 7px;
  font-size: 0.8em;
  background-color: var(--grid-footer-bg);
}
article.grid-layout .card-footer .heading {
  background-color: var(--grid-footer-heading-bg);
}

/* Article SINGLE cards — full-width article layout */
article.single-layout .card-header {
  padding: 6px 7px 6px 7px;
}

/* ----------------------------------------------------------
   SIDEBAR CARDS
   Right column: <aside class="sidebar"> inside col-md-3.
   Contains info cards (links, resources, books, etc.) with
   tighter padding and smaller font than main content cards.
   ---------------------------------------------------------- */
.sidebar .card-body,
.sidebar .card-footer {
  margin: 0;
  padding: 4px 8px 6px 12px;
  font-size: 0.8em;
}
.sidebar .card-header {
  color: var(--sidebar-header-color);
  background-color: var(--sidebar-header-bg);
  margin: 0;
  padding: 4px 8px 4px 12px;
}
.sidebar .card-body {
  color: var(--sidebar-body-color);
  background-color: var(--sidebar-body-bg);
}
.sidebar .card-footer {
  color: var(--sidebar-footer-color);
  background-color: var(--sidebar-footer-bg);
}
/* Tighter list spacing inside sidebar cards */
.sidebar ul,
.sidebar ol {
  padding-left: 1em;
  margin: -12px 0 -10px 0;
}


/* ----------------------------------------------------------
   UTILITY CLASSES
   Spacing and layout helpers used throughout the HTML.
   ---------------------------------------------------------- */
.zbot {                     /* zero bottom margin (used on <ul> in sidebar) */
  margin-bottom: 0;
  padding-bottom: 0;
}
.zpbot {                    /* 5px bottom margin */
  margin-bottom: 5px;
}
.zpadbot {                  /* zero bottom padding */
  padding-bottom: 0 !important;
}
.zpadtop {                  /* zero top padding */
  padding-top: 0 !important;
}
.textrz {                   /* right-aligned float, zero bottom */
  float: right;
  margin-bottom: 0;
}
.f-right {                  /* float right with clear */
  float: right;
  clear: both;
}
.highlight {                /* text highlight background */
  background: #ffff40;
}

/* ----------------------------------------------------------
   GO-TO-TOP LINKS
   "^top" links at the bottom of content columns.
   Different sizes for main, article, and aside contexts.
   ---------------------------------------------------------- */
main .gotop {
  font-size: 0.7em;
  text-align: right;
  margin-top: -1rem;
  margin-bottom: 1.5rem;
}
article .gotop {
  font-size: 0.8em;
  text-align: right;
  margin-bottom: 0;
}
aside .gotop {
  font-size: 0.7em;
  text-align: right;
  margin-top: -1rem;
  margin-bottom: 1.5rem;
}

/* ----------------------------------------------------------
   ZOOM SEARCH ENGINE RESULTS
   Styles for output generated by Zoom Search Engine
   (search.php). These classes are in the search results HTML
   and are not used elsewhere on the site.
   ---------------------------------------------------------- */
.searchheading {
  font-size: 130%;
  font-weight: bold;
  color: var(--searchheading-color);
}
.summary {
  font-size: 80%;
  font-style: italic;
}
.category {
  color: #999999;
}
.sorting {
  text-align: right;
}
.description {
  color: var(--description-color);
}
.infoline {
  font-size: 80%;
  font-style: normal;
  color: #808080;
}
.zoom_results_per_page {
  font-size: 80%;
  margin-left: 10px;
}
.zoom_match {
  font-size: 80%;
  margin-left: 10px;
}
.zoom_categories {
  font-size: 80%;
}
.zoom_categories ul {
  display: inline;
  margin: 0px;
  padding: 0px;
}
.zoom_categories li {
  display: inline;
  margin-left: 15px;
  list-style-type: none;
}
.cat_summary ul {
  margin: 0px;
  padding: 0px;
  display: inline;
}
.cat_summary li {
  display: inline;
  margin-left: 15px;
  list-style-type: none;
}
.result_image {
  float: left;
  display: block;
}
.result_image img {
  margin: 10px;
  width: 80px;
  border: 0px;
}
.result_block,
.result_altblock {
  margin-top: 15px;
  margin-bottom: 15px;
  clear: left;
}
.searchtime {
  font-size: 80%;
}
.recommended {
  background: #dfffbf;
  border-top: 1px dotted #808080;
  border-bottom: 1px dotted #808080;
  margin-top: 15px;
  margin-bottom: 15px;
}
.recommended_heading {
  float: right;
  font-weight: bold;
}
.recommend_block {
  margin-top: 15px;
  margin-bottom: 15px;
  clear: left;
}
.recommend_description {
  color: var(--description-color);
}
.recommend_infoline {
  font-size: 80%;
  font-style: normal;
  color: #808080;
}
.recommend_image {
  float: left;
  display: block;
}
.recommend_image img {
  margin: 10px;
  width: 80px;
  border: 0px;
}
