/* =========================================================
   $UFO — Unstable Flying Object
   vibe: minimal meme poster · pale sky / aqua / cosmic violet
   ========================================================= */

:root {
    --bg:           #f1faff;          /* near-white with hint of cyan */
    --bg-2:         #ffffff;
    --paper:        #ffffff;
    --ink:          #0b1f2a;          /* deep teal-ink */
    --ink-soft:     #1d3947;
    --ink-dim:      #5b738a;
    --line:         #c8e3ed;          /* hairline aqua */

    --aqua:         #2e89cc;          /* primary royal blue (matches logo) */
    --aqua-deep:    #1a5fa8;
    --aqua-pop:     #3aa0e8;
    --aqua-soft:    #d6ecfa;
    --aqua-pale:    #e9f4fd;

    --plasma:       #6f5fff;          /* cosmic violet accent */
    --plasma-soft:  #e6e1ff;

    --shadow:       6px 6px 0 var(--ink);
    --shadow-sm:    3px 3px 0 var(--ink);
}

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

html, body { height: 100%; }

body {
    background: var(--bg);
    background-image:
        radial-gradient(circle at 14% 10%,  rgba(46,137,204,.12),  transparent 35%),
        radial-gradient(circle at 86% 22%,  rgba(111, 95,255,.10), transparent 38%),
        radial-gradient(circle at 50% 92%,  rgba(46,137,204,.10),  transparent 45%);
    color: var(--ink);
    font-family: 'Inter', system-ui, -apple-system, "Segoe UI", sans-serif;
    font-size: 17px;
    line-height: 1.55;
    overflow-x: hidden;
    position: relative;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

::selection { background: var(--aqua); color: #fff; }

a { color: inherit; text-decoration: none; }

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

/* =========================================================
   BACKGROUND BLOBS + SPARKS
   ========================================================= */
.bg {
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    overflow: hidden;
}

.blob {
    position: absolute;
    border-radius: 50%;
    filter: blur(70px);
    opacity: .55;
    mix-blend-mode: multiply;
}
.blob.b1 {
    width: 50vmax; height: 50vmax;
    background: radial-gradient(circle, rgba(46,137,204,.45), transparent 60%);
    top: -15vmax; left: -10vmax;
    animation: blobA 26s ease-in-out infinite alternate;
}
.blob.b2 {
    width: 60vmax; height: 60vmax;
    background: radial-gradient(circle, rgba(111, 95,255,.22), transparent 60%);
    bottom: -25vmax; right: -15vmax;
    animation: blobB 32s ease-in-out infinite alternate;
}
.blob.b3 {
    width: 35vmax; height: 35vmax;
    background: radial-gradient(circle, rgba(58,160,232,.30), transparent 60%);
    top: 40%; left: 50%;
    transform: translate(-50%, -50%);
    animation: blobC 22s ease-in-out infinite alternate;
}
@keyframes blobA { to { transform: translate(8vmax, 4vmax) scale(1.15); } }
@keyframes blobB { to { transform: translate(-6vmax, -10vmax) scale(1.1);  } }
@keyframes blobC { to { transform: translate(-50%, -50%) scale(1.2);  } }

.spark {
    position: absolute;
    color: var(--aqua);
    font-family: 'Archivo Black', sans-serif;
    font-size: 22px;
    opacity: .35;
    animation: blink 4.5s ease-in-out infinite;
    user-select: none;
    line-height: 1;
}
.spark.s1 { top:  8%;  left:  6%;  animation-delay: .0s; }
.spark.s2 { top: 14%;  left: 84%;  font-size: 28px; animation-delay: .6s; color: var(--plasma); }
.spark.s3 { top: 32%;  left: 12%;  font-size: 16px; animation-delay: 1.2s; }
.spark.s4 { top: 48%;  left: 92%;  animation-delay: 1.8s; }
.spark.s5 { top: 68%;  left:  4%;  font-size: 30px; animation-delay: 2.4s; color: var(--plasma); }
.spark.s6 { top: 78%;  left: 76%;  font-size: 18px; animation-delay: 3.0s; }
.spark.s7 { top: 90%;  left: 32%;  animation-delay: 3.6s; }
.spark.s8 { top: 22%;  left: 50%;  font-size: 14px; animation-delay: 4.2s; }

@keyframes blink {
    0%, 100% { opacity: .15; transform: scale(.8) rotate(0deg);  }
    50%      { opacity: .55; transform: scale(1.15) rotate(180deg); }
}

/* =========================================================
   SCROLLING TAPE
   ========================================================= */
.tape {
    position: relative;
    z-index: 5;
    background: var(--aqua);
    color: #fff;
    border-block: 3px solid var(--ink);
    overflow: hidden;
    font-family: 'Archivo Black', 'Inter', sans-serif;
    font-size: 1rem;
    letter-spacing: 3px;
    text-transform: uppercase;
}
.tape-top    { border-top: none; transform: rotate(-1deg); margin: -8px -20px 0; padding: 0 20px; }
.tape-bottom { border-bottom: none; transform: rotate(.8deg); margin: 0 -20px -8px; padding: 0 20px; background: var(--ink); color: #fff; }

.tape-track {
    display: flex;
    width: max-content;
    animation: tapeScroll 32s linear infinite;
}
.tape-track.reverse { animation-direction: reverse; animation-duration: 36s; }

.tape-content {
    display: inline-block;
    padding: .55rem 0;
    white-space: nowrap;
}

@keyframes tapeScroll {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}

/* =========================================================
   TOP NAV
   ========================================================= */
.topbar {
    position: relative;
    z-index: 4;
    max-width: 1080px;
    margin: 1.4rem auto 0;
    padding: 0 1.4rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
}

.brand {
    display: inline-flex;
    align-items: center;
    gap: .65rem;
    font-family: 'Archivo Black', sans-serif;
    font-size: 1.2rem;
    letter-spacing: 2px;
    color: var(--ink);
}
.brand-mark {
    width: 36px; height: 36px;
    border-radius: 50%;
    object-fit: cover;
    object-position: center;
    border: 2px solid var(--ink);
    box-shadow: var(--shadow-sm);
    background: var(--aqua-pale);
}

.topnav {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
}
.topnav a {
    padding: .55rem .9rem;
    font-family: 'Inter', sans-serif;
    font-weight: 700;
    font-size: .95rem;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    border: 2px solid transparent;
    border-radius: 999px;
    color: var(--ink-soft);
    transition: color .15s ease, background .15s ease, border-color .15s ease;
}
.topnav a:hover {
    color: var(--ink);
    background: var(--aqua-soft);
    border-color: var(--ink);
}

@media (max-width: 540px) {
    .topbar { flex-direction: column; align-items: flex-start; }
    .topnav { width: 100%; justify-content: flex-end; }
    .topnav a { padding: .4rem .7rem; font-size: .85rem; }
}

/* =========================================================
   PAGE LAYOUT
   ========================================================= */
.page {
    position: relative;
    z-index: 2;
    max-width: 1080px;
    margin: 0 auto;
    padding: 0 1.4rem;
}

/* =========================================================
   HERO
   ========================================================= */
.hero {
    padding: 2.5rem 0 4rem;
    display: grid;
    place-items: center;
}

.hero-inner {
    width: 100%;
    max-width: 760px;
    display: grid;
    gap: 1.4rem;
    text-align: center;
    justify-items: center;
}

/* logo */
.logo-wrap {
    position: relative;
    width: min(100%, 320px);
    margin-bottom: .4rem;
}

.logo {
    width: 100%;
    height: auto;
    filter: drop-shadow(8px 8px 0 rgba(11, 31, 42, .14));
    animation: hover 6s ease-in-out infinite;
    transition: transform .3s ease;
    cursor: grab;
    user-select: none;
    -webkit-user-drag: none;
}
.logo:hover { transform: rotate(-3deg) scale(1.04); }
.logo:active { cursor: grabbing; transform: rotate(2deg) scale(.98); }

/* slow flying-saucer hover */
@keyframes hover {
    0%, 100% { transform: translate(0, 0)        rotate(-2deg); }
    25%      { transform: translate(8px, -8px)   rotate(0deg);  }
    50%      { transform: translate(0, -14px)    rotate(2deg);  }
    75%      { transform: translate(-8px, -8px)  rotate(0deg);  }
}

/* sticker tags around logo */
.float-tag {
    position: absolute;
    font-family: 'Caveat', 'Inter', cursive;
    font-weight: 700;
    font-size: 1.15rem;
    color: var(--ink);
    background: var(--paper);
    padding: .25rem .7rem;
    border: 2px solid var(--ink);
    border-radius: 999px;
    box-shadow: var(--shadow-sm);
    white-space: nowrap;
    animation: floaty 5s ease-in-out infinite;
    pointer-events: none;
    user-select: none;
}
.float-tag.t1 { top:  4%; left: -16%; --r: -10deg; transform: rotate(-10deg); background: var(--aqua-soft); animation-delay: 0s; }
.float-tag.t2 { top: 24%; right: -18%; --r:  9deg; transform: rotate(9deg);                                animation-delay: 1.4s; }
.float-tag.t3 { bottom: 6%; left: -10%; --r: -6deg; transform: rotate(-6deg); background: var(--plasma-soft); color: var(--ink); animation-delay: 2.6s; }

@keyframes floaty {
    0%, 100% { transform: translateY(0)    rotate(var(--r, -8deg)); }
    50%      { transform: translateY(-8px) rotate(var(--r, -8deg)); }
}

@media (max-width: 540px) {
    .float-tag { font-size: .95rem; padding: .2rem .55rem; }
    .float-tag.t1 { left: -6%; }
    .float-tag.t2 { right: -6%; }
    .float-tag.t3 { left: -2%; }
}

/* eyebrow pill */
.eyebrow {
    display: inline-block;
    background: var(--ink);
    color: #fff;
    font-family: 'Archivo Black', sans-serif;
    font-size: .82rem;
    letter-spacing: 3px;
    text-transform: uppercase;
    padding: .4rem .9rem;
    border-radius: 999px;
    transform: rotate(-1.5deg);
    box-shadow: var(--shadow-sm);
}

/* title */
.title {
    font-family: 'Archivo Black', 'Inter', sans-serif;
    line-height: .9;
    color: var(--aqua);
    font-size: clamp(5rem, 18vw, 11rem);
    letter-spacing: -2px;
    -webkit-text-stroke: 4px var(--ink);
    text-shadow:
        7px 7px 0 var(--ink),
        14px 14px 0 var(--aqua-soft);
    transform: rotate(-1.5deg);
    margin: .2rem 0;
    user-select: none;
}
.title-symbol {
    display: inline-block;
    font-size: .85em;
    transform: translateY(-6px) rotate(-6deg);
    margin-right: .05em;
    color: #fff;
    -webkit-text-stroke: 4px var(--ink);
}
.title-main {
    display: inline-block;
}

.subtitle {
    font-family: 'Archivo Black', sans-serif;
    font-size: clamp(1.05rem, 3.4vw, 1.7rem);
    color: var(--ink);
    background: var(--aqua-pale);
    padding: .35rem .9rem;
    border: 2.5px solid var(--ink);
    border-radius: 14px;
    letter-spacing: 2px;
    text-transform: uppercase;
    transform: rotate(.8deg);
    box-shadow: var(--shadow-sm);
    width: max-content;
    max-width: 100%;
}

.tagline {
    font-family: 'Caveat', 'Inter', cursive;
    font-weight: 700;
    font-size: clamp(1.4rem, 3.5vw, 2rem);
    color: var(--aqua-deep);
    transform: rotate(-1deg);
    margin-top: .4rem;
    line-height: 1.15;
}

.lede {
    max-width: 560px;
    color: var(--ink-soft);
    font-size: 1.05rem;
    line-height: 1.6;
    margin-top: .2rem;
}

/* CA card */
.ca-card {
    width: 100%;
    max-width: 620px;
    background: var(--paper);
    border: 3px solid var(--ink);
    border-radius: 18px;
    box-shadow: var(--shadow);
    padding: .35rem;
    margin-top: 1rem;
    transform: rotate(-.4deg);
    transition: transform .2s ease, box-shadow .2s ease;
}
.ca-card:hover {
    transform: rotate(0deg) translateY(-2px);
    box-shadow: 8px 10px 0 var(--ink);
}

.ca-row {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: .6rem;
    background: var(--aqua-pale);
    border-radius: 14px;
    padding: .35rem;
}

.ca-chain {
    background: var(--aqua);
    color: #fff;
    font-family: 'Archivo Black', sans-serif;
    font-size: .8rem;
    letter-spacing: 2px;
    padding: .55rem .8rem;
    border-radius: 10px;
    border: 2px solid var(--ink);
    white-space: nowrap;
}

.ca-address {
    font-family: 'Space Mono', ui-monospace, monospace;
    font-size: .92rem;
    color: var(--ink);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    cursor: copy;
    text-align: left;
    padding: 0 .2rem;
}

.ca-copy {
    position: relative;
    background: var(--ink);
    color: #fff;
    border: 2px solid var(--ink);
    border-radius: 10px;
    padding: .55rem 1.1rem;
    font-family: 'Archivo Black', sans-serif;
    font-size: .88rem;
    letter-spacing: 2px;
    cursor: pointer;
    transition: background .15s ease, transform .1s ease;
    overflow: hidden;
}
.ca-copy .copy-done { display: none; }
.ca-copy.copied { background: var(--aqua); }
.ca-copy.copied .copy-default { display: none; }
.ca-copy.copied .copy-done    { display: inline; }
.ca-copy:hover  { background: var(--aqua-deep); }
.ca-copy:active { transform: scale(.96); }

@media (max-width: 540px) {
    .ca-row { grid-template-columns: 1fr; gap: .4rem; }
    .ca-address { padding: .2rem .4rem; font-size: .82rem; text-align: center; }
    .ca-chain, .ca-copy { justify-self: stretch; text-align: center; }
}

/* CTA */
.cta {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: .8rem;
    margin-top: 1rem;
}

.btn {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .9rem 1.4rem;
    font-family: 'Archivo Black', sans-serif;
    font-size: .95rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    border: 2.5px solid var(--ink);
    border-radius: 14px;
    box-shadow: var(--shadow-sm);
    cursor: pointer;
    transition: transform .12s ease, box-shadow .12s ease, background .15s ease, color .15s ease;
}

.btn-primary {
    background: var(--aqua);
    color: #fff;
}
.btn-primary:hover { background: var(--aqua-deep); }

.btn-ghost {
    background: var(--paper);
    color: var(--ink);
}
.btn-ghost:hover { background: var(--aqua-soft); }

.btn:hover  { transform: translate(-2px, -3px); box-shadow: 6px 8px 0 var(--ink); }
.btn:active { transform: translate(2px, 2px);  box-shadow: 1px 1px 0 var(--ink); }

.btn-arrow { font-size: 1.05rem; transition: transform .2s ease; }
.btn:hover .btn-arrow { transform: translate(2px, -2px); }
.btn-ico   { font-size: 1.05rem; line-height: 1; }

.hero-note {
    margin-top: 1rem;
    color: var(--ink-dim);
    font-size: .95rem;
    letter-spacing: .5px;
}
.hero-note em {
    color: var(--aqua-deep);
    font-style: normal;
    font-weight: 700;
    background: var(--aqua-soft);
    padding: 1px 8px;
    border-radius: 6px;
}

/* =========================================================
   TRANSMISSION (manifesto)
   ========================================================= */
.manifesto {
    padding: 4rem 0 5rem;
    position: relative;
}
.manifesto::before {
    content: "✦ ✦ ✦ ✦ ✦ ✦ ✦ ✦ ✦ ✦ ✦";
    position: absolute;
    top: -2px; left: 50%;
    transform: translateX(-50%);
    font-size: 1rem;
    letter-spacing: 12px;
    color: var(--aqua);
    opacity: .65;
}

.manifesto-inner { display: grid; gap: 2.2rem; }

.kicker {
    font-family: 'Caveat', cursive;
    font-weight: 700;
    text-align: center;
    color: var(--plasma);
    font-size: 1.6rem;
    transform: rotate(-1deg);
    margin-top: .4rem;
}

.section-title {
    font-family: 'Archivo Black', sans-serif;
    font-size: clamp(2rem, 5.5vw, 3.4rem);
    color: var(--aqua);
    -webkit-text-stroke: 3px var(--ink);
    text-shadow: 5px 5px 0 var(--ink);
    text-align: center;
    text-transform: uppercase;
    letter-spacing: 3px;
    transform: rotate(-1deg);
}

.cards {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.4rem;
}
@media (max-width: 820px) { .cards { grid-template-columns: 1fr; } }

.card {
    position: relative;
    background: var(--paper);
    border: 2.5px solid var(--ink);
    border-radius: 18px;
    padding: 2.2rem 1.4rem 1.4rem;
    box-shadow: var(--shadow);
    transition: transform .25s ease, box-shadow .25s ease;
}
.card:nth-child(1) { transform: rotate(-2deg);  background: var(--paper); }
.card:nth-child(2) { transform: rotate(.8deg);  background: var(--aqua-soft); }
.card:nth-child(3) { transform: rotate(-.8deg); background: var(--plasma-soft); }

.card::after {
    content: "";
    position: absolute;
    inset: 6px;
    border: 2px dashed rgba(11, 31, 42, .18);
    border-radius: 14px;
    pointer-events: none;
}
.card:hover {
    transform: rotate(0deg) translateY(-6px);
    box-shadow: 9px 11px 0 var(--ink);
}

.card-num {
    position: absolute;
    top: -20px;
    left: 50%;
    background: var(--ink);
    color: #fff;
    font-family: 'Archivo Black', sans-serif;
    font-size: 1rem;
    line-height: 1;
    padding: .55rem .95rem;
    border: 2.5px solid var(--ink);
    border-radius: 999px;
    letter-spacing: 3px;
    box-shadow: var(--shadow-sm);
    transform: translateX(-50%) rotate(-3deg);
    white-space: nowrap;
}

.card h3 {
    font-family: 'Archivo Black', sans-serif;
    font-size: 1.4rem;
    color: var(--ink);
    margin: .4rem 0 .7rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    text-align: center;
}

.card p {
    color: var(--ink-soft);
    font-size: 1rem;
    line-height: 1.6;
    text-align: center;
}
.card p em {
    color: var(--aqua-deep);
    font-style: normal;
    font-weight: 700;
}
.card:nth-child(3) p em { color: var(--plasma); }

.manifesto-foot {
    text-align: center;
    color: var(--ink);
    font-size: 1.05rem;
    max-width: 640px;
    margin: 0 auto;
    padding: 1.4rem;
    background: var(--paper);
    border: 2.5px solid var(--ink);
    border-radius: 18px;
    box-shadow: var(--shadow);
    line-height: 1.65;
    transform: rotate(.4deg);
}
.chip {
    display: inline-block;
    color: #fff;
    background: var(--plasma);
    padding: .15rem .55rem;
    border: 2px solid var(--ink);
    border-radius: 8px;
    font-family: 'Archivo Black', sans-serif;
    font-size: .85rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    transform: rotate(-2deg);
    animation: wiggle 1.6s ease-in-out infinite;
}
@keyframes wiggle {
    0%, 100% { transform: rotate(-2deg); }
    50%      { transform: rotate(2deg); }
}

/* =========================================================
   FOOTER
   ========================================================= */
.page-foot {
    position: relative;
    z-index: 2;
    max-width: 880px;
    margin: 0 auto;
    padding: 3rem 1.4rem 4rem;
    text-align: center;
}
.copyright {
    color: var(--ink-dim);
    font-size: .82rem;
    font-family: 'Inter', sans-serif;
    letter-spacing: .5px;
}

/* =========================================================
   TOAST
   ========================================================= */
.toast {
    position: fixed;
    left: 50%;
    bottom: 2rem;
    transform: translate(-50%, 30px);
    background: var(--aqua);
    color: #fff;
    padding: .75rem 1.2rem;
    font-family: 'Archivo Black', sans-serif;
    letter-spacing: 2px;
    font-size: .95rem;
    border: 2.5px solid var(--ink);
    border-radius: 12px;
    box-shadow: var(--shadow);
    opacity: 0;
    pointer-events: none;
    transition: opacity .25s ease, transform .25s ease;
    z-index: 9999;
}
.toast.show {
    opacity: 1;
    transform: translate(-50%, 0) rotate(-1.5deg);
}

/* reduced motion */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation: none !important;
        transition: none !important;
    }
}
