:root{--bg:#F1F5F9;--surface:#FFFFFF;--ink:#0F172A;--ink-muted:#475569;--border:#CBD5E1;--overlay:#CBD5E188;--tag-bg:#E0F2FE;--tag-ink:#0369A1;--accent:#38BDF8;--font-sans:"Outfit",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif,"Noto Color Emoji";--font-serif:"Fraunces",Georgia,"Times New Roman",serif,"Noto Color Emoji";--font-mono:"Courier Prime",'Courier New',Courier,monospace,"Noto Color Emoji"}*,*::before,*::after{box-sizing:border-box;-webkit-user-select:none;-moz-user-select:none;user-select:none}html,body{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px}body{background:var(--bg);color:var(--ink);font-family:var(--font-sans);font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;display:flex;flex-direction:column}a{color:inherit;text-decoration:none}img{display:block;max-width:100%;height:auto}ul{list-style:none;margin:0px 0px 0px 0px;padding:0px 0px 0px 0px}.site-header{border-bottom:1px solid var(--border);background:#FFFFFF;position:sticky;top:0;z-index:10}.header-inner{display:flex;align-items:center;justify-content:space-between;padding:20px 32px 20px 32px}.wordmark{display:inline-flex;align-items:center;gap:10px;color:var(--ink);font-size:18px;font-family:var(--font-mono);font-weight:400;line-height:1;transition:all 0.2s ease}.wordmark::after{content:"_";margin:0px 0px 2px -9px;animation:blinkCursor 1s step-end infinite}@keyframes blinkCursor{50%{opacity:0}}.wordmark-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;color:var(--ink);transition:all 0.2s ease}.wordmark-icon svg{width:100%;height:100%;stroke-width:2}.site-nav{display:flex;gap:28px;align-items:center}.nav-link{font-size:14px;font-weight:500;color:var(--ink-muted);padding:6px 2px 6px 2px;border-bottom:1px solid transparent;transition:all 0.2s ease}.nav-link:hover{color:var(--accent)}.nav-link.flag-active{color:var(--ink);border-bottom-color:var(--ink)}.site-main{flex:1;padding:56px 32px 96px 32px}.intro{display:flex;flex-direction:column;align-items:center;margin:0px 0px 48px 0px}.intro-title{font-family:var(--font-serif);font-weight:600;font-size:clamp(40px,6vw,56px);line-height:normal;margin:0px 0px 0px 0px}.intro-title::after{content:"";display:block;width:72px;height:4px;margin:32px auto 0px auto;background:var(--accent);border-radius:2px}.intro-contact{display:inline-flex;align-items:center;gap:10px;height:40px;margin:28px 0px 0px 0px;padding:0px 20px 0px 20px;background:var(--surface);border:1px solid var(--border);border-radius:999px;box-shadow:0px 0px 6px -1px var(--border);transition:all 0.2s ease}.intro-contact:hover{border-color:var(--accent);box-shadow:0px 0px 6px -1px var(--accent);color:var(--accent)}.intro-contact-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px}.intro-contact-icon svg{width:100%;height:100%;stroke-width:2}.intro-contact-text{padding:2px 0px 0px 0px;color:var(--ink);font-family:var(--font-mono);font-size:15px;font-weight:500;line-height:1}.apps{display:flex;flex-direction:column;gap:32px;align-items:center}.app-card{position:relative;display:flex;flex-direction:row;gap:32px;align-items:center;width:100%;max-width:1000px;padding:32px 32px 32px 32px;background:var(--surface);border:1px solid var(--border);border-radius:32px;box-shadow:0px 0px 6px -1px var(--border);transition:all 0.2s ease}.app-card.flag-under-development{overflow:hidden}.app-card:not(.flag-under-development):hover{border:1px solid var(--accent);box-shadow:0px 0px 6px -1px var(--accent)}.app-card:not(.flag-under-development):hover .app-link{border-bottom-color:var(--accent)}.app-thumbnail{position:relative;align-self:stretch;width:240px;box-shadow:0px 0px 5px 0px var(--border);border-radius:16px;overflow:hidden;transition:all 0.2s ease}.app-thumbnail img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.app-body{display:flex;flex-direction:column;gap:12px;flex:1;min-width:0}.app-title{margin:0px 0px 0px 0px;font-family:var(--font-serif);font-weight:600;font-size:24px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2;transition:all 0.2s ease}.app-description{display:-webkit-box;-webkit-box-orient:vertical;margin:0px 0px 0px 0px;color:var(--ink-muted);font-size:15px;line-height:1.6;-webkit-line-clamp:2;line-clamp:2;-webkit-hyphens:auto;hyphens:auto;overflow:hidden}.app-tags{display:flex;flex-wrap:nowrap;gap:8px;margin:4px 0px 0px 0px;overflow-x:auto;scrollbar-width:none}.app-tags::-webkit-scrollbar{display:none}.app-tags li{flex-shrink:0;padding:5px 8px 3px 8px;background:var(--tag-bg);border-radius:3px;color:var(--tag-ink);font-family:var(--font-mono);font-size:11.5px;font-weight:500;letter-spacing:0.5px;text-transform:uppercase;white-space:nowrap}.app-link{align-self:flex-start;margin-top:6px;border-bottom:1px solid transparent;color:var(--accent);font-size:15px;font-weight:500;font-family:var(--font-mono);transition:all 0.2s ease}.app-link::after{content:"";position:absolute;inset:0;z-index:1}.under-development-container{position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:flex-end;background:var(--overlay);backdrop-filter:blur(1.5px);-webkit-backdrop-filter:blur(1.5px);z-index:2;pointer-events:auto}.under-development-label{padding:10px 18px 10px 18px;background:#374151;border-radius:16px 0px 0px 0px;color:#FFFFFF;font-family:var(--font-sans);font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase}.site-footer{background:#374151}.site-footer::before{position:absolute;display:block;content:"";height:20px;width:100%;margin:-14px auto -0px auto;background-color:transparent;background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 13"><polyline fill="%23374151" stroke="%23374151" stroke-linecap="square" stroke-linejoin="square" stroke-width="2" points="40.0 11.5 30.0 1.5 20.0 11.5 10.0 1.5 0.0 11.5"/></svg>');background-position:top left;background-size:20px 20px;background-repeat:repeat-x}.footer-inner{display:flex;align-items:center;justify-content:center;gap:16px;padding:24px 32px 24px 32px;text-align:center}.footer-message{margin:0px 0px 0px 0px;color:#FFFFFF;text-wrap:balance;letter-spacing:0.5px}@media (max-width:640px){.site-main{padding:40px 20px 64px 20px}.intro{margin-bottom:32px}.intro-title{font-size:34px}.header-inner{padding:28px 20px 28px 20px}.app-card{flex-direction:column;align-items:stretch;gap:18px;padding:24px 28px 28px 28px}.app-thumbnail{width:100%;aspect-ratio:16 / 9;order:1}.app-title{font-size:20px}.app-description{-webkit-line-clamp:3;line-clamp:3}.footer-inner{gap:12px;padding:24px 20px 24px 20px}}