.guestbook{--ease-drawer: cubic-bezier(.32, .72, 0, 1);--ease-out-strong: cubic-bezier(.23, 1, .32, 1);display:flex;flex-direction:column;gap:2rem}.guestbook-form{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;border:1px dashed var(--border);border-radius:.5rem;background:var(--card-bg)}.guestbook-form h2{font-family:Shadows Into Light,cursive;font-size:1.75rem;color:var(--text);margin:0;letter-spacing:.02em;text-shadow:0 0 1px rgba(255,255,255,.3)}.guestbook-field{display:flex;flex-direction:column;gap:.25rem;position:relative}.guestbook-label{font-family:var(--font-mono, monospace);font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.guestbook-form input,.guestbook-form textarea{font:inherit;padding:.5rem .75rem;border:1px solid var(--border);border-radius:.25rem;background:var(--bg);color:var(--text);resize:vertical}.guestbook-form input:focus,.guestbook-form textarea:focus{outline:2px solid var(--accent);outline-offset:1px}.guestbook-counter{position:absolute;right:.5rem;bottom:.25rem;font-family:var(--font-mono, monospace);font-size:.625rem;color:var(--text-muted)}.guestbook-turnstile{min-height:65px}.guestbook-error{color:#f87171;font-family:Shadows Into Light,cursive;font-size:1.125rem;margin:0}.guestbook-form button[type=submit]{align-self:flex-start;padding:.5rem 1.25rem;border:1px solid var(--accent);border-radius:.25rem;background:transparent;color:var(--accent);font-family:Shadows Into Light,cursive;font-size:1.125rem;cursor:pointer;transition:transform .14s var(--ease-out-strong),background .16s ease-out}.guestbook-form button[type=submit]:hover:not(:disabled){background:color-mix(in srgb,var(--accent) 12%,transparent)}.guestbook-form button[type=submit]:active:not(:disabled){transform:scale(.97)}.guestbook-form button[type=submit]:disabled{opacity:.4;cursor:not-allowed}.guestbook-board{position:relative;cursor:pointer;width:100%;aspect-ratio:2 / 1;left:50%;transform:translate(-50%);border-radius:.75rem;overflow:hidden;background-color:#1e293b;background-image:radial-gradient(circle at 20% 30%,rgba(255,255,255,.03) 0,transparent 40%),radial-gradient(circle at 80% 70%,rgba(255,255,255,.02) 0,transparent 40%);box-shadow:inset 0 0 60px #0009;transition:width .22s var(--ease-drawer)}.guestbook-board:hover,.guestbook-board.is-expanded{width:max(100%,min(80vw,1280px));transition-duration:.32s}.guestbook-board:focus-visible{outline:2px solid var(--accent);outline-offset:4px}.guestbook-empty{position:absolute;inset:0;display:grid;place-items:center;font-family:Shadows Into Light,cursive;font-size:1.5rem;color:#fff9;text-shadow:0 0 1px rgba(255,255,255,.3)}.guestbook-note{position:absolute;max-width:260px;padding:.5rem .75rem;color:#fffffff2;text-shadow:0 0 1px rgba(255,255,255,.3);touch-action:pan-y;user-select:none;-webkit-user-select:none;animation:guestbook-note-in .25s var(--ease-out-strong) both;animation-delay:calc(min(var(--n, 0),20)*35ms);border-radius:.375rem;transition:background-color .18s ease-out,box-shadow .18s ease-out,padding .18s ease-out}@media(hover:hover)and (pointer:fine){.guestbook-note{cursor:grab}}.guestbook-note.is-dragging{transition:none;cursor:grabbing;z-index:9999!important;box-shadow:0 8px 28px #0000008c,0 0 0 1px #ffffff1a}.guestbook-note.is-snapping-back{transition:transform .32s cubic-bezier(.34,1.56,.64,1),background-color .18s ease-out,box-shadow .22s ease-out;z-index:9999!important}@media(hover:hover)and (pointer:fine){.guestbook-note:hover{background-color:#0f172aeb;box-shadow:0 4px 20px #0000008c,0 0 0 1px #ffffff14;padding:.625rem .875rem;z-index:9999!important}}.guestbook-note-name{font-family:Shadows Into Light,cursive;font-size:1.75rem;margin:0 0 .25rem;padding-bottom:.125rem;border-bottom:1px solid rgba(255,255,255,.4);letter-spacing:.02em}.guestbook-note-message{font-family:Shadows Into Light,cursive;font-size:1rem;color:#ffffffd9;margin:0;line-height:1.4;white-space:pre-wrap;word-break:break-word}@keyframes guestbook-note-in{0%{opacity:0;transform-origin:center;scale:.9}to{opacity:1;scale:1}}.guestbook-list-toggle{position:absolute;top:.75rem;right:.75rem;z-index:9999;display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;border:1px solid rgba(255,255,255,.2);border-radius:.375rem;background:#0f172a99;color:#ffffffd9;cursor:pointer;transition:transform .14s var(--ease-out-strong),background-color .16s ease-out,border-color .16s ease-out,color .16s ease-out}.guestbook-list-toggle:active{transform:scale(.93)}.guestbook-list-toggle:hover{background:#0f172ae6;border-color:#ffffff59;color:#fff}.guestbook-list-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.guestbook-list-panel{position:absolute;top:0;right:0;bottom:0;width:min(360px,90%);max-width:100%;z-index:50;background:#0f172aeb;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-left:1px solid rgba(255,255,255,.12);box-shadow:-8px 0 24px #0006;overflow-y:auto;cursor:default;transform:translate(100%);transition:transform .28s var(--ease-drawer)}.guestbook-list-panel.is-open{transform:translate(0)}.guestbook-list-header{position:sticky;top:0;padding:1rem 1.25rem .75rem;background:#0f172aeb;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid rgba(255,255,255,.08)}.guestbook-list-header h2{margin:0;font-family:var(--font-mono, monospace);font-size:.75rem;font-weight:500;color:#ffffffb3;text-transform:uppercase;letter-spacing:.08em}.guestbook-list{list-style:none;margin:0;padding:.5rem 0}.guestbook-list-item{padding:.875rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.05)}.guestbook-list-item:last-child{border-bottom:none}.guestbook-list-name{font-family:Shadows Into Light,cursive;font-size:1.25rem;color:#fffffff2;line-height:1.1;margin-bottom:.25rem}.guestbook-list-message{margin:0;font-size:.875rem;line-height:1.45;color:#ffffffc7;white-space:pre-wrap;word-break:break-word}.guestbook-list-time{display:block;margin-top:.375rem;font-family:var(--font-mono, monospace);font-size:.625rem;color:#fff6}@media(prefers-reduced-motion:reduce){.guestbook-list-panel,.guestbook-board{transition:none}.guestbook-note{animation:none;animation-delay:0s}}@media(max-width:639px){.guestbook-board,.guestbook-board:hover,.guestbook-board.is-expanded{width:100%;aspect-ratio:auto;left:auto;transform:none;padding:1rem;display:flex;flex-direction:column;gap:1.25rem}.guestbook-note{position:static;max-width:unset;transform:none!important;animation:none}.guestbook-empty{position:static;padding:3rem 0}.guestbook-list-toggle,.guestbook-list-panel{display:none}}
