/* =========================================================
   utterdeck.css — Bootstrap-compatible class layer
   ---------------------------------------------------------
   Drop-in replacement for bootstrap.min.css: same class names,
   same layout grid, restyled with the Utterdeck "clay" palette,
   Instrument Serif display type, hand-made 1.5px ink borders,
   and the signature hard-offset drop-ink shadow.

   Link AFTER colors_and_type.css (tokens come from there) or
   use standalone — it imports the tokens itself.

   Covered Bootstrap primitives:
     container / container-fluid
     row / col-{1..12} / col-{sm,md,lg,xl}-{1..12}
     d-* (flex display & flex helpers) / justify-* / align-* / gap-*
     m-* / p-* / mt-* / mb-* / mx-auto
     text-* (colors + alignment) / fw-* / fs-*
     btn / btn-primary / btn-secondary / btn-success / btn-warning
          / btn-outline-* / btn-light / btn-dark / btn-link / btn-sm / btn-lg
     btn-group
     card / card-body / card-header / card-footer / card-img-top / card-title
     navbar / navbar-brand / navbar-nav / nav-link / nav-item
     alert / alert-primary / alert-success / alert-warning / alert-danger / alert-info
     badge / rounded-pill
     form-control / form-label / form-select / form-check
     input-group
     list-group / list-group-item
     progress / progress-bar
     modal / modal-dialog / modal-content
     breadcrumb
     pagination
     table / table-striped / table-bordered
     bg-* (primary/light/dark/warning/danger/success)
     rounded / rounded-{0..4} / rounded-pill / rounded-circle
     border / border-0 / shadow / shadow-sm / shadow-lg
     w-* / h-* / mw-100 / mh-100
   ========================================================= */

@import url("colors_and_type.css");

/* =========================================================
   RESET / BASE (Bootstrap-flavored)
   ========================================================= */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; -webkit-tap-highlight-color: transparent; }
body {
  margin: 0;
  font-family: var(--fs-ui);
  font-size: 1rem;
  line-height: 1.5;
  color: var(--ink);
  background: var(--cream);
  -webkit-font-smoothing: antialiased;
}
a { color: var(--clay); text-decoration: none; }
a:hover { color: var(--clay-deep); text-decoration: underline; text-decoration-thickness: 1.5px; text-underline-offset: 2px; }
hr { border: 0; border-top: 1px dashed var(--paper-line-strong); margin: 1.5rem 0; }
small { font-size: 0.875em; }
code { color: var(--clay-deep); background: var(--cream-2); padding: 2px 6px; border-radius: 4px; }

/* Bootstrap-compat heading sizes, but in Instrument Serif italic-able */
h1, h2, h3, h4, h5, h6 { font-family: var(--fs-display); font-weight: 400; letter-spacing: -0.02em; margin: 0 0 0.5rem; line-height: 1.1; }
h1 { font-size: 2.5rem; }
h2 { font-size: 2rem; }
h3 { font-size: 1.75rem; }
h4 { font-size: 1.5rem; }
h5 { font-size: 1.25rem; }
h6 { font-size: 1rem; }
.display-1 { font-size: 5rem; line-height: 0.95; letter-spacing: -0.025em; font-family: var(--fs-display); }
.display-2 { font-size: 4.5rem; line-height: 0.95; letter-spacing: -0.025em; font-family: var(--fs-display); }
.display-3 { font-size: 4rem; line-height: 0.95; letter-spacing: -0.025em; font-family: var(--fs-display); }
.display-4 { font-size: 3.5rem; line-height: 0.95; letter-spacing: -0.025em; font-family: var(--fs-display); }
.display-5 { font-size: 3rem; line-height: 0.95; letter-spacing: -0.025em; font-family: var(--fs-display); }
.display-6 { font-size: 2.5rem; line-height: 0.95; letter-spacing: -0.025em; font-family: var(--fs-display); }
.lead { font-size: 1.125rem; color: var(--ink-soft); }

/* Italic clay accent works out-of-box: wrap in <em> or <i> */
em, i, .fst-italic { font-style: italic; color: var(--clay); }

/* =========================================================
   CONTAINER / GRID
   ========================================================= */
.container, .container-fluid { width: 100%; padding-right: 12px; padding-left: 12px; margin-right: auto; margin-left: auto; }
.container { max-width: 1140px; }
@media (min-width: 576px)  { .container-sm { max-width: 540px; } }
@media (min-width: 768px)  { .container-md { max-width: 720px; } }
@media (min-width: 992px)  { .container-lg { max-width: 960px; } }
@media (min-width: 1200px) { .container-xl { max-width: 1140px; } .container { max-width: 1140px; } }
@media (min-width: 1400px) { .container-xxl { max-width: 1320px; } }

.row {
  display: flex; flex-wrap: wrap;
  margin-right: -12px; margin-left: -12px;
}
.row > * { flex-shrink: 0; width: 100%; max-width: 100%; padding-right: 12px; padding-left: 12px; }

.col { flex: 1 0 0%; }
.col-auto { flex: 0 0 auto; width: auto; }
.col-1  { flex: 0 0 auto; width: 8.3333%; }
.col-2  { flex: 0 0 auto; width: 16.6667%; }
.col-3  { flex: 0 0 auto; width: 25%; }
.col-4  { flex: 0 0 auto; width: 33.3333%; }
.col-5  { flex: 0 0 auto; width: 41.6667%; }
.col-6  { flex: 0 0 auto; width: 50%; }
.col-7  { flex: 0 0 auto; width: 58.3333%; }
.col-8  { flex: 0 0 auto; width: 66.6667%; }
.col-9  { flex: 0 0 auto; width: 75%; }
.col-10 { flex: 0 0 auto; width: 83.3333%; }
.col-11 { flex: 0 0 auto; width: 91.6667%; }
.col-12 { flex: 0 0 auto; width: 100%; }
@media (min-width: 768px) {
  .col-md-1 { width: 8.3333%; } .col-md-2 { width: 16.6667%; } .col-md-3 { width: 25%; }
  .col-md-4 { width: 33.3333%; } .col-md-5 { width: 41.6667%; } .col-md-6 { width: 50%; }
  .col-md-7 { width: 58.3333%; } .col-md-8 { width: 66.6667%; } .col-md-9 { width: 75%; }
  .col-md-10 { width: 83.3333%; } .col-md-11 { width: 91.6667%; } .col-md-12 { width: 100%; }
}
@media (min-width: 992px) {
  .col-lg-1 { width: 8.3333%; } .col-lg-2 { width: 16.6667%; } .col-lg-3 { width: 25%; }
  .col-lg-4 { width: 33.3333%; } .col-lg-5 { width: 41.6667%; } .col-lg-6 { width: 50%; }
  .col-lg-7 { width: 58.3333%; } .col-lg-8 { width: 66.6667%; } .col-lg-9 { width: 75%; }
  .col-lg-10 { width: 83.3333%; } .col-lg-11 { width: 91.6667%; } .col-lg-12 { width: 100%; }
}

.g-0 > * { padding-right: 0; padding-left: 0; } .g-0 { margin: 0; }
.g-1 > * { padding: 4px; } .g-2 > * { padding: 8px; }
.g-3 > * { padding: 12px; } .g-4 > * { padding: 16px; }
.g-5 > * { padding: 24px; }

/* =========================================================
   FLEX / DISPLAY / SPACING / TEXT UTILITIES
   ========================================================= */
.d-none { display: none !important; } .d-block { display: block !important; }
.d-inline { display: inline !important; } .d-inline-block { display: inline-block !important; }
.d-flex { display: flex !important; } .d-inline-flex { display: inline-flex !important; }
.d-grid { display: grid !important; }

.flex-row { flex-direction: row !important; } .flex-column { flex-direction: column !important; }
.flex-wrap { flex-wrap: wrap !important; } .flex-nowrap { flex-wrap: nowrap !important; }
.flex-grow-0 { flex-grow: 0 !important; } .flex-grow-1 { flex-grow: 1 !important; }
.flex-shrink-0 { flex-shrink: 0 !important; } .flex-shrink-1 { flex-shrink: 1 !important; }

.justify-content-start { justify-content: flex-start !important; }
.justify-content-end { justify-content: flex-end !important; }
.justify-content-center { justify-content: center !important; }
.justify-content-between { justify-content: space-between !important; }
.justify-content-around { justify-content: space-around !important; }

.align-items-start { align-items: flex-start !important; }
.align-items-end { align-items: flex-end !important; }
.align-items-center { align-items: center !important; }
.align-items-baseline { align-items: baseline !important; }
.align-items-stretch { align-items: stretch !important; }

.gap-0 { gap: 0 !important; } .gap-1 { gap: 4px !important; } .gap-2 { gap: 8px !important; }
.gap-3 { gap: 16px !important; } .gap-4 { gap: 24px !important; } .gap-5 { gap: 48px !important; }

/* Spacing (0,1,2,3,4,5 = 0, 4, 8, 16, 24, 48) */
.m-0{margin:0!important}.m-1{margin:4px!important}.m-2{margin:8px!important}.m-3{margin:16px!important}.m-4{margin:24px!important}.m-5{margin:48px!important}.m-auto{margin:auto!important}
.mt-0{margin-top:0!important}.mt-1{margin-top:4px!important}.mt-2{margin-top:8px!important}.mt-3{margin-top:16px!important}.mt-4{margin-top:24px!important}.mt-5{margin-top:48px!important}.mt-auto{margin-top:auto!important}
.mb-0{margin-bottom:0!important}.mb-1{margin-bottom:4px!important}.mb-2{margin-bottom:8px!important}.mb-3{margin-bottom:16px!important}.mb-4{margin-bottom:24px!important}.mb-5{margin-bottom:48px!important}.mb-auto{margin-bottom:auto!important}
.ms-0{margin-left:0!important}.ms-1{margin-left:4px!important}.ms-2{margin-left:8px!important}.ms-3{margin-left:16px!important}.ms-4{margin-left:24px!important}.ms-5{margin-left:48px!important}.ms-auto{margin-left:auto!important}
.me-0{margin-right:0!important}.me-1{margin-right:4px!important}.me-2{margin-right:8px!important}.me-3{margin-right:16px!important}.me-4{margin-right:24px!important}.me-5{margin-right:48px!important}.me-auto{margin-right:auto!important}
.mx-auto{margin-left:auto!important;margin-right:auto!important}
.my-0{margin-top:0!important;margin-bottom:0!important}.my-1{margin-top:4px!important;margin-bottom:4px!important}.my-2{margin-top:8px!important;margin-bottom:8px!important}.my-3{margin-top:16px!important;margin-bottom:16px!important}.my-4{margin-top:24px!important;margin-bottom:24px!important}.my-5{margin-top:48px!important;margin-bottom:48px!important}

.p-0{padding:0!important}.p-1{padding:4px!important}.p-2{padding:8px!important}.p-3{padding:16px!important}.p-4{padding:24px!important}.p-5{padding:48px!important}
.pt-0{padding-top:0!important}.pt-1{padding-top:4px!important}.pt-2{padding-top:8px!important}.pt-3{padding-top:16px!important}.pt-4{padding-top:24px!important}.pt-5{padding-top:48px!important}
.pb-0{padding-bottom:0!important}.pb-1{padding-bottom:4px!important}.pb-2{padding-bottom:8px!important}.pb-3{padding-bottom:16px!important}.pb-4{padding-bottom:24px!important}.pb-5{padding-bottom:48px!important}
.ps-0{padding-left:0!important}.ps-1{padding-left:4px!important}.ps-2{padding-left:8px!important}.ps-3{padding-left:16px!important}.ps-4{padding-left:24px!important}.ps-5{padding-left:48px!important}
.pe-0{padding-right:0!important}.pe-1{padding-right:4px!important}.pe-2{padding-right:8px!important}.pe-3{padding-right:16px!important}.pe-4{padding-right:24px!important}.pe-5{padding-right:48px!important}
.px-0{padding-left:0!important;padding-right:0!important}.px-1{padding-left:4px!important;padding-right:4px!important}.px-2{padding-left:8px!important;padding-right:8px!important}.px-3{padding-left:16px!important;padding-right:16px!important}.px-4{padding-left:24px!important;padding-right:24px!important}.px-5{padding-left:48px!important;padding-right:48px!important}
.py-0{padding-top:0!important;padding-bottom:0!important}.py-1{padding-top:4px!important;padding-bottom:4px!important}.py-2{padding-top:8px!important;padding-bottom:8px!important}.py-3{padding-top:16px!important;padding-bottom:16px!important}.py-4{padding-top:24px!important;padding-bottom:24px!important}.py-5{padding-top:48px!important;padding-bottom:48px!important}

/* Text */
.text-start   { text-align: left !important; }
.text-center  { text-align: center !important; }
.text-end     { text-align: right !important; }
.text-uppercase { text-transform: uppercase !important; letter-spacing: 0.04em; }
.text-lowercase { text-transform: lowercase !important; }
.text-muted   { color: var(--ink-mute) !important; }
.text-primary { color: var(--clay) !important; }
.text-success { color: var(--forest) !important; }
.text-warning { color: var(--yolk) !important; }
.text-danger  { color: var(--clay-deep) !important; }
.text-info    { color: var(--ink-soft) !important; }
.text-dark    { color: var(--ink) !important; }
.text-light   { color: var(--cream) !important; }
.text-white   { color: #fff !important; }
.text-body    { color: var(--ink) !important; }

.fw-light { font-weight: 300 !important; } .fw-normal { font-weight: 400 !important; }
.fw-medium { font-weight: 500 !important; } .fw-semibold { font-weight: 600 !important; }
.fw-bold { font-weight: 700 !important; }

.fs-1 { font-size: 2.5rem !important; } .fs-2 { font-size: 2rem !important; }
.fs-3 { font-size: 1.75rem !important; } .fs-4 { font-size: 1.5rem !important; }
.fs-5 { font-size: 1.25rem !important; } .fs-6 { font-size: 1rem !important; }

.font-monospace { font-family: var(--fs-mono) !important; text-transform: uppercase; letter-spacing: 0.04em; font-size: 0.75rem; }
.font-serif     { font-family: var(--fs-display) !important; }

/* =========================================================
   BACKGROUNDS / BORDERS / SHADOWS / RADII / SIZING
   ========================================================= */
.bg-primary { background-color: var(--clay) !important; color: var(--cream); }
.bg-secondary { background-color: var(--ink-soft) !important; color: var(--cream); }
.bg-success { background-color: var(--forest) !important; color: var(--cream); }
.bg-warning { background-color: var(--yolk) !important; color: var(--ink); }
.bg-danger  { background-color: var(--clay-deep) !important; color: var(--cream); }
.bg-light   { background-color: var(--cream-2) !important; color: var(--ink); }
.bg-dark    { background-color: var(--ink) !important; color: var(--cream); }
.bg-body    { background-color: var(--cream) !important; color: var(--ink); }
.bg-white   { background-color: #fff !important; }
.bg-transparent { background-color: transparent !important; }

.border          { border: 1.5px solid var(--ink) !important; }
.border-0        { border: 0 !important; }
.border-top      { border-top: 1.5px solid var(--ink) !important; }
.border-bottom   { border-bottom: 1.5px solid var(--ink) !important; }
.border-start    { border-left: 1.5px solid var(--ink) !important; }
.border-end      { border-right: 1.5px solid var(--ink) !important; }
.border-primary  { border-color: var(--clay) !important; }
.border-dashed   { border-style: dashed !important; border-color: var(--paper-line-strong) !important; }

/* Drop-ink shadow — Utterdeck's signature replaces the soft BS shadow */
.shadow-none { box-shadow: none !important; }
.shadow-sm   { box-shadow: 2px 2px 0 var(--ink) !important; }
.shadow      { box-shadow: 3px 3px 0 var(--ink) !important; }
.shadow-lg   { box-shadow: 6px 6px 0 var(--ink) !important; }
.shadow-xl   { box-shadow: 8px 8px 0 var(--forest), 14px 14px 0 var(--paper-line-strong) !important; }

.rounded        { border-radius: 10px !important; }
.rounded-0      { border-radius: 0 !important; }
.rounded-1      { border-radius: 4px !important; }
.rounded-2      { border-radius: 6px !important; }
.rounded-3      { border-radius: 10px !important; }
.rounded-4      { border-radius: 14px !important; }
.rounded-5      { border-radius: 18px !important; }
.rounded-pill   { border-radius: 999px !important; }
.rounded-circle { border-radius: 50% !important; }

.w-25 { width: 25% !important; } .w-50 { width: 50% !important; }
.w-75 { width: 75% !important; } .w-100 { width: 100% !important; } .w-auto { width: auto !important; }
.h-25 { height: 25% !important; } .h-50 { height: 50% !important; }
.h-75 { height: 75% !important; } .h-100 { height: 100% !important; } .h-auto { height: auto !important; }
.mw-100 { max-width: 100% !important; } .mh-100 { max-height: 100% !important; }

/* =========================================================
   BUTTONS (Bootstrap class contract; drop-ink restyle)
   ========================================================= */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--fs-ui); font-weight: 500;
  font-size: 0.875rem; line-height: 1.5;
  padding: 0.625rem 1.25rem;
  border: 1.5px solid var(--ink);
  border-radius: 999px;
  background: transparent;
  color: var(--ink);
  cursor: pointer;
  text-decoration: none;
  transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s, color 0.15s;
  user-select: none;
}
.btn:hover { text-decoration: none; }
.btn:focus-visible { outline: 3px solid var(--yolk); outline-offset: 2px; }
.btn:disabled, .btn.disabled { opacity: 0.55; cursor: not-allowed; pointer-events: none; }
.btn-sm { padding: 0.375rem 0.875rem; font-size: 0.8125rem; }
.btn-lg { padding: 1rem 1.75rem; font-size: 1rem; }

.btn-primary   { background: var(--clay); color: var(--cream); box-shadow: 3px 3px 0 var(--ink); }
.btn-primary:hover   { transform: translate(-1px,-1px); box-shadow: 4px 4px 0 var(--ink); background: var(--clay); color: var(--cream); }
.btn-primary:active  { transform: translate(2px,2px);  box-shadow: 1px 1px 0 var(--ink); }

.btn-secondary { background: var(--ink); color: var(--cream); box-shadow: 3px 3px 0 var(--clay); }
.btn-secondary:hover { transform: translate(-1px,-1px); box-shadow: 4px 4px 0 var(--clay); color: var(--cream); }

.btn-success   { background: var(--forest); color: var(--cream); box-shadow: 3px 3px 0 var(--ink); }
.btn-success:hover { transform: translate(-1px,-1px); box-shadow: 4px 4px 0 var(--ink); color: var(--cream); }

.btn-warning   { background: var(--yolk); color: var(--ink); box-shadow: 3px 3px 0 var(--ink); }
.btn-warning:hover { transform: translate(-1px,-1px); box-shadow: 4px 4px 0 var(--ink); color: var(--ink); }

.btn-danger    { background: var(--clay-deep); color: var(--cream); box-shadow: 3px 3px 0 var(--ink); }
.btn-danger:hover  { transform: translate(-1px,-1px); box-shadow: 4px 4px 0 var(--ink); color: var(--cream); }

.btn-info      { background: var(--cream-3); color: var(--ink); box-shadow: 3px 3px 0 var(--ink); }

.btn-light     { background: var(--cream-2); color: var(--ink); }
.btn-light:hover { background: var(--cream-3); }
.btn-dark      { background: var(--ink); color: var(--cream); }
.btn-dark:hover  { background: var(--ink-soft); color: var(--cream); }

.btn-outline-primary { color: var(--clay); border-color: var(--clay); }
.btn-outline-primary:hover { background: var(--clay); color: var(--cream); }
.btn-outline-secondary { color: var(--ink); border-color: var(--ink); }
.btn-outline-secondary:hover { background: var(--ink); color: var(--cream); }
.btn-outline-success { color: var(--forest); border-color: var(--forest); }
.btn-outline-success:hover { background: var(--forest); color: var(--cream); }
.btn-outline-warning { color: var(--yolk); border-color: var(--yolk); }
.btn-outline-warning:hover { background: var(--yolk); color: var(--ink); }
.btn-outline-danger { color: var(--clay-deep); border-color: var(--clay-deep); }
.btn-outline-danger:hover { background: var(--clay-deep); color: var(--cream); }
.btn-outline-dark { color: var(--ink); border-color: var(--ink); }
.btn-outline-dark:hover { background: var(--ink); color: var(--cream); }
.btn-outline-light { color: var(--cream); border-color: var(--cream); }

.btn-link { background: transparent; border: none; color: var(--clay); box-shadow: none; padding: 0.25rem 0; }
.btn-link:hover { color: var(--clay-deep); text-decoration: underline; box-shadow: none; transform: none; }

.btn-group { display: inline-flex; }
.btn-group > .btn { border-radius: 0; border-right-width: 0; }
.btn-group > .btn:first-child { border-radius: 999px 0 0 999px; }
.btn-group > .btn:last-child  { border-radius: 0 999px 999px 0; border-right-width: 1.5px; }

/* =========================================================
   CARD
   ========================================================= */
.card {
  position: relative; display: flex; flex-direction: column;
  background: var(--cream-2);
  border: 1.5px solid var(--ink);
  border-radius: 14px;
  overflow: hidden;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.card:hover { transform: translateY(-4px) rotate(-0.3deg); box-shadow: 6px 6px 0 var(--ink); }
.card-body   { padding: 20px; flex: 1 1 auto; display: flex; flex-direction: column; gap: 10px; }
.card-header { padding: 14px 20px; border-bottom: 1.5px solid var(--ink); background: var(--cream-3); font-family: var(--fs-mono); font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-mute); }
.card-footer { padding: 14px 20px; border-top: 1px dashed var(--paper-line-strong); color: var(--ink-mute); font-size: 0.8125rem; }
.card-title    { font-family: var(--fs-display); font-size: 1.5rem; line-height: 1; margin: 0; }
.card-subtitle { font-family: var(--fs-mono); font-size: 0.6875rem; text-transform: uppercase; letter-spacing: 0.12em; color: var(--clay); }
.card-text     { color: var(--ink-soft); font-size: 0.9375rem; line-height: 1.5; margin: 0; }
.card-img, .card-img-top {
  width: 100%; display: block; aspect-ratio: 4/3; object-fit: cover;
  border-bottom: 1.5px solid var(--ink);
}
.card-img-bottom { width: 100%; display: block; border-top: 1.5px solid var(--ink); }

/* =========================================================
   NAVBAR / NAV
   ========================================================= */
.navbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 20px;
  background: var(--cream);
  border-bottom: 1.5px solid var(--ink);
}
.navbar-brand {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--fs-display); font-size: 1.5rem; letter-spacing: -0.02em;
  color: var(--ink); text-decoration: none;
}
.navbar-brand::before {
  content: "U";
  width: 32px; height: 32px; background: var(--clay); color: var(--cream);
  border-radius: 10px; display: grid; place-items: center;
  font-family: var(--fs-display); font-size: 1.25rem;
  transform: rotate(-4deg);
  box-shadow: 2px 2px 0 var(--ink);
}
.navbar-nav { display: flex; gap: 22px; list-style: none; margin: 0; padding: 0; }
.navbar-nav .nav-item { display: inline-flex; }
.nav-link {
  color: var(--ink-soft); text-decoration: none; font-size: 0.9375rem;
  padding: 6px 2px;
}
.nav-link:hover, .nav-link.active { color: var(--clay); }
.navbar-dark { background: var(--ink); color: var(--cream); border-bottom-color: var(--cream); }
.navbar-dark .navbar-brand, .navbar-dark .nav-link { color: var(--cream); }
.navbar-dark .nav-link:hover { color: var(--yolk); }

/* Nav pills — used on /Identity/Account/Manage and any other place the default
   Identity UI scaffolds a sidebar of .nav-pills. Override Bootstrap's default
   blue active pill with Utterdeck ink/cream so the page reads as one design. */
.nav-pills { gap: 4px; }
.nav-pills .nav-link {
  padding: 8px 14px;
  border-radius: 8px;
  border: 1.5px solid transparent;
  font-weight: 500;
  color: var(--ink-soft);
}
.nav-pills .nav-link:hover {
  color: var(--ink);
  background: var(--cream-2);
  border-color: var(--paper-line-strong);
}
.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
  color: var(--cream);
  background: var(--ink);
  border-color: var(--ink);
}

/* Nav tabs — same treatment so the Identity tab strip aligns with the
   dashboard's .segments tabstrip. */
.nav-tabs { border-bottom: 1.5px solid var(--paper-line-strong); }
.nav-tabs .nav-link {
  color: var(--ink-soft);
  border: 1.5px solid transparent;
  border-top-left-radius: 8px;
  border-top-right-radius: 8px;
  padding: 8px 14px;
  margin-bottom: -1.5px;
  font-weight: 500;
}
.nav-tabs .nav-link:hover {
  color: var(--ink);
  border-color: var(--paper-line-strong) var(--paper-line-strong) transparent;
  background: var(--cream-2);
}
.nav-tabs .nav-link.active {
  color: var(--ink);
  background: var(--cream);
  border-color: var(--paper-line-strong) var(--paper-line-strong) var(--cream);
}

/* =========================================================
   ALERT
   ========================================================= */
.alert {
  padding: 14px 18px; border: 1.5px solid var(--ink); border-radius: 14px;
  background: var(--cream-2); color: var(--ink);
  box-shadow: 3px 3px 0 var(--ink);
  font-size: 0.9375rem; line-height: 1.5;
  display: flex; gap: 10px; align-items: flex-start;
}
.alert-heading { font-family: var(--fs-display); font-size: 1.25rem; margin: 0 0 4px; white-space: nowrap; }
.alert-primary { background: color-mix(in oklab, var(--clay) 18%, var(--cream)); }
.alert-success { background: color-mix(in oklab, var(--forest) 18%, var(--cream)); }
.alert-warning { background: color-mix(in oklab, var(--yolk) 30%, var(--cream)); }
.alert-danger  { background: color-mix(in oklab, var(--clay-deep) 22%, var(--cream)); color: var(--ink); }
.alert-info    { background: var(--cream-3); }
.alert-dark    { background: var(--ink); color: var(--cream); box-shadow: 3px 3px 0 var(--cream); }

/* =========================================================
   BADGE
   ========================================================= */
.badge {
  display: inline-block; padding: 3px 10px;
  font-family: var(--fs-mono); font-size: 0.6875rem;
  letter-spacing: 0.1em; text-transform: uppercase;
  background: var(--ink); color: var(--cream);
  border-radius: 4px;
  line-height: 1.5;
}
.badge.bg-primary { background: var(--clay); color: var(--cream); }
.badge.bg-success { background: var(--forest); color: var(--cream); }
.badge.bg-warning { background: var(--yolk); color: var(--ink); }
.badge.bg-danger  { background: var(--clay-deep); color: var(--cream); }
.badge.bg-light   { background: var(--cream-2); color: var(--ink); border: 1px dashed var(--paper-line-strong); }

/* =========================================================
   FORMS
   ========================================================= */
.form-label { font-family: var(--fs-mono); font-size: 0.6875rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-mute); display: block; margin-bottom: 6px; }
.form-control, .form-select {
  display: block; width: 100%;
  font-family: var(--fs-ui); font-size: 0.9375rem; line-height: 1.5;
  padding: 10px 14px;
  color: var(--ink);
  background: var(--cream);
  border: 1.5px solid var(--ink);
  border-radius: 10px;
  transition: box-shadow 0.15s, border-color 0.15s;
}
.form-control::placeholder { color: var(--ink-mute); }
.form-control:focus, .form-select:focus {
  outline: none;
  box-shadow: 3px 3px 0 var(--clay);
  border-color: var(--clay);
}
.form-control:disabled { background: var(--cream-3); opacity: 0.7; }
.form-text { font-size: 0.8125rem; color: var(--ink-mute); margin-top: 4px; }

.form-check { display: flex; align-items: center; gap: 8px; }
.form-check-input {
  width: 18px; height: 18px; margin: 0;
  appearance: none;
  border: 1.5px solid var(--ink);
  border-radius: 4px;
  background: var(--cream);
  cursor: pointer;
  position: relative;
}
.form-check-input[type="radio"] { border-radius: 50%; }
.form-check-input:checked { background: var(--clay); }
.form-check-input[type="checkbox"]:checked::after {
  content: ""; position: absolute; left: 4px; top: 1px;
  width: 6px; height: 10px; border-right: 2px solid var(--cream); border-bottom: 2px solid var(--cream);
  transform: rotate(42deg);
}
.form-check-input[type="radio"]:checked::after {
  content: ""; position: absolute; left: 3px; top: 3px;
  width: 8px; height: 8px; border-radius: 50%; background: var(--cream);
}
.form-check-label { font-size: 0.9375rem; color: var(--ink); cursor: pointer; }

.form-switch .form-check-input {
  width: 36px; height: 20px; border-radius: 999px; position: relative;
}
.form-switch .form-check-input::before {
  content: ""; position: absolute; left: 2px; top: 2px;
  width: 14px; height: 14px; border-radius: 50%; background: var(--ink);
  transition: transform 0.15s, background 0.15s;
}
.form-switch .form-check-input:checked { background: var(--clay); border-color: var(--ink); }
.form-switch .form-check-input:checked::before { transform: translateX(16px); background: var(--cream); }

.input-group { display: flex; align-items: stretch; position: relative; }
/* Input inside an .input-group keeps only the outer (left) corner rounded
   and drops its right border so it meets the addon flush. The nested form
   used by ASP.NET Identity wraps the addon in an .input-group-append div
   (Bootstrap 4 pattern) — the descendant selectors below handle both the
   Bootstrap 5 flat children layout and the nested-wrapper layout. */
.input-group .form-control {
  border-radius: 10px 0 0 10px;
  border-right: 0;
}
.input-group .input-group-text {
  display: inline-flex; align-items: center; padding: 0 14px;
  background: var(--cream-3);
  border: 1.5px solid var(--ink);
  border-left: 0;
  border-radius: 0 10px 10px 0;
  font-family: var(--fs-mono); font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--ink-soft);
}
/* Prepend pattern: addon on the LEFT, input on the right — flip the radii. */
.input-group > .input-group-prepend:first-child .input-group-text,
.input-group > .input-group-text:first-child {
  border-radius: 10px 0 0 10px;
  border-right: 0;
  border-left: 1.5px solid var(--ink);
}
.input-group > .input-group-prepend:first-child + .form-control,
.input-group > .input-group-text:first-child + .form-control {
  border-radius: 0 10px 10px 0;
  border-right: 1.5px solid var(--ink);
  border-left: 0;
}
.input-group .btn { border-radius: 0 10px 10px 0; box-shadow: none; }
.input-group .input-group-append,
.input-group .input-group-prepend { display: flex; }

/* form-floating labels inside input-groups: Identity UI places <label> as
   the last child for Bootstrap 5 form-floating. We don't ship the full
   form-floating CSS, so absolute-position the label above the input and
   keep the label-on-top style consistent with the rest of the app. */
.input-group > label.form-label {
  position: absolute;
  top: -8px; left: 10px;
  margin: 0;
  padding: 0 6px;
  background: var(--cream);
  z-index: 2;
  pointer-events: none;
}

/* =========================================================
   LIST GROUP
   ========================================================= */
.list-group { display: flex; flex-direction: column; border: 1.5px solid var(--ink); border-radius: 14px; overflow: hidden; background: var(--cream-2); }
.list-group-item {
  padding: 14px 18px;
  border-bottom: 1px dashed var(--paper-line-strong);
  background: transparent; color: var(--ink);
  font-size: 0.9375rem;
}
.list-group-item:last-child { border-bottom: 0; }
.list-group-item.active { background: var(--clay); color: var(--cream); border-bottom-color: var(--ink); }
.list-group-flush { border: 0; border-radius: 0; background: transparent; }

/* =========================================================
   PROGRESS
   ========================================================= */
.progress {
  height: 12px; background: var(--cream-3); border: 1.5px solid var(--ink);
  border-radius: 999px; overflow: hidden;
}
.progress-bar {
  height: 100%; background: var(--clay); color: var(--cream);
  font-family: var(--fs-mono); font-size: 0.625rem;
  display: flex; align-items: center; justify-content: center;
  transition: width 0.4s ease;
}

/* =========================================================
   TABLE
   ========================================================= */
.table { width: 100%; border-collapse: collapse; color: var(--ink); }
.table th, .table td { padding: 10px 14px; text-align: left; border-bottom: 1px dashed var(--paper-line-strong); font-size: 0.9375rem; }
.table th { font-family: var(--fs-mono); font-size: 0.6875rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-mute); font-weight: 500; border-bottom: 1.5px solid var(--ink); }
.table-striped tbody tr:nth-of-type(odd) { background: var(--cream-2); }
.table-bordered { border: 1.5px solid var(--ink); border-radius: 12px; overflow: hidden; }
.table-bordered th, .table-bordered td { border: 1px dashed var(--paper-line-strong); }

/* =========================================================
   BREADCRUMB / PAGINATION
   ========================================================= */
.breadcrumb {
  display: flex; flex-wrap: wrap; list-style: none; gap: 8px;
  font-family: var(--fs-mono); font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-mute);
  margin: 0; padding: 0;
}
.breadcrumb-item + .breadcrumb-item::before { content: "/"; margin-right: 8px; color: var(--ink-mute); }
.breadcrumb-item a { color: var(--ink-soft); text-decoration: none; }
.breadcrumb-item a:hover { color: var(--clay); }
.breadcrumb-item.active { color: var(--ink); }

.pagination { display: inline-flex; gap: 6px; list-style: none; padding: 0; margin: 0; }
.page-item .page-link {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 36px; height: 36px; padding: 0 10px;
  border: 1.5px solid var(--ink); border-radius: 8px;
  background: var(--cream-2); color: var(--ink);
  font-size: 0.875rem; text-decoration: none;
  transition: transform 0.15s, box-shadow 0.15s;
}
.page-item .page-link:hover { transform: translate(-1px,-1px); box-shadow: 2px 2px 0 var(--ink); }
.page-item.active .page-link { background: var(--ink); color: var(--cream); }
.page-item.disabled .page-link { opacity: 0.4; pointer-events: none; }

/* =========================================================
   MODAL (basic)
   ========================================================= */
.modal-backdrop { position: fixed; inset: 0; background: rgba(30,42,74,0.55); backdrop-filter: blur(3px); }
.modal { position: fixed; inset: 0; display: grid; place-items: center; z-index: 1000; }
.modal-dialog { width: min(520px, 92vw); }
.modal-content {
  background: var(--cream); border: 1.5px solid var(--ink); border-radius: 18px;
  box-shadow: 8px 8px 0 var(--ink);
  overflow: hidden;
}
.modal-header { padding: 18px 22px; border-bottom: 1.5px solid var(--ink); display: flex; justify-content: space-between; align-items: center; background: var(--cream-2); }
.modal-title { font-family: var(--fs-display); font-size: 1.5rem; margin: 0; white-space: nowrap; }
.modal-body { padding: 22px; font-size: 0.9375rem; color: var(--ink-soft); line-height: 1.55; }
.modal-footer { padding: 14px 22px; border-top: 1px dashed var(--paper-line-strong); display: flex; gap: 10px; justify-content: flex-end; }
.btn-close {
  width: 28px; height: 28px; border-radius: 50%; border: 1.5px solid var(--ink);
  background: var(--cream-2); cursor: pointer; position: relative;
  padding: 0; flex-shrink: 0;
}
.btn-close::before, .btn-close::after {
  content: ""; position: absolute;
  top: 50%; left: 50%;
  width: 14px; height: 1.5px;
  background: var(--ink);
  transform-origin: center;
}
.btn-close::before { transform: translate(-50%, -50%) rotate(45deg); }
.btn-close::after  { transform: translate(-50%, -50%) rotate(-45deg); }
.btn-close:hover { background: var(--clay); }
.btn-close:hover::before, .btn-close:hover::after { background: var(--cream); }

/* =========================================================
   TOOLTIP / POPOVER (pure CSS)
   ========================================================= */
[data-bs-toggle="tooltip"] { position: relative; }
[data-bs-toggle="tooltip"]:hover::after {
  content: attr(data-bs-title); position: absolute; bottom: 100%; left: 50%; transform: translateX(-50%) translateY(-6px);
  background: var(--ink); color: var(--cream);
  padding: 4px 10px; border-radius: 6px;
  font-family: var(--fs-mono); font-size: 0.6875rem; text-transform: uppercase; letter-spacing: 0.08em;
  white-space: nowrap;
}

/* =========================================================
   RESPONSIVE HELPERS
   ========================================================= */
@media (max-width: 767.98px) {
  .d-md-none { display: none !important; }
  .d-md-block { display: block !important; }
}
@media (min-width: 768px) {
  .d-md-block { display: block !important; }
  .d-md-flex { display: flex !important; }
}

/* End of utterdeck.css */
