/* =====================================================================
   The Liquidity Coverage Ratio Homepage  --  stylesheet
   Aesthetic target: ~1999 GeoCities / Angelfire personal homepage.
   ===================================================================== */

body {
  background-color: #008080;          /* classic teal "desktop" */
  background-image:
      repeating-linear-gradient(
          45deg,
          rgba(255,255,255,0.04) 0,
          rgba(255,255,255,0.04) 2px,
          transparent 2px,
          transparent 6px);
  color: #000000;
  font-family: "Times New Roman", Times, serif;
  font-size: 14px;
  margin: 0;
  padding: 16px 0;
}

/* ---------- outer page frame ---------- */
table.frame {
  width: 880px;
  background-color: #c0c0c0;          /* Win9x silver */
  border-top: 2px solid #ffffff;
  border-left: 2px solid #ffffff;
  border-right: 2px solid #404040;
  border-bottom: 2px solid #404040;
  padding: 4px;
}

/* ---------- header ---------- */
table.header {
  background-color: #000080;          /* navy title-bar */
  background-image: linear-gradient(to right, #000080 0%, #1084d0 100%);
  border-top: 2px solid #ffffff;
  border-left: 2px solid #ffffff;
  border-right: 2px solid #000040;
  border-bottom: 2px solid #000040;
}
.header-cell { color: #ffffff; }
.header h1 {
  color: #ffff00;
  font-family: "Comic Sans MS", "Times New Roman", serif;
  font-size: 28px;
  margin: 0 0 4px 0;
  text-align: center;
  text-shadow: 2px 2px 0 #800000;
}
.header .tagline {
  color: #ffffff;
  text-align: center;
  font-style: italic;
  margin: 0;
}

/* ---------- nav bar ---------- */
table.navbar {
  background-color: #d4d0c8;
  border-top: 2px solid #ffffff;
  border-left: 2px solid #ffffff;
  border-right: 2px solid #808080;
  border-bottom: 2px solid #808080;
  margin-top: 4px;
}
table.navbar td {
  text-align: center;
  border-right: 1px dotted #808080;
}
table.navbar td:last-child { border-right: none; }
table.navbar a {
  color: #000080;
  text-decoration: none;
  font-weight: bold;
  font-size: 12px;
  font-family: Verdana, Arial, sans-serif;
}
table.navbar a:hover {
  color: #ff0000;
  background-color: #ffff80;
  text-decoration: underline;
}

/* ---------- sidebar ---------- */
.sidebar {
  background-color: #c0c0c0;
  padding: 8px;
  border-right: 2px solid #808080;
}
.box {
  background-color: #ffffe0;          /* parchment yellow */
  border-top: 2px solid #ffffff;
  border-left: 2px solid #ffffff;
  border-right: 2px solid #808080;
  border-bottom: 2px solid #808080;
  margin-bottom: 12px;
  padding: 6px 8px;
}
.box-title {
  background-color: #000080;
  color: #ffffff;
  font-family: Verdana, Arial, sans-serif;
  font-size: 11px;
  font-weight: bold;
  margin: -6px -8px 6px -8px;
  padding: 3px 6px;
  letter-spacing: 1px;
}
.menu {
  list-style: square;
  padding-left: 18px;
  margin: 4px 0;
}
.menu li { margin-bottom: 2px; }
.menu a {
  color: #0000ee;
  text-decoration: underline;
  font-size: 12px;
}
.menu a:visited { color: #551a8b; }
.menu a:hover   { color: #ff0000; background-color: #ffff80; }

.counter { text-align: center; }
.counter-num {
  display: inline-block;
  background-color: #000000;
  color: #00ff00;
  font-family: "Courier New", Courier, monospace;
  font-weight: bold;
  font-size: 18px;
  letter-spacing: 2px;
  padding: 4px 8px;
  border: 2px inset #808080;
  margin: 4px 0;
}

/* ---------- main content ---------- */
.content {
  background-color: #fffff0;          /* ivory */
  padding: 18px 22px;
  border-left: 2px solid #ffffff;
}
.content h2 {
  color: #800000;
  font-family: "Times New Roman", Times, serif;
  font-size: 20px;
  border-bottom: 2px ridge #808080;
  padding-bottom: 2px;
  margin-top: 18px;
}
.content p {
  line-height: 1.45;
  margin: 8px 0;
  text-align: justify;
}
.content a          { color: #0000ee; text-decoration: underline; }
.content a:visited  { color: #800080; }
.content a:hover    { color: #ff0000; background-color: #ffff80; }

/* ---------- "new" / blink imitation ---------- */
.blink {
  color: #ff0000;
  font-weight: bold;
  background-color: #ffff00;
  padding: 0 4px;
  border: 1px solid #800000;
}

/* ---------- notice strip ---------- */
.notice {
  background-color: #ffffcc;
  border: 2px ridge #c0a000;
  padding: 6px 10px;
  font-size: 12px;
  margin-bottom: 12px;
  font-family: Verdana, Arial, sans-serif;
}

/* ---------- callout box ---------- */
table.callout {
  background-color: #e0f0ff;
  border-top: 2px solid #ffffff;
  border-left: 2px solid #ffffff;
  border-right: 2px solid #608090;
  border-bottom: 2px solid #608090;
  margin: 10px auto;
  font-style: italic;
}

/* ---------- formula box ---------- */
table.formula {
  background-color: #f8f8ff;
  border: 3px double #000080;
  margin: 12px auto;
  font-family: "Times New Roman", Times, serif;
  font-size: 16px;
}
.formula .big { font-size: 22px; font-weight: bold; }
table.fraction { display: inline-table; vertical-align: middle; }
.fraction .numerator   { border-bottom: 2px solid #000000; padding: 4px 12px; }
.fraction .denominator { padding: 4px 12px; }

/* ---------- data tables ---------- */
table.data {
  border-collapse: collapse;
  margin: 8px 0 12px 0;
  background-color: #ffffff;
  font-size: 13px;
}
table.data th, table.data td {
  border: 1px solid #808080;
  padding: 4px 8px;
  vertical-align: top;
}
table.data .data-head th,
table.data tr.data-head th {
  background-color: #000080;
  color: #ffffff;
  font-family: Verdana, Arial, sans-serif;
  font-size: 12px;
  letter-spacing: 1px;
}
table.data tr.alt td { background-color: #f0f0e8; }

/* ---------- divider ---------- */
hr.divider {
  border: 0;
  height: 0;
  border-top: 2px ridge #808080;
  margin: 18px 0;
}

/* ---------- small / utility ---------- */
.small      { font-size: 11px; }
.center     { text-align: center; }
.disclaimer {
  background-color: #fff0f0;
  border: 1px dashed #800000;
  padding: 6px 10px;
  margin-top: 18px;
}

/* ---------- billing / order summary ---------- */
table.order {
  border-collapse: collapse;
  margin: 12px auto;
  background-color: #ffffff;
  font-size: 14px;
  width: 90%;
}
table.order th, table.order td {
  border: 1px solid #808080;
  padding: 6px 10px;
}
table.order tr.order-head th {
  background-color: #000080;
  color: #ffffff;
  font-family: Verdana, Arial, sans-serif;
  font-size: 12px;
  letter-spacing: 1px;
}
table.order tr.total td {
  background-color: #ffffcc;
  font-weight: bold;
  font-size: 16px;
}
.price { font-family: "Courier New", Courier, monospace; }

/* ---------- "purchase" button ---------- */
.buy-button {
  display: inline-block;
  background-color: #d4d0c8;
  color: #000080 !important;
  font-family: Verdana, Arial, sans-serif;
  font-size: 16px;
  font-weight: bold;
  text-decoration: none !important;
  padding: 8px 28px;
  margin: 10px 0;
  border-top: 2px solid #ffffff;
  border-left: 2px solid #ffffff;
  border-right: 2px solid #404040;
  border-bottom: 2px solid #404040;
  letter-spacing: 1px;
  cursor: pointer;
}
.buy-button:active {
  border-top: 2px solid #404040;
  border-left: 2px solid #404040;
  border-right: 2px solid #ffffff;
  border-bottom: 2px solid #ffffff;
}
.buy-button:hover {
  color: #ff0000 !important;
  background-color: #e8e4dc;
}

/* ---------- error dialog (revealed via :target, no JavaScript) ---------- */
.error-box {
  display: none;
  background-color: #ffffff;
  border-top: 2px solid #ffffff;
  border-left: 2px solid #ffffff;
  border-right: 2px solid #404040;
  border-bottom: 2px solid #404040;
  margin: 16px auto;
  width: 80%;
}
.error-box:target { display: block; }
.error-titlebar {
  background-color: #800000;
  background-image: linear-gradient(to right, #800000 0%, #d04040 100%);
  color: #ffffff;
  font-family: Verdana, Arial, sans-serif;
  font-size: 12px;
  font-weight: bold;
  padding: 3px 8px;
  letter-spacing: 1px;
}
.error-body {
  padding: 14px 18px;
  font-family: Verdana, Arial, sans-serif;
  font-size: 13px;
}
.error-icon {
  display: inline-block;
  background-color: #ffff00;
  color: #ff0000;
  border: 2px solid #800000;
  font-weight: bold;
  font-size: 20px;
  padding: 0 10px;
  margin-right: 10px;
  vertical-align: middle;
}
.error-code {
  font-family: "Courier New", Courier, monospace;
  font-size: 11px;
  color: #404040;
}
.error-dismiss {
  display: inline-block;
  background-color: #d4d0c8;
  color: #000080 !important;
  font-family: Verdana, Arial, sans-serif;
  font-size: 12px;
  font-weight: bold;
  text-decoration: none !important;
  padding: 4px 18px;
  margin-top: 8px;
  border-top: 2px solid #ffffff;
  border-left: 2px solid #ffffff;
  border-right: 2px solid #404040;
  border-bottom: 2px solid #404040;
}

/* ---------- footer ---------- */
table.footer {
  background-color: #d4d0c8;
  border-top: 2px solid #ffffff;
  border-left: 2px solid #ffffff;
  border-right: 2px solid #808080;
  border-bottom: 2px solid #808080;
  margin-top: 6px;
  font-family: Verdana, Arial, sans-serif;
  font-size: 11px;
}
table.footer a {
  color: #000080;
  text-decoration: none;
  font-weight: bold;
}
table.footer a:hover {
  color: #ff0000;
  text-decoration: underline;
}
table.footer p { margin: 4px 0; }

/* ---------- "compliance" badges ---------- */
.badges { margin-top: 8px; }
.badge {
  display: inline-block;
  background-color: #000000;
  color: #00ff00;
  font-family: "Courier New", Courier, monospace;
  font-size: 10px;
  font-weight: bold;
  padding: 2px 6px;
  margin: 0 3px;
  border-top: 1px solid #00ff00;
  border-left: 1px solid #00ff00;
  border-right: 1px solid #006000;
  border-bottom: 1px solid #006000;
  letter-spacing: 1px;
}
