/* ==========================================================================
   3Lions.ca — Global Styles
   CSS Reset + Base Typography + Foundational Styles
   Imports tokens.css. Every page loads this file.
   ========================================================================== */

/* ----------------------------------------------------------------
   GOOGLE FONTS — Roboto (300, 400, 500, 700, 900)
   ---------------------------------------------------------------- */
@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,300;0,400;0,500;0,700;0,900;1,300;1,400;1,500;1,700&display=swap');

/* ----------------------------------------------------------------
   CSS RESET — Modern Minimal
   ---------------------------------------------------------------- */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  text-size-adjust: 100%;
  hanging-punctuation: first last;
}

body {
  font-family: var(--font-primary);
  font-weight: var(--fw-light);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--color-text);
  background-color: var(--color-surface);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  min-height: 100dvh;
}

/* Remove default list styles */
ul,
ol {
  list-style: none;
}

/* Prevent img and media from overflowing */
img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
  height: auto;
}

/* Remove built-in form typography styles */
input,
button,
textarea,
select {
  font: inherit;
  color: inherit;
}

/* Remove default button styles */
button {
  cursor: pointer;
  background: none;
  border: none;
}

/* Avoid text overflows */
p,
h1,
h2,
h3,
h4,
h5,
h6 {
  overflow-wrap: break-word;
}

/* Remove default fieldset/legend styles */
fieldset {
  border: none;
}

/* Remove animations for people who've turned them off */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* ----------------------------------------------------------------
   SELECTION STYLING
   ---------------------------------------------------------------- */
::selection {
  background-color: var(--color-navy);
  color: var(--color-white);
}

::-moz-selection {
  background-color: var(--color-navy);
  color: var(--color-white);
}

/* ----------------------------------------------------------------
   FOCUS STYLES — Accessibility
   ---------------------------------------------------------------- */
:focus-visible {
  outline: 2px solid var(--color-navy);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}

:focus:not(:focus-visible) {
  outline: none;
}

/* ----------------------------------------------------------------
   SCROLLBAR STYLING
   ---------------------------------------------------------------- */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: var(--color-off-white);
}

::-webkit-scrollbar-thumb {
  background: var(--color-navy);
  border-radius: var(--radius-full);
  border: 2px solid var(--color-off-white);
}

::-webkit-scrollbar-thumb:hover {
  background: var(--color-navy-light);
}

/* Firefox */
html {
  scrollbar-width: thin;
  scrollbar-color: var(--color-navy) var(--color-off-white);
}

/* ----------------------------------------------------------------
   BASE TYPOGRAPHY
   ---------------------------------------------------------------- */
h1,
.h1 {
  font-size: var(--fs-h1);
  font-weight: var(--fw-black);
  line-height: var(--lh-tight);
  letter-spacing: var(--ls-tight);
  color: var(--color-navy);
}

h2,
.h2 {
  font-size: var(--fs-h2);
  font-weight: var(--fw-black);
  line-height: var(--lh-heading);
  letter-spacing: var(--ls-tight);
  color: var(--color-navy);
}

h3,
.h3 {
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  line-height: var(--lh-heading);
  color: var(--color-navy);
}

h4,
.h4 {
  font-size: var(--fs-h4);
  font-weight: var(--fw-medium);
  line-height: var(--lh-heading);
  color: var(--color-navy);
}

h5,
.h5 {
  font-size: var(--fs-body);
  font-weight: var(--fw-medium);
  line-height: var(--lh-heading);
  color: var(--color-navy);
}

h6,
.h6 {
  font-size: var(--fs-small);
  font-weight: var(--fw-medium);
  line-height: var(--lh-heading);
  color: var(--color-text-light);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
}

p {
  margin-bottom: var(--space-md);
  max-width: 70ch;
}

p:last-child {
  margin-bottom: 0;
}

/* Body large variant */
.text-lg {
  font-size: var(--fs-body-lg);
  line-height: var(--lh-relaxed);
}

small,
.text-sm {
  font-size: var(--fs-small);
  line-height: var(--lh-body);
}

.caption {
  font-size: var(--fs-caption);
  font-weight: var(--fw-regular);
  line-height: var(--lh-body);
  color: var(--color-text-light);
}

/* Heading spacing — add margin-top when following content */
:is(h1, h2, h3, h4, h5, h6) + :is(h1, h2, h3, h4, h5, h6) {
  margin-top: var(--space-sm);
}

:is(p, ul, ol, blockquote, figure, table) + :is(h2, h3, h4, h5, h6) {
  margin-top: var(--space-2xl);
}

h1 + :is(p, ul, ol) {
  margin-top: var(--space-lg);
}

:is(h2, h3) + :is(p, ul, ol) {
  margin-top: var(--space-md);
}

:is(h4, h5, h6) + :is(p, ul, ol) {
  margin-top: var(--space-sm);
}

/* ----------------------------------------------------------------
   LINKS
   ---------------------------------------------------------------- */
a {
  color: var(--color-navy);
  text-decoration: none;
  transition: var(--transition-color);
}

a:hover {
  color: var(--color-navy-light);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}

a:active {
  color: var(--color-navy-dark);
}

/* Links inside dark backgrounds */
.bg-navy a:not(.btn) {
  color: var(--color-white);
}

.bg-navy a:not(.btn):hover {
  color: var(--color-gray-200);
}

/* ----------------------------------------------------------------
   STRONG, EM, MARK
   ---------------------------------------------------------------- */
strong,
b {
  font-weight: var(--fw-bold);
}

em,
i {
  font-style: italic;
}

mark {
  background-color: rgba(207, 8, 31, 0.1);
  color: var(--color-text);
  padding: var(--space-2xs) var(--space-xs);
  border-radius: var(--radius-sm);
}

/* ----------------------------------------------------------------
   LISTS (when styled)
   ---------------------------------------------------------------- */
.list-styled {
  padding-left: var(--space-lg);
}

.list-styled li {
  margin-bottom: var(--space-sm);
  position: relative;
}

ul.list-styled li::before {
  content: '';
  position: absolute;
  left: calc(-1 * var(--space-md));
  top: 0.6em;
  width: 6px;
  height: 6px;
  background-color: var(--color-red);
  border-radius: var(--radius-full);
}

ol.list-styled {
  list-style: decimal;
}

/* ----------------------------------------------------------------
   BLOCKQUOTE
   ---------------------------------------------------------------- */
blockquote {
  border-left: 3px solid var(--color-red);
  padding-left: var(--space-lg);
  margin-block: var(--space-lg);
  font-size: var(--fs-body-lg);
  font-style: italic;
  color: var(--color-text-light);
}

blockquote cite {
  display: block;
  margin-top: var(--space-sm);
  font-size: var(--fs-small);
  font-style: normal;
  font-weight: var(--fw-medium);
  color: var(--color-navy);
}

/* ----------------------------------------------------------------
   CODE
   ---------------------------------------------------------------- */
code {
  font-family: 'Roboto Mono', 'Courier New', monospace;
  font-size: 0.875em;
  background-color: var(--color-gray-100);
  padding: var(--space-2xs) var(--space-xs);
  border-radius: var(--radius-sm);
}

pre {
  background-color: var(--color-navy-dark);
  color: var(--color-white);
  padding: var(--space-lg);
  border-radius: var(--radius-md);
  overflow-x: auto;
  margin-block: var(--space-lg);
}

pre code {
  background: none;
  padding: 0;
  color: inherit;
}

/* ----------------------------------------------------------------
   HORIZONTAL RULE
   ---------------------------------------------------------------- */
hr {
  border: none;
  height: 1px;
  background-color: var(--color-border);
  margin-block: var(--space-2xl);
}

/* ----------------------------------------------------------------
   TABLES (basic)
   ---------------------------------------------------------------- */
table {
  width: 100%;
  border-collapse: collapse;
  margin-block: var(--space-lg);
}

th,
td {
  padding: var(--space-sm) var(--space-md);
  text-align: left;
  border-bottom: 1px solid var(--color-border);
}

th {
  font-weight: var(--fw-bold);
  color: var(--color-navy);
  font-size: var(--fs-small);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
}

/* ----------------------------------------------------------------
   IMAGES
   ---------------------------------------------------------------- */
img {
  max-width: 100%;
  height: auto;
  display: block;
}

figure {
  margin-block: var(--space-lg);
}

figcaption {
  margin-top: var(--space-sm);
  font-size: var(--fs-small);
  color: var(--color-text-light);
}

/* ----------------------------------------------------------------
   DARK SECTION TEXT OVERRIDES
   ---------------------------------------------------------------- */
.bg-navy :is(h1, h2, h3, h4, h5, h6) {
  color: var(--color-white);
}

.bg-navy p,
.bg-navy li {
  color: var(--color-gray-200);
}

.bg-navy .caption {
  color: var(--color-gray-300);
}

/* ----------------------------------------------------------------
   UTILITY TYPOGRAPHY CLASSES
   ---------------------------------------------------------------- */
.text-center {
  text-align: center;
}

.text-left {
  text-align: left;
}

.text-right {
  text-align: right;
}

.text-uppercase {
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
}

.text-balance {
  text-wrap: balance;
}

.text-pretty {
  text-wrap: pretty;
}

.fw-light { font-weight: var(--fw-light); }
.fw-regular { font-weight: var(--fw-regular); }
.fw-medium { font-weight: var(--fw-medium); }
.fw-bold { font-weight: var(--fw-bold); }
.fw-black { font-weight: var(--fw-black); }

/* ----------------------------------------------------------------
   LAYOUT UTILITIES
   ---------------------------------------------------------------- */
.flex {
  display: flex;
}

.flex-center {
  display: flex;
  align-items: center;
  justify-content: center;
}

.flex-between {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.flex-col {
  display: flex;
  flex-direction: column;
}

.flex-wrap {
  flex-wrap: wrap;
}

.gap-xs { gap: var(--space-xs); }
.gap-sm { gap: var(--space-sm); }
.gap-md { gap: var(--space-md); }
.gap-lg { gap: var(--space-lg); }
.gap-xl { gap: var(--space-xl); }
.gap-2xl { gap: var(--space-2xl); }

/* ----------------------------------------------------------------
   SPACING UTILITIES
   ---------------------------------------------------------------- */
.mt-0  { margin-top: 0; }
.mt-sm { margin-top: var(--space-sm); }
.mt-md { margin-top: var(--space-md); }
.mt-lg { margin-top: var(--space-lg); }
.mt-xl { margin-top: var(--space-xl); }
.mt-2xl { margin-top: var(--space-2xl); }

.mb-0  { margin-bottom: 0; }
.mb-sm { margin-bottom: var(--space-sm); }
.mb-md { margin-bottom: var(--space-md); }
.mb-lg { margin-bottom: var(--space-lg); }
.mb-xl { margin-bottom: var(--space-xl); }
.mb-2xl { margin-bottom: var(--space-2xl); }

/* ----------------------------------------------------------------
   RESPONSIVE DISPLAY UTILITIES
   ---------------------------------------------------------------- */
.hide-mobile {
  display: none;
}

@media (min-width: 768px) {
  .hide-mobile {
    display: initial;
  }
  .hide-tablet-up {
    display: none;
  }
}

@media (min-width: 1024px) {
  .hide-desktop-up {
    display: none;
  }
}

/* ===== Interior Hero Breadcrumbs (shared across all interior pages) ===== */
.page-hero__breadcrumbs {
  margin: 0 0 var(--space-md, 16px);
}

.page-hero__breadcrumbs ol {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.page-hero__breadcrumbs li {
  display: inline-flex;
  align-items: center;
  color: rgba(255, 255, 255, 0.82);
  font-size: 0.95rem;
  line-height: 1.4;
}

.page-hero__breadcrumbs li + li::before {
  content: "/";
  margin-right: 8px;
  color: rgba(255, 255, 255, 0.55);
}

.page-hero__breadcrumbs a {
  color: #fff;
  text-decoration: none;
}

.page-hero__breadcrumbs a:hover,
.page-hero__breadcrumbs a:focus {
  text-decoration: underline;
}

@media (max-width: 640px) {
  .page-hero__breadcrumbs li {
    font-size: 0.875rem;
  }
}
/* ===== End Interior Hero Breadcrumbs ===== */

/* ===== Hero Accent Line (global — works across all hero types) ===== */
.hero-accent-line {
  display: block;
  width: 60px;
  height: 3px;
  background: var(--color-red, #CF081F);
  border-radius: 9999px;
  margin-top: var(--space-xl, 2rem);
}

/* ===== Breadcrumb Accent Line — DISABLED (using per-page HTML elements instead) ===== */
