@font-face {
    font-family: "Meowa Cat Paw";
    src: url("/meowa-cat-paw.woff") format("woff");
    font-style: normal;
    font-weight: 400;
    font-display: swap;
}

:root {
    --meowa-deep: #210338;
    --meowa-deeper: #12001f;
    --meowa-royal: #5e1195;
    --meowa-violet: #a238ff;
    --meowa-pink: #ff72f8;
    --meowa-hot: #ff4fd8;
    --meowa-lilac: #f4d7ff;
    --meowa-white: #fff8ff;
    --meowa-text: #fff4ff;
    --meowa-muted: #e8b8ff;
    --meowa-line: rgba(255, 203, 255, 0.24);
    --meowa-glow: 0 0 28px rgba(255, 79, 216, 0.42), 0 0 70px rgba(162, 56, 255, 0.32);
}

* {
    box-sizing: border-box;
}

html {
    min-width: 320px;
    background: var(--meowa-deeper);
}

body {
    min-height: 100vh;
    margin: 0;
    color: var(--meowa-text);
    font-family: "Meowa Cat Paw", ui-rounded, "Comic Sans MS", "Segoe UI", Arial, sans-serif;
    font-size: 18px;
    line-height: 1.35;
    background:
        radial-gradient(circle at 50% 2%, rgba(255, 114, 248, 0.36) 0 90px, transparent 230px),
        radial-gradient(circle at 84% 16%, rgba(162, 56, 255, 0.34) 0 110px, transparent 310px),
        radial-gradient(circle at 10% 82%, rgba(255, 79, 216, 0.22) 0 90px, transparent 270px),
        linear-gradient(145deg, #310552 0%, #170025 45%, #33084d 100%);
    overflow-x: hidden;
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -1;
    opacity: 0.34;
    background-image:
        radial-gradient(circle, rgba(255, 216, 255, 0.32) 0 2px, transparent 3px),
        radial-gradient(circle, rgba(255, 114, 248, 0.22) 0 1px, transparent 3px);
    background-position: 0 0, 42px 54px;
    background-size: 112px 112px, 84px 84px;
}

a {
    color: inherit;
}

.meowa-topbar {
    position: sticky;
    top: 0;
    z-index: 20;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    min-height: 76px;
    padding: 14px clamp(18px, 5vw, 56px);
    background: rgba(28, 0, 46, 0.72);
    border-bottom: 1px solid var(--meowa-line);
    backdrop-filter: blur(18px);
}

.meowa-logo {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
    font-size: 22px;
    font-weight: 900;
}

.meowa-logo-mark {
    display: inline-grid;
    place-items: center;
    width: 44px;
    height: 44px;
    color: var(--meowa-white);
    background: linear-gradient(145deg, #3d075d, #14001f);
    border: 2px solid var(--meowa-pink);
    border-radius: 16px;
    font-size: 24px;
    line-height: 1;
    box-shadow: 0 0 0 4px rgba(255, 114, 248, 0.14), 0 0 24px rgba(255, 79, 216, 0.46);
}

.meowa-nav {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    flex-wrap: wrap;
}

.meowa-nav a,
.meowa-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 22px;
    border: 1px solid var(--meowa-line);
    border-radius: 999px;
    text-decoration: none;
    font-size: 17px;
    font-weight: 850;
    transition: transform 160ms ease, border-color 160ms ease, background 160ms ease, box-shadow 160ms ease;
}

.meowa-nav a {
    background: rgba(255, 248, 255, 0.08);
}

.meowa-nav a:hover,
.meowa-button:hover {
    transform: translateY(-2px);
    border-color: rgba(255, 216, 255, 0.58);
    box-shadow: 0 0 24px rgba(255, 79, 216, 0.26);
}

.meowa-main {
    width: min(1180px, calc(100% - 36px));
    margin: 0 auto;
}

.meowa-hero {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(360px, 1.05fr);
    align-items: center;
    gap: clamp(28px, 5vw, 72px);
    min-height: calc(100svh - 180px);
    padding: clamp(38px, 7vw, 82px) 0 62px;
}

.meowa-copy {
    position: relative;
    z-index: 2;
}

.meowa-kicker {
    margin: 0 0 16px;
    color: #ffd8ff;
    font-size: 18px;
    font-weight: 900;
    letter-spacing: 0;
    text-shadow: 0 0 18px rgba(255, 114, 248, 0.74);
}

.meowa-copy h1 {
    margin: 0;
    color: var(--meowa-white);
    font-family: Inter, "Arial Black", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
    font-size: 82px;
    line-height: 0.9;
    text-shadow: 0 0 18px rgba(255, 114, 248, 0.54), 0 0 44px rgba(162, 56, 255, 0.42);
}

.meowa-copy h1 span,
.meowa-wordmark span {
    position: relative;
    display: inline-block;
    color: inherit;
}

.meowa-o-paw {
    position: absolute;
    left: 50%;
    top: 53%;
    display: block;
    width: 0.5em;
    height: 0.45em;
    transform: translate(-50%, -50%);
    color: #7b1fb7;
    filter: drop-shadow(0 0 0.08em rgba(255, 255, 255, 0.68));
    z-index: 1;
}

.meowa-o-paw ellipse,
.meowa-o-paw path {
    fill: currentColor;
}

.meowa-o-paw .meowa-o-paw-shine {
    fill: #c477ff;
    opacity: 0.56;
}

.meowa-tagline {
    max-width: 500px;
    margin: 22px 0 0;
    color: var(--meowa-muted);
    font-size: 26px;
    line-height: 1.42;
}

.meowa-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 32px;
}

.meowa-button-primary {
    color: #2d0648;
    background: linear-gradient(135deg, #fff8ff, #ffb9fb);
    border-color: rgba(255, 255, 255, 0.72);
    box-shadow: 0 0 26px rgba(255, 114, 248, 0.44), 0 16px 44px rgba(0, 0, 0, 0.22);
}

.meowa-button-secondary {
    color: var(--meowa-white);
    background: rgba(255, 248, 255, 0.08);
}

.meowa-badge {
    position: relative;
    display: grid;
    place-items: center;
    width: min(520px, 100%);
    aspect-ratio: 1;
    margin: 0 auto;
    border: 2px solid rgba(255, 216, 255, 0.7);
    border-radius: 50%;
    background:
        radial-gradient(circle at 50% 42%, rgba(255, 114, 248, 0.2), transparent 32%),
        radial-gradient(circle at 50% 56%, rgba(76, 2, 113, 0.92), rgba(44, 0, 75, 0.96) 58%, rgba(28, 0, 46, 0.98));
    box-shadow:
        inset 0 0 44px rgba(255, 114, 248, 0.34),
        inset 0 0 110px rgba(162, 56, 255, 0.26),
        0 0 0 10px rgba(255, 114, 248, 0.09),
        var(--meowa-glow);
}

.meowa-badge::before,
.meowa-badge::after {
    content: "";
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
}

.meowa-badge::before {
    inset: 18px;
    border: 1px solid rgba(255, 216, 255, 0.24);
    box-shadow: inset 0 0 42px rgba(255, 114, 248, 0.16);
}

.meowa-badge::after {
    inset: -16px;
    border: 5px solid rgba(196, 77, 255, 0.36);
    filter: drop-shadow(0 0 22px rgba(255, 79, 216, 0.62));
}

.meowa-orbit {
    position: absolute;
    inset: 58px;
    border: 1px dashed rgba(255, 216, 255, 0.25);
    border-radius: 50%;
}

.meowa-paw {
    position: absolute;
    width: 26px;
    height: 22px;
    opacity: 0.22;
    transform: rotate(-16deg);
}

.meowa-paw::before {
    content: "";
    display: block;
    width: 30px;
    height: 28px;
    background:
        radial-gradient(circle at 20% 24%, #ffd8ff 0 4px, transparent 5px),
        radial-gradient(circle at 50% 12%, #ffd8ff 0 5px, transparent 6px),
        radial-gradient(circle at 80% 24%, #ffd8ff 0 4px, transparent 5px),
        radial-gradient(ellipse at 50% 74%, #ffd8ff 0 10px, transparent 11px);
}

.meowa-paw-one {
    top: 92px;
    left: 82px;
}

.meowa-paw-two {
    right: 72px;
    bottom: 136px;
    transform: rotate(18deg);
}

.meowa-sparkle {
    position: absolute;
    width: 54px;
    height: 54px;
    filter: drop-shadow(0 0 14px rgba(255, 79, 216, 0.9));
}

.meowa-sparkle::before,
.meowa-sparkle::after {
    content: "";
    position: absolute;
    inset: 23px 0;
    height: 8px;
    border-radius: 999px;
    background: #ff86ff;
}

.meowa-sparkle::after {
    transform: rotate(90deg);
}

.meowa-sparkle-one {
    top: 42px;
    left: 50%;
    transform: translateX(-50%) rotate(45deg);
}

.meowa-sparkle-two {
    right: 76px;
    top: 118px;
    width: 30px;
    height: 30px;
    transform: rotate(45deg);
    opacity: 0.72;
}

.meowa-sparkle-two::before,
.meowa-sparkle-two::after {
    inset: 12px 0;
    height: 5px;
}

.meowa-cat {
    position: relative;
    width: 320px;
    max-width: 70%;
    height: auto;
    margin-top: -68px;
    overflow: visible;
    filter: drop-shadow(0 20px 38px rgba(18, 0, 31, 0.32)) drop-shadow(0 0 18px rgba(255, 114, 248, 0.22));
    z-index: 1;
}

.meowa-cat-ear-outer,
.meowa-cat-head {
    fill: url("#meowa-cat-fur");
    stroke: #3f176d;
    stroke-width: 9px;
    stroke-linejoin: round;
    stroke-linecap: round;
}

.meowa-cat-ear-inner {
    fill: url("#meowa-cat-ear");
    opacity: 0.86;
    stroke: #7b2ab6;
    stroke-width: 5px;
    stroke-linejoin: round;
}

.meowa-cat-head {
    filter: drop-shadow(0 0 0.4rem rgba(255, 216, 255, 0.3));
}

.meowa-cat-blush {
    fill: #db74ff;
    opacity: 0.28;
}

.meowa-cat-circuit {
    fill: none;
    stroke: #b94af2;
    stroke-width: 4px;
    stroke-linecap: round;
    stroke-linejoin: round;
    opacity: 0.62;
}

.meowa-cat-circuit circle {
    fill: #ffd4ff;
    stroke: #b94af2;
}

.meowa-cat-headset-shadow {
    fill: none;
    stroke: #3f176d;
    stroke-width: 18px;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.meowa-cat-headset-main {
    fill: none;
    stroke: url("#meowa-cat-headset");
    stroke-width: 13px;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.meowa-cat-headset-gloss {
    fill: none;
    stroke: rgba(255, 248, 255, 0.58);
    stroke-width: 4px;
    stroke-linecap: round;
    opacity: 0.74;
}

.meowa-cat-earcup ellipse:first-child {
    fill: url("#meowa-cat-earcup");
    stroke: #3f176d;
    stroke-width: 7px;
}

.meowa-cat-earcup-glow {
    fill: rgba(255, 131, 249, 0.44);
}

.meowa-cat-earcup-shine {
    fill: rgba(255, 255, 255, 0.62);
}

.meowa-cat-eye-group ellipse:first-child {
    fill: url("#meowa-cat-eye");
    stroke: #26103d;
    stroke-width: 6px;
}

.meowa-cat-eye-group path {
    fill: #ab3bdf;
    opacity: 0.74;
}

.meowa-cat-eye-group circle {
    fill: #ffffff;
}

.meowa-cat-mark {
    fill: #9b68c9;
    opacity: 0.56;
}

.meowa-cat-nose {
    fill: #ff9fcf;
    stroke: #3f176d;
    stroke-width: 4px;
    stroke-linejoin: round;
}

.meowa-cat-mouth {
    fill: none;
    stroke: #3f176d;
    stroke-width: 4px;
    stroke-linecap: round;
}

.meowa-cat-tongue {
    display: none;
}

.meowa-cat-whiskers {
    fill: none;
    stroke: #a93bd6;
    stroke-width: 6px;
    stroke-linecap: round;
    filter: drop-shadow(0 0 7px rgba(255, 114, 248, 0.38));
}

.meowa-wordmark {
    position: absolute;
    bottom: 58px;
    display: inline-flex;
    align-items: center;
    color: var(--meowa-white);
    font-family: Inter, "Arial Black", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
    font-size: 58px;
    font-weight: 1000;
    line-height: 1;
    text-shadow:
        -3px -3px 0 #d988ff,
        3px -3px 0 #d988ff,
        -3px 3px 0 #d988ff,
        3px 3px 0 #d988ff,
        0 0 20px rgba(255, 114, 248, 0.75);
}

.meowa-status-band {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1px;
    margin: -18px 0 54px;
    overflow: hidden;
    border: 1px solid var(--meowa-line);
    border-radius: 26px;
    background: var(--meowa-line);
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.28), 0 0 42px rgba(255, 79, 216, 0.18);
}

.meowa-status-item {
    position: relative;
    display: grid;
    gap: 7px;
    min-height: 108px;
    padding: 24px;
    background: rgba(36, 0, 61, 0.78);
}

.meowa-status-label {
    color: #ffadfb;
    font-size: 17px;
    font-weight: 900;
}

.meowa-status-item strong {
    color: var(--meowa-white);
    font-size: 28px;
}

.meowa-status-dot {
    position: absolute;
    top: 26px;
    right: 24px;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: #ffd44c;
    box-shadow: 0 0 0 6px rgba(255, 212, 76, 0.17), 0 0 20px rgba(255, 212, 76, 0.6);
}

.meowa-status-dot.is-online {
    background: #73ffc9;
    box-shadow: 0 0 0 6px rgba(115, 255, 201, 0.18), 0 0 20px rgba(115, 255, 201, 0.72);
}

.meowa-status-dot.is-offline {
    background: #ff5e9f;
    box-shadow: 0 0 0 6px rgba(255, 94, 159, 0.2), 0 0 20px rgba(255, 94, 159, 0.72);
}

@media (max-width: 920px) {
    .meowa-hero {
        grid-template-columns: 1fr;
        min-height: auto;
        padding-top: 44px;
    }

    .meowa-copy {
        text-align: center;
    }

    .meowa-tagline {
        margin-right: auto;
        margin-left: auto;
    }

    .meowa-actions {
        justify-content: center;
    }

    .meowa-badge {
        width: min(500px, 100%);
    }

    .meowa-status-band {
        margin-top: 0;
    }
}

@media (max-width: 640px) {
    .meowa-topbar {
        align-items: flex-start;
        flex-direction: column;
        min-height: 130px;
    }

    .meowa-nav,
    .meowa-actions {
        width: 100%;
    }

    .meowa-nav a,
    .meowa-button {
        flex: 1 1 130px;
    }

    .meowa-copy h1 {
        font-size: 52px;
    }

    .meowa-tagline {
        font-size: 22px;
    }

    .meowa-badge {
        width: min(280px, 100%);
    }

    .meowa-cat {
        width: 202px;
        max-width: 76%;
        margin-top: -32px;
    }

    .meowa-wordmark {
        bottom: 36px;
        font-size: 31px;
    }

    .meowa-sparkle-one {
        top: 24px;
    }

    .meowa-status-band {
        grid-template-columns: 1fr;
    }
}
