@charset "UTF-8";

:root {
  --black: #000;
  --dark: #111;
  --gray: #555;
  --silver: #888;
  --light: #ccc;
  --lighter: #eee;
  --pale: #f7f7f7;
  --white: #fff;
  --green: #0f6b4e;
  --blue: #1756a3;
  --gold: #b8860b;
  --red: #b91c3c;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: "ET Book", Georgia, serif;
  font-size: 1rem;
  line-height: 1.6;
  color: var(--dark);
  padding: 1.25rem 1.5rem;
}

/* ============ SITE HEADER ============ */
header[role="banner"] {
  margin-bottom: 1.25rem;

  & .logo {
    font-family: "ET Book", Georgia, serif;
    font-weight: 600;
    font-size: 1.7rem;
    letter-spacing: -0.01em;
    color: var(--dark);
    text-decoration: none;

    &:hover { color: var(--green); }
  }

  & nav {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    margin-top: 0.6rem;

    & a {
      font-family: "Ioskeley", monospace;
      font-size: 0.7rem;
      font-weight: 500;
      text-decoration: none;
      text-transform: uppercase;
      letter-spacing: 0.03em;
      color: var(--dark);
      padding: 0.3rem 0.65rem;
      border: 1px solid var(--dark);
      box-shadow: 2px 2px 0 0 var(--dark);
      transition: all 0.1s ease;

      &:hover {
        background: var(--dark);
        color: var(--white);
        box-shadow: 1px 1px 0 0 var(--dark);
      }
    }
  }
}

/* ============ BREADCRUMB ============ */
nav[aria-label="Breadcrumbs"] {
  font-family: "Ioskeley", monospace;
  font-size: 0.7rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  margin: 1.25rem 0 0.4rem;

  & a {
    color: var(--blue);
    text-decoration: none;
    &:hover { text-decoration: underline; }
  }
}

/* ============ HORIZONTAL RULES ============ */
hr {
  border: none;
  border-top: 1px dotted var(--light);
  margin: 0.4rem 0 1.25rem;

  &.thick { border-top: 1px dashed var(--light); }

  &.section {
    border: none;
    text-align: center;
    margin: 2rem 0;
    &::before {
      content: "· · ·";
      font-family: "Ioskeley", monospace;
      color: var(--silver);
      letter-spacing: 0.5em;
    }
  }
}

/* ============ TYPOGRAPHY ============ */
h1, h2, h3 {
  font-family: "Ioskeley", monospace;
  text-transform: uppercase;
}

h1 {
  font-weight: 600;
  font-size: 1.25rem;
  letter-spacing: 0.02em;
  line-height: 1.3;
  margin-bottom: 0.5rem;
}

h2 {
  font-weight: 700;
  font-size: 0.9rem;
  letter-spacing: 0.04em;
  color: var(--dark);
  margin-top: 2rem;
  margin-bottom: 0.25rem;
}

h3 {
  font-weight: 600;
  font-size: 0.8rem;
  letter-spacing: 0.02em;
  color: var(--gray);
  margin-top: 1.5rem;
  margin-bottom: 0.35rem;
}

p { margin: 0.75rem 0; text-wrap: pretty; }
a { color: var(--blue); &:hover { color: var(--dark); } }
strong { font-weight: 600; }
em { font-style: italic; }

/* ============ TAGS ============ */
.tag {
  font-family: "Ioskeley", monospace;
  font-size: 0.6rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 0.2rem 0.4rem;
  border: 1px dotted var(--dark);
  display: inline-flex;
  align-items: center;
  vertical-align: middle;

  &.solid { border-style: solid; }
  &.fill-green { background: var(--green); color: var(--white); border-color: transparent; }
  &.fill-blue { background: var(--blue); color: var(--white); border-color: transparent; }
  &.fill-gold { background: var(--gold); color: var(--white); border-color: transparent; }
  &.fill-red { background: var(--red); color: var(--white); border-color: transparent; }
  &.fill-pale { background: var(--pale); color: var(--gray); border-color: var(--light); font-weight: 600; }
  &.lg { font-size: 0.7rem; padding: 0.25rem 0.5rem; }
}

/* ============ UTILITIES ============ */
.mono { font-family: "Ioskeley", monospace; font-weight: 500; }
.condensed { font-stretch: 85%; }
.text-gray { color: var(--gray); }
.text-silver { color: var(--silver); }
.flex-gap { display: flex; gap: 0.5rem; flex-wrap: wrap; }

/* ============ CODE (INLINE) ============ */
code {
  font-family: "Ioskeley", monospace;
  font-size: 0.85em;
  font-weight: 500;
  background: var(--pale);
  padding: 0.1em 0.3em;
  border-radius: 2px;
}

/* ============ LISTS ============ */
ul, ol {
  padding-left: 1.5rem;
  margin: 0.75rem 0;
}

li {
  margin: 0.4rem 0;
  &::marker { color: var(--gray); }
}

/* ============ BLOCKQUOTE ============ */
blockquote {
  border-left: 2px solid var(--dark);
  padding-left: 0.9rem;
  margin: 1rem 0;
  font-style: italic;
  color: var(--gray);

  & em { font-style: normal; }
}

/* ============ BUTTONS ============ */
.btn {
  font-family: "Ioskeley", monospace;
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  text-decoration: none;
  padding: 0.35rem 0.7rem;
  border: 1px solid;
  box-shadow: 2px 2px 0 0 var(--dark);
  display: inline-block;
  transition: all 0.1s ease;

  &:hover {
    box-shadow: 1px 1px 0 0 var(--dark);
  }

  &.btn-green {
    background: var(--green);
    color: var(--white);
    border-color: var(--dark);

    &:hover {
      background: var(--dark);
      color: var(--white);
    }
  }

  &.btn-outline {
    background: var(--white);
    color: var(--dark);
    border-color: var(--dark);

    &:hover {
      background: var(--dark);
      color: var(--white);
    }
  }
}

/* ============ TABLES ============ */
table {
  font-family: "Ioskeley", monospace;
  font-size: 0.75rem;
  font-weight: 500;
  width: 100%;
  border-collapse: collapse;
  margin: 0.6rem 0;
}

th, td {
  text-align: left;
  padding: 0.35rem 0.75rem 0.35rem 0;
  border-bottom: 1px dotted var(--light);
}

th {
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  font-size: 0.65rem;
  color: var(--gray);
  border-bottom: 1px solid var(--dark);
}

tbody tr:last-child td {
  border-bottom: none;
}

/* ============ CARDS ============ */
.card {
  border: 1px solid var(--dark);
  padding: 0.9rem 1rem;
  box-shadow: 2px 2px 0 0 var(--dark);
  display: flex;
  flex-direction: column;

  & h3 {
    margin-top: 0;
    color: var(--dark);
    font-weight: 600;
  }

  & p {
    margin: 0.4rem 0;
    font-size: 0.875rem;
  }

  & > :last-child {
    margin-top: auto;
    padding-top: 0.4rem;
    align-self: flex-start;
  }
}

/* ============ SITE FOOTER ============ */
footer[role="contentinfo"] {
  margin-top: 1.5rem;
  padding-top: 0.6rem;
  border-top: 1px solid var(--dark);
  font-family: "Ioskeley", monospace;
  font-size: 0.65rem;
  font-weight: 500;
  color: var(--silver);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  text-transform: uppercase;
  letter-spacing: 0.02em;

  & a {
    color: var(--silver);
    &:hover { color: var(--dark); }
  }

  & .btn-small {
    text-decoration: none;
    padding: 0.25rem 0.5rem;
    border: 1px solid var(--dark);
    box-shadow: 2px 2px 0 0 var(--dark);
    color: var(--dark);
    transition: all 0.1s ease;

    &:hover {
      background: var(--dark);
      color: var(--white);
      box-shadow: 1px 1px 0 0 var(--dark);
    }
  }
}

