:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.landing-hero{width:100%;max-width:600px;height:auto;display:block;margin:2rem auto 1rem;border-radius:12px;box-shadow:0 4px 24px #00000014}@media (max-width: 600px){.landing-hero{max-width:90vw;margin:1rem auto;border-radius:8px}}body{background-color:#222}.gallery-modal-download{display:inline-block;margin-top:18px;padding:8px 18px;background:#333;color:#fff;border-radius:6px;text-decoration:none;font-weight:700;font-size:1.1rem;transition:background .2s,color .2s}.gallery-modal-download:hover{background:#222;color:#fafafa}.gallery-tabs{display:flex;gap:12px;margin-bottom:18px;justify-content:center;width:100%}.gallery-photo{width:100%;height:auto;object-fit:contain;border-radius:6px;box-shadow:0 2px 8px #00000014;background:#fafafa;display:block;cursor:pointer}.gallery-pagination{display:flex;justify-content:center;align-items:center;margin:20px 0 32px;gap:10px;flex-wrap:wrap}.gallery-page-btn{font-weight:400;background:#f5f5f5;color:#333;border:1px solid #bbb;border-radius:6px;padding:8px 14px;margin:0 2px;font-size:1.1rem;cursor:pointer;transition:all .2s;min-width:36px;box-shadow:none}.gallery-page-btn.active{font-weight:700;background:#333;color:#fff;border:2px solid #333;box-shadow:0 2px 8px #5050501f}.gallery-page-btn:disabled{opacity:.5;cursor:not-allowed}.gallery-ellipsis{padding:0 6px;color:#888;font-size:1.1rem}.gallery-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000}.gallery-modal{position:relative;background:#fff;padding:20px;border-radius:8px;max-width:90vw;max-height:90vh;box-shadow:0 2px 20px #00000080;display:flex;flex-direction:column;align-items:center;justify-content:center}.gallery-modal-close{position:absolute;top:10px;right:10px;font-size:2rem;background:none;border:none;cursor:pointer;color:#333;z-index:1001}.photos{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.photos img{width:100%;height:auto;object-fit:contain;border-radius:6px;box-shadow:0 2px 8px #00000014;background:#fafafa;display:block}@media (max-width: 600px){.gallery{padding-bottom:60px}.photos{grid-template-columns:1fr;gap:12px}.photos img{width:100%;height:auto;object-fit:contain}.gallery-pagination{flex-wrap:nowrap;gap:2px;font-size:.95rem;margin:12px 0 32px;overflow-x:auto}.gallery-page-btn{font-size:.95rem;padding:6px 8px;min-width:28px;margin:0 1px;border-radius:6px}.gallery-ellipsis{display:none}}.gallery-modal-img{max-width:80vw;max-height:80vh;border-radius:4px}body,.gallery{background-color:#222}.about-contact{max-width:500px;margin:2rem auto;padding:2rem 1.5rem;background:#f6f6f4;border-radius:12px;box-shadow:0 4px 24px #0000000f}.about-contact h2{margin-top:1.5rem;margin-bottom:.5rem;font-size:1.5rem;color:#2a2a2a}.about-contact p{margin-bottom:1.5rem;color:#444;line-height:1.6}.about-contact form{display:flex;flex-direction:column;gap:1rem}.about-contact label{display:flex;flex-direction:column;font-weight:500;color:#333}.about-contact input,.about-contact textarea{margin-top:.3rem;padding:.5rem .7rem;border:1px solid #d2d2d2;border-radius:6px;font-size:1rem;font-family:inherit;background:#f9f9f7}.about-contact textarea{min-height:90px;resize:vertical}.about-contact button[type=submit]{background:#e0e0dd;color:#222;border:none;border-radius:6px;padding:.7rem 1.2rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s,color .2s;box-shadow:0 1px 4px #0000000a}.about-contact button[type=submit]:hover:enabled{background:#cacac7;color:#111}.form-message{margin-top:.5rem;color:#5a5a5a;font-weight:500}.about-user-photo{display:block;width:170px;height:170px;object-fit:cover;border-radius:50%;margin:0 auto 1.5rem;box-shadow:0 2px 12px #0000001a;border:3px solid #e0e0dd}@media (max-width: 600px){.about-contact{padding:1rem .5rem;border-radius:8px}.about-contact h2{font-size:1.2rem}}.navbar{width:100%;background:#222;color:#fff;box-shadow:0 2px 8px #00000014;position:sticky;top:0;z-index:100}.navbar-container{display:flex;justify-content:center;align-items:center;gap:2rem;padding:1rem .5rem}.navbar-link{color:#fff;text-decoration:none;font-size:1.1rem;padding:.5rem 1.2rem;border-radius:6px;transition:background .2s,color .2s}.navbar-link:hover,.navbar-link.active{background:#fff;color:#222}@media (max-width: 600px){.navbar-container{gap:.5rem;padding:.7rem .2rem}.navbar-link{font-size:1rem;padding:.4rem .7rem}}
