@import "https://unpkg.com/ionicons@4.5.10-0/dist/css/ionicons.min.css";@import "https://fonts.googleapis.com/css?family=Source+Sans+Pro:300,400,600&display=swap";@import "https://fonts.googleapis.com/css?family=Source+Code+Pro&display=swap";.grid {
  width: 100%;
  padding: 0 32px;
  max-width: 1200px;
  margin: 0 auto;
  box-sizing: border-box;
}
.row {
  display: flex;
  flex-flow: row;
  gap: 2%;
}
.row:after,
.grid:after {
  clear: both;
  content: "";
  display: table;
}
.column {
  display: flex;
  flex-direction: column;
  flex-grow: 0;
  width: 100%;
  float: left;
  box-sizing: border-box;
}
@media only all {
  .column:not(.no-margin) {
    margin-right: 0;
  }
  .column:last-child {
    margin-right: 0;
  }
  .column.one {
    width: 6.5%;
  }
  .column.one.no-margin:not(:last-child) {
    width: 8.5%;
  }
  .column.two {
    width: 15%;
  }
  .column.two.no-margin:not(:last-child) {
    width: 17%;
  }
  .column.three {
    width: 23.5%;
  }
  .column.three.no-margin:not(:last-child) {
    width: 25.5%;
  }
  .column.four {
    width: 32%;
  }
  .column.four.no-margin:not(:last-child) {
    width: 34%;
  }
  .column.five {
    width: 40.5%;
  }
  .column.five.no-margin:not(:last-child) {
    width: 42.5%;
  }
  .column.six {
    width: 49%;
  }
  .column.six.no-margin:not(:last-child) {
    width: 51%;
  }
  .column.seven {
    width: 57.5%;
  }
  .column.seven.no-margin:not(:last-child) {
    width: 59.5%;
  }
  .column.eight {
    width: 66%;
  }
  .column.eight.no-margin:not(:last-child) {
    width: 68%;
  }
  .column.nine {
    width: 74.5%;
  }
  .column.nine.no-margin:not(:last-child) {
    width: 76.5%;
  }
  .column.ten {
    width: 83%;
  }
  .column.ten.no-margin:not(:last-child) {
    width: 85%;
  }
  .column.eleven {
    width: 91.5%;
  }
  .column.eleven.no-margin:not(:last-child) {
    width: 93.5%;
  }
  .column.offset-one {
    margin-left: 8.5%;
  }
  .column.offset-two {
    margin-left: 17%;
  }
  .column.offset-three {
    margin-left: 25.5%;
  }
  .column.offset-four {
    margin-left: 34%;
  }
  .column.offset-five {
    margin-left: 42.5%;
  }
  .column.offset-six {
    margin-left: 51%;
  }
  .column.offset-seven {
    margin-left: 59.5%;
  }
  .column.offset-eight {
    margin-left: 68%;
  }
  .column.offset-nine {
    margin-left: 76.5%;
  }
  .column.offset-ten {
    margin-left: 85%;
  }
  .column.offset-eleven {
    margin-left: 93.5%;
  }
}
@media (max-width: 640px) {
  .row:not(.non-responsive) > .column {
    width: 100% !important;
    margin-right: 0;
    margin-left: 0;
  }
  .large-only {
    display: none;
  }
  .row:not(.non-responsive) {
    flex-direction: column;
  }
}
@media (min-width: 640px) {
  .small-only {
    display: none;
  }
}
*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

html {
  font-size: 62.5%;
}

body {
  font-size: 1.6em;
  line-height: 1.5;
  font-family: "Source Sans Pro", sans-serif;
  background-color: #0d0d14;
  color: #d0d0e0;
  min-height: 100vh;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 400;
  color: #e8e8f0;
}
h1 {
  font-size: 5rem;
}
h2 {
  font-size: 4.5rem;
}
h3 {
  font-size: 2.6rem;
}
h4 {
  font-size: 3.5rem;
}
h5 {
  font-size: 3rem;
}
h6 {
  font-size: 2.5rem;
}

.subtext {
  font-size: 1.6rem;
  font-weight: 300;
  color: #6b6b80;
}
.subtext strong {
  font-weight: 600;
  color: #9090a8;
}
.subtext a {
  color: #5a8aff !important;
  text-decoration: none;
  transition: color 0.2s;
}
.subtext a:hover {
  color: #839dff !important;
}

em {
  font-style: italic;
}

/* ── HEADER ─────────────────────────────────────────────── */
header {
  width: 100%;
  display: flex;
  flex-direction: row;
  background: #13131f;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  box-shadow: 0 2px 20px rgba(0, 0, 0, 0.4);
  margin-bottom: 0;
}

header #icon,
header #url_submit_button {
  box-sizing: border-box;
  min-width: 7rem;
  line-height: 7rem;
  text-align: center;
  font-size: 4.5rem;
}

header #icon {
  font-size: 2.2rem;
  font-weight: 700;
  background: linear-gradient(135deg, #005dff, #6339ff);
  color: #fff;
  border: none;
  letter-spacing: -1px;
  font-family: "Source Sans Pro", sans-serif;
  min-width: 7rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

header #url_submit_button {
  color: #4a4a6a;
  font-size: 2.6rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-bottom: none;
  min-width: 6rem;
  transition:
    color 0.2s,
    background 0.2s;
}

header #url_submit_button:hover {
  color: #5a8aff;
  background: rgba(0, 93, 255, 0.08);
  cursor: pointer;
}

header #url_input {
  height: 7rem;
  line-height: 7rem;
  padding: 0 2rem;
  width: 100%;
  border: none;
  font-size: 1.7rem;
  font-family: "Source Code Pro", monospace;
  background: transparent;
  color: #d0d0e0;
  outline: none;
  caret-color: #005dff;
}

header #url_input::placeholder {
  color: #3a3a55;
}

/* ── ARTICLE ─────────────────────────────────────────────── */
article {
  padding-top: 3rem;
}

/* ── ALERT BOX (MessageBox + FontSetContainer header) ───── */
.alertBox {
  flex-direction: row;
  display: flex;
  align-items: center;
  background: #13131f;
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: 12px;
  padding: 2rem 2.4rem;
  margin-bottom: 2.4rem;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.3);
}

.alertBox .subtext {
  color: #6b6b80;
  margin-top: 0.4rem;
}

.alertBox .info_container h3 {
  color: #e8e8f0;
  font-size: 2.2rem;
  font-weight: 600;
}

.alertBox .subtext a,
.item .lower .info_container a {
  color: #5a8aff;
  text-decoration: none;
  transition: color 0.2s;
}
.alertBox .subtext a:hover,
.item .lower .info_container a:hover {
  color: #839dff;
}

/* ── FONT CARD ───────────────────────────────────────────── */
.item {
  display: flex;
  flex-flow: column;
  height: 100%;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.07);
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.3);
  transition:
    border-color 0.2s,
    box-shadow 0.2s,
    transform 0.2s;
  background: #13131f;
}

.item:hover {
  border-color: rgba(0, 93, 255, 0.4);
  box-shadow: 0 8px 32px rgba(0, 93, 255, 0.15);
  transform: translateY(-2px);
}

.item .upper {
  border: none;
  border-radius: 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.07);
  padding: 2.4rem 2rem;
  font-size: 2.8rem;
  height: 100%;
  background: #0f0f1c;
  color: #e8e8f0;
}

.item .lower {
  background: #13131f;
  border: none;
  border-radius: 0;
  display: flex;
  flex-direction: row;
  align-items: center;
}

.info_container {
  flex-grow: 1;
  padding: 1.2rem 1.4rem;
}

.info_container p {
  color: #c0c0d8;
  font-size: 1.5rem;
  font-weight: 500;
}

.info_container .small {
  font-size: 1.3rem;
  color: #4a4a6a;
  margin-top: 0.1rem;
}

.button_container {
  padding: 1rem 1.4rem;
}

.button_container .button {
  background: transparent;
  border-radius: 8px;
  border: 1px solid rgba(0, 93, 255, 0.4);
  padding: 0.9rem 1.3rem;
  color: #5a8aff;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  transition:
    background 0.2s,
    color 0.2s,
    border-color 0.2s;
  font-size: 2rem;
}

.button_container .button:hover {
  background: linear-gradient(135deg, #005dff, #6339ff);
  border-color: transparent;
  color: #fff;
  cursor: pointer;
  box-shadow: 0 4px 16px rgba(0, 93, 255, 0.35);
}

/* ── ROW SPACING ─────────────────────────────────────────── */
header,
footer {
  margin-bottom: 0;
}

.row {
  margin-bottom: 2rem;
}

footer p,
footer a,
footer a:active {
  color: #4a4a6a;
}

header[data-v-e0b57308]:focus-within {
  box-shadow:
    0 2px 20px rgba(0, 0, 0, 0.4),
    0 0 0 1px rgba(0, 93, 255, 0.3) inset;
}

.upper p[data-v-1467776a] {
        font-family: var(--2e677c3f);
}

*[data-v-66b170c8] {
  box-sizing: border-box;
}
.password-gate[data-v-66b170c8] {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  background: #0d0d14;
  background-image:
    radial-gradient(
      ellipse at 20% 50%,
      rgba(99, 57, 255, 0.08) 0%,
      transparent 60%
    ),
    radial-gradient(
      ellipse at 80% 20%,
      rgba(233, 69, 96, 0.07) 0%,
      transparent 50%
    );
  padding: 2rem;
}
.password-box[data-v-66b170c8] {
  background: #13131f;
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: 16px;
  padding: 3rem 2.5rem;
  text-align: center;
  max-width: 420px;
  width: 100%;
  box-shadow:
    0 24px 64px rgba(0, 0, 0, 0.6),
    0 1px 0 rgba(255, 255, 255, 0.05) inset;
}
.logo-wrap[data-v-66b170c8] {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.9rem;
  margin-bottom: 0.6rem;
}
.logo-icon[data-v-66b170c8] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  background: linear-gradient(135deg, #005dff, #6339ff);
  border-radius: 10px;
  color: #fff;
  font-size: 1.5rem;
  font-weight: 700;
  font-family: "Source Sans Pro", sans-serif;
  letter-spacing: -1px;
  flex-shrink: 0;
}
.password-box h1[data-v-66b170c8] {
  color: #ffffff;
  font-size: 2rem;
  font-weight: 700;
  font-family: "Source Sans Pro", sans-serif;
  letter-spacing: -0.5px;
  margin: 0;
}
.subtitle[data-v-66b170c8] {
  color: #6b6b80;
  font-size: 0.92rem;
  margin-bottom: 2rem;
  font-family: "Source Sans Pro", sans-serif;
}
form[data-v-66b170c8] {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  text-align: left;
}
.input-label[data-v-66b170c8] {
  color: #9090a8;
  font-size: 0.82rem;
  font-weight: 600;
  font-family: "Source Sans Pro", sans-serif;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 0.25rem;
  display: block;
}
.input-wrap[data-v-66b170c8] {
  display: flex;
  align-items: center;
  background: #1c1c2e;
  border: 1px solid rgba(255, 255, 255, 0.09);
  border-radius: 10px;
  overflow: hidden;
  transition:
    border-color 0.2s,
    box-shadow 0.2s;
  margin-bottom: 0.4rem;
}
.input-wrap[data-v-66b170c8]:focus-within {
  border-color: #005dff;
  box-shadow: 0 0 0 3px rgba(0, 93, 255, 0.15);
}
.input-wrap.input-error[data-v-66b170c8] {
  border-color: #e94560;
  box-shadow: 0 0 0 3px rgba(233, 69, 96, 0.15);
}
.input-wrap input[data-v-66b170c8] {
  flex: 1;
  padding: 0.75rem 1rem;
  background: transparent;
  border: none;
  color: #fff;
  font-size: 1rem;
  outline: none;
  font-family: "Source Code Pro", monospace;
  letter-spacing: 0.05em;
}
.input-wrap input[data-v-66b170c8]::placeholder {
  color: #3a3a55;
  letter-spacing: 0.15em;
}
.eye-btn[data-v-66b170c8] {
  background: none;
  border: none;
  padding: 0 0.85rem;
  cursor: pointer;
  color: #4a4a6a;
  display: flex;
  align-items: center;
  transition: color 0.2s;
  flex-shrink: 0;
}
.eye-btn[data-v-66b170c8]:hover {
  color: #9090b8;
}
.eye-btn svg[data-v-66b170c8] {
  width: 18px;
  height: 18px;
}
.error-msg[data-v-66b170c8] {
  color: #e94560;
  font-size: 0.85rem;
  font-family: "Source Sans Pro", sans-serif;
  display: flex;
  align-items: center;
  gap: 0.4rem;
  margin-bottom: 0.4rem;
}
.error-msg svg[data-v-66b170c8] {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}
.submit-btn[data-v-66b170c8] {
  margin-top: 0.6rem;
  padding: 0.78rem 1rem;
  border-radius: 10px;
  border: none;
  background: linear-gradient(135deg, #005dff, #6339ff);
  color: #fff;
  font-size: 0.97rem;
  cursor: pointer;
  font-family: "Source Sans Pro", sans-serif;
  font-weight: 600;
  letter-spacing: 0.02em;
  transition:
    opacity 0.2s,
    transform 0.15s;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  box-shadow: 0 4px 20px rgba(0, 93, 255, 0.3);
}
.submit-btn svg[data-v-66b170c8] {
  width: 16px;
  height: 16px;
}
.submit-btn[data-v-66b170c8]:hover {
  opacity: 0.88;
  transform: translateY(-1px);
}
.submit-btn[data-v-66b170c8]:active {
  transform: translateY(0);
  opacity: 1;
}




