@font-face {
    font-family: 'Onest';
    font-style: normal;
    font-weight: 100 900;
    font-display: swap;
    src: url('/fonts/onest-latin.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
    font-family: 'Onest';
    font-style: normal;
    font-weight: 100 900;
    font-display: swap;
    src: url('/fonts/onest-latin-ext.woff2') format('woff2');
    unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

:root { --w: #fff; --b: #000; --tr: 0.4s cubic-bezier(0.25, 1, 0.5, 1); --st-c: rgba(255, 255, 255, 0.2); }
::-webkit-scrollbar { width: 0; }
html, body, *, a, button, input, svg, .l-c, .i-w, #v-s, #ent { cursor: none !important; user-select: none !important; -webkit-user-drag: none !important; }

.ic { width: 1em; height: 1em; display: inline-block; vertical-align: -0.125em; flex-shrink: 0; }
* { box-sizing: border-box; margin: 0; padding: 0; outline: none !important; }
*:focus-visible { outline: 1px solid rgba(255, 255, 255, 0.6) !important; outline-offset: 3px; border-radius: 2px; }
body { background: var(--b); color: var(--w); font-family: 'Onest', sans-serif; height: 100vh; width: 100vw; display: flex; justify-content: center; align-items: center; overflow: hidden; position: fixed; animation: ogk-page-in 0.45s ease both; }
body.ogk-leaving { opacity: 0; transition: opacity 0.28s ease; pointer-events: none; animation: none; }
@keyframes ogk-page-in { from { opacity: 0; } to { opacity: 1; } }
@media (prefers-reduced-motion: reduce) { body { animation: none; } body.ogk-leaving { transition: none; opacity: 1; } }
#cursor { position: fixed; pointer-events: none; z-index: 99999; transform: translate(-50%, -50%); transition: opacity 0.3s; }
#cursor img { width: 28px; height: 28px; image-rendering: pixelated; image-rendering: crisp-edges; display: block; filter: drop-shadow(0 0 1px rgba(0,0,0,0.5)); }
.footer-text { position: fixed; bottom: 20px; left: 0; right: 0; text-align: center; font-size: 13px; font-weight: 400; color: rgba(255, 255, 255, 0.35); z-index: 1; pointer-events: none; letter-spacing: 1px; white-space: nowrap; opacity: 0; transition: opacity 2s; }
#ent { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: var(--b); z-index: 999; display: flex; justify-content: center; align-items: center; transition: opacity 1.2s, visibility 1.2s; }
.p-txt { font-size: 36px; letter-spacing: 5px; text-transform: uppercase; opacity: 0.67; filter: drop-shadow(0 0 8px rgba(255,255,255,0.6)) drop-shadow(0 0 18px rgba(255,255,255,0.25)); animation: glow-pulse 2s ease-in-out infinite; }
.p-img { width: min(380px, 80vw); height: auto; display: block; pointer-events: none; user-select: none; -webkit-user-drag: none; }
@keyframes glow-pulse { 0%,100% { filter: drop-shadow(0 0 6px rgba(255,255,255,0.5)) drop-shadow(0 0 14px rgba(255,255,255,0.2)); } 50% { filter: drop-shadow(0 0 16px rgba(255,255,255,0.9)) drop-shadow(0 0 30px rgba(255,255,255,0.4)); } }
@media (max-width: 768px) { .p-img { width: min(320px, 86vw); } }
@media (prefers-reduced-motion: reduce) { .p-img, .p-txt { animation: none; } }
#main { opacity: 0; transform: scale(1.06); filter: blur(40px); transition: opacity 2.4s, filter 2.4s, transform 3s cubic-bezier(0.16, 1, 0.3, 1); display: flex; justify-content: center; align-items: center; width: 100%; height: 100%; }
#main.active { opacity: 1; transform: scale(1); filter: blur(0); }
.v-ctrl { position: fixed; top: 25px; left: 25px; display: flex; align-items: center; z-index: 1000; opacity: 0; transition: opacity 0.3s; }
.v-ctrl:hover { opacity: 1 !important; }
.i-w { width: 20px; display: flex; justify-content: center; align-items: center; }
.i-w .ic { width: 18px; height: 18px; color: var(--w); }
#v-s { -webkit-appearance: none; width: 70px; height: 2px; background: rgba(255,255,255,0.2); margin-left: 8px; }
#v-s::-webkit-slider-thumb { -webkit-appearance: none; width: 10px; height: 10px; background: var(--w); border-radius: 50%; }
@media (max-width: 1024px) { #v-s { display: none; } }
.cnt, .card { width: 100%; display: flex; flex-direction: column; align-items: center; }
.card { max-width: 500px; padding: 20px; z-index: 2; position: relative; text-align: center; }
.n-cnt { position: relative; display: inline-block; padding: 10px 20px; }
#p-cv { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 0; pointer-events: none; opacity: 0; transition: 2s ease; }
#p-cv.active { opacity: 1; }
.title { font-size: clamp(32px, 5vw, 48px); font-weight: 700; position: relative; z-index: 1; background: linear-gradient(120deg, #fff 0%, #aaa 30%, #fff 50%, #ccc 70%, #fff 100%); background-size: 250% auto; -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; animation: shimmer 3s linear infinite; }
@keyframes shimmer { 0% { background-position: 0% center; } 100% { background-position: 250% center; } }
@keyframes breathe { 0%, 100% { box-shadow: 0 0 15px var(--st-c); border-color: var(--st-c); } 50% { box-shadow: 0 0 30px var(--st-c); border-color: var(--st-c); } }
.av-cnt { position: relative; display: inline-block; margin-bottom: 15px; padding: 5px; }
#d-av { width: 110px; height: 110px; border-radius: 50%; border: 2px solid var(--st-c); object-fit: cover; transition: border-color 0.8s ease; animation: breathe 3s infinite ease-in-out; }
#d-st { position: absolute; bottom: 12px; right: 12px; width: 20px; height: 20px; border-radius: 50%; border: 3px solid var(--b); transition: background 0.5s ease; }
.quote { font-size: 18px; margin: 10px 0; min-height: 24px; color: var(--w); }
.loc { font-size: 14px; color: var(--w); margin: 15px 0 10px 0; display: flex; align-items: center; gap: 8px; justify-content: center; transition: 0.3s; }
.loc .ic { width: 14px; height: 14px; }
.loc a { color: inherit; text-decoration: none; transition: 0.3s; }
.loc:hover { filter: drop-shadow(0 0 5px rgba(255, 255, 255, 0.6)); }
.visit-cnt { font-size: 12px; color: rgba(255,255,255,0.3); display: flex; align-items: center; gap: 6px; justify-content: center; margin: 4px 0 14px 0; transition: 0.3s; }
.visit-cnt .ic { width: 12px; height: 12px; }
.visit-cnt:hover { color: rgba(255,255,255,0.6); }
.links { display: flex; justify-content: center; gap: 30px; margin: 20px 0; position: relative; }
.l-c { color: var(--w); font-size: 32px; transition: var(--tr); text-decoration: none; position: relative; display: inline-flex; justify-content: center; align-items: center; }
.l-c .ic { width: 32px; height: 32px; transition: transform 0.4s cubic-bezier(0.25, 1, 0.5, 1), filter 0.3s; }
.l-c:hover .ic { transform: translateY(-6px) scale(1.08); filter: drop-shadow(0 0 8px rgba(255, 255, 255, 0.5)); }
.l-c::after { content: attr(data-tip); position: absolute; bottom: -32px; left: 50%; transform: translateX(-50%) translateY(5px); background: #0f0f0f; color: #fff; padding: 3px 8px; font-size: 10px; border-radius: 4px; opacity: 0; visibility: hidden; transition: 0.2s; white-space: nowrap; border: 1px solid rgba(255,255,255,0.1); z-index: 10; }
.l-c:hover::after { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
#cp-n { position: absolute; top: -45px; left: 50%; transform: translateX(-50%) translateY(10px); background: #5865F2; color: #fff; padding: 5px 12px; border-radius: 6px; font-size: 12px; font-weight: bold; opacity: 0; transition: 0.3s; pointer-events: none; z-index: 100; }
#cp-n.active { opacity: 1; transform: translateX(-50%) translateY(0); }
#sp-w { height: 95px; display: flex; align-items: center; justify-content: center; margin-top: 10px; width: 100%; transition: 0.5s; }
#sp-g { display: flex; align-items: center; gap: 12px; background: rgba(255,255,255,0.05); backdrop-filter: blur(12px); padding: 12px 18px; border-radius: 12px; border: 1px solid rgba(255,255,255,0.1); max-width: 380px; width: fit-content; min-width: 220px; overflow: hidden; transition: transform 0.3s, border-color 0.3s, background 0.3s; }
#sp-g.clickable { cursor: none !important; }
#sp-g.clickable:hover { border-color: rgba(29,185,84,0.45); background: rgba(29,185,84,0.06); transform: translateY(-2px); }
#sp-a { width: 48px; height: 48px; border-radius: 6px; flex-shrink: 0; object-fit: cover; }
.sp-i { display: flex; flex-direction: column; align-items: flex-start; text-align: left; overflow: hidden; width: 100%; }
#sp-t { font-weight: 700; font-size: 14px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 240px; }
#sp-ar { color: #1DB954 !important; font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 240px; }
#sp-p-cnt { width: 100%; margin-top: 6px; display: flex; align-items: center; gap: 8px; }
#sp-p-bar { height: 3px; background: rgba(255,255,255,0.1); border-radius: 2px; flex-grow: 1; position: relative; overflow: hidden; }
#sp-p-bar::after { content: ''; position: absolute; left: 0; top: 0; height: 100%; background: #1DB954; width: var(--p, 0%); transition: 0.5s linear; }
#sp-p-time { font-size: 10px; color: rgba(255,255,255,0.4); font-family: monospace; white-space: nowrap; }
#cl-e { position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%) scale(0); font-size: 120px; z-index: 10000; pointer-events: none; transition: transform 0.5s cubic-bezier(0.17, 0.89, 0.32, 1.49), opacity 0.3s; opacity: 0; }
#cl-e.show { transform: translate(-50%, -50%) scale(1); opacity: 1; }
@media (max-width: 768px) { .footer-text { font-size: 11px; letter-spacing: 0.5px; } .card { max-width: 90%; } }

@media (max-width: 600px) {
    #sp-w { height: 70px; margin-top: 6px; }
    #sp-g { padding: 8px 12px; gap: 8px; min-width: 0; max-width: 92vw; border-radius: 10px; }
    #sp-a { width: 36px; height: 36px; border-radius: 4px; }
    #sp-t { font-size: 12px; max-width: 56vw; }
    #sp-ar { font-size: 10px; max-width: 56vw; }
    #sp-p-bar { height: 2px; }
    #sp-p-time { font-size: 9px; }
}
@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; }
    #p-cv { display: none; }
}
