:root{--color-bg: #f8f9fa;--color-surface: #ffffff;--color-border: #d0d0d0;--color-text: #1a1a1a;--color-text-muted: #555555;--color-accent: #c8ff00;--color-input-bg: #ffffff;--color-input-border:#cccccc;--color-error: #cc0000;--color-overlay-bg: rgba(0, 0, 0, .88);--color-card-bg: #ffffff;--color-card-hover: #f0f0f0;--font-family: "Inter", "Helvetica Neue", Arial, sans-serif;--font-size-base: 16px;--font-size-sm: 13px;--font-size-lg: 20px;--font-size-xl: 28px;--font-weight-normal: 400;--font-weight-bold: 600;--line-height: 1.6;--letter-spacing: .01em;--grid-gap: 16px;--card-radius: 6px;--transition-fast: .15s ease;--transition-med: .25s ease;--dynamic-font-size: 16px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden}.hidden{display:none!important}body{background-color:var(--color-bg);color:var(--color-text);font-family:var(--font-family);font-size:var(--font-size-base);line-height:var(--line-height);letter-spacing:var(--letter-spacing);-webkit-font-smoothing:antialiased;overscroll-behavior:none}.desktop-blocker{min-height:100vh;display:flex;align-items:center;justify-content:center;font-family:system-ui,-apple-system,sans-serif;background:#0a0a0a;color:#f5f5f5}.desktop-blocker p{font-size:1.25rem;letter-spacing:.04em;text-align:center;padding:1.5rem}.login-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem;background:var(--color-bg)}.login-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-normal);letter-spacing:.08em;text-transform:uppercase;margin-bottom:2rem;color:var(--color-text)}.login-form{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:280px}.login-input{padding:.75rem 1rem;font-size:var(--font-size-base);font-family:var(--font-family);border:1px solid var(--color-input-border);background:var(--color-input-bg);color:var(--color-text);border-radius:var(--card-radius);outline:none;transition:border-color var(--transition-fast);-webkit-appearance:none}.login-input:focus{border-color:var(--color-text)}.login-btn{padding:.75rem 1rem;font-size:var(--font-size-base);font-family:var(--font-family);font-weight:var(--font-weight-bold);background:var(--color-text);color:var(--color-bg);border:none;border-radius:var(--card-radius);cursor:pointer;letter-spacing:.05em;text-transform:uppercase;transition:opacity var(--transition-fast)}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-error{font-size:var(--font-size-sm);color:var(--color-error);text-align:center;min-height:1.2em}.login-footer{position:fixed;bottom:0;left:0;right:0;display:flex;flex-direction:row;align-items:center;justify-content:center;flex-wrap:nowrap;gap:6px;padding:0 2rem 20px;pointer-events:none}.login-footer-sep{font-size:8px;color:var(--color-text-muted);opacity:.35;pointer-events:none}.login-welcome{font-size:9px;color:var(--color-text-muted);opacity:.5;text-decoration:none;border-bottom:1px solid currentColor;white-space:nowrap;pointer-events:auto}.login-welcome:hover{opacity:1}.login-legal{display:flex;gap:6px;align-items:center;pointer-events:auto}.login-legal a,.login-legal span{font-size:8px;color:var(--color-text-muted);opacity:.35;text-decoration:none;letter-spacing:.05em;text-transform:uppercase;transition:opacity var(--transition-fast)}.login-legal a:hover{opacity:.75}.legal-page{position:fixed;inset:0;overflow-y:auto;background:var(--color-bg)}.legal-inner{max-width:640px;margin:0 auto;padding:48px 28px 80px}.legal-page h1{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin-bottom:32px;letter-spacing:.01em}.legal-page h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);margin-top:40px;margin-bottom:10px}.legal-page h3{font-size:var(--font-size-base);font-weight:var(--font-weight-bold);margin-top:24px;margin-bottom:6px}.legal-page p,.legal-page li{font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.75;margin-bottom:10px}.legal-page ul{padding-left:18px;margin-bottom:10px}.legal-page a{color:var(--color-text-muted);word-break:break-all}.legal-page strong{color:var(--color-text)}.legal-page em{font-style:italic}.legal-page hr{border:none;border-top:1px solid var(--color-border);margin:36px 0}.legal-back{display:inline-block;margin-bottom:36px;font-size:11px;color:var(--color-text-muted);text-decoration:none;letter-spacing:.06em;text-transform:uppercase;opacity:.5;transition:opacity var(--transition-fast)}.legal-back:hover{opacity:1}.portfolio-screen{position:relative;width:100%;height:100%;overflow:hidden;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;padding:20px}.greeting{font-size:var(--dynamic-font-size);font-weight:var(--font-weight-normal);line-height:1.4;letter-spacing:.02em;text-align:justify;-webkit-hyphens:auto;hyphens:auto;width:100%;margin-top:0;padding-top:20px;margin-bottom:0;white-space:pre-line;color:var(--color-text);flex-shrink:0}.grid{display:grid;gap:var(--grid-gap);justify-content:center;align-content:flex-start;flex:1;width:100%;overflow:hidden}.portfolio-item{position:relative;overflow:hidden;background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:var(--card-radius);cursor:pointer;flex-shrink:0;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.portfolio-item:active{opacity:.85}.item-media{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--color-text-muted);background:var(--color-card-bg);overflow:hidden}.item-media img,.item-media video{width:100%;height:100%;object-fit:cover;display:block}.item-overlay{position:absolute;bottom:0;left:0;right:0;padding:4px 6px;background:#ffffffe0;font-size:10px;font-weight:var(--font-weight-bold);color:var(--color-text);overflow-wrap:anywhere;line-height:1.2;letter-spacing:.03em}.chaos-btn{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:10;padding:10px 20px;font-size:var(--font-size-sm);font-family:var(--font-family);background:var(--color-accent);color:#000;border:none;border-radius:999px;cursor:pointer;letter-spacing:.04em;white-space:nowrap;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.chaos-btn:disabled{opacity:.6}.chaos-clone{padding:10px 20px;font-size:var(--font-size-sm);font-family:var(--font-family);background:var(--color-accent);color:#000;border:none;border-radius:999px;cursor:pointer;letter-spacing:.04em;white-space:nowrap;box-sizing:border-box;overflow:hidden;-webkit-tap-highlight-color:transparent}.overlay{position:fixed;inset:0;z-index:300;display:flex;align-items:flex-end;justify-content:center}.overlay.hidden{display:none}.overlay-backdrop{position:absolute;inset:0;background:var(--color-overlay-bg)}.overlay-panel{position:relative;z-index:1;width:100%;max-height:92vh;background:var(--color-surface);border-radius:16px 16px 0 0;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:12px}.overlay-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.overlay-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text);flex:1}.overlay-close{background:none;border:none;font-size:1.25rem;cursor:pointer;color:var(--color-text-muted);padding:4px;flex-shrink:0;line-height:1}.overlay-media{width:100%;display:flex;flex-direction:column;gap:16px}.overlay-asset{width:100%}.overlay-desc{font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.6;white-space:pre-wrap;overflow-wrap:break-word}.black-hole{background:#000;border-radius:50%;box-shadow:inset 30px 10px 40px -10px #333,inset -10px -10px 20px -5px #fff6,0 10px 15px #0000001a}.admin-page{position:fixed;inset:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:24px;background:var(--color-bg);font-family:var(--font-family)}.admin-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--color-border)}.admin-header h1{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);letter-spacing:.05em}.admin-section{margin-bottom:32px}.admin-section h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);margin-bottom:16px;letter-spacing:.03em}.admin-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.admin-table th,.admin-table td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--color-border);vertical-align:top}.admin-table th{font-weight:var(--font-weight-bold);letter-spacing:.04em;text-transform:uppercase;font-size:11px;color:var(--color-text-muted)}.admin-form{display:flex;flex-direction:column;gap:10px;margin-top:16px;padding:16px;border:1px solid var(--color-border);border-radius:var(--card-radius);background:var(--color-surface)}.admin-input,.admin-select,.admin-textarea{width:100%;padding:8px 10px;font-size:var(--font-size-sm);font-family:var(--font-family);border:1px solid var(--color-input-border);background:var(--color-input-bg);color:var(--color-text);border-radius:4px;outline:none}.admin-textarea{min-height:80px;resize:vertical}.admin-btn{padding:8px 16px;font-size:var(--font-size-sm);font-family:var(--font-family);font-weight:var(--font-weight-bold);cursor:pointer;border-radius:4px;border:none;letter-spacing:.03em}.admin-btn.primary{background:var(--color-text);color:var(--color-bg)}.admin-btn.danger{background:var(--color-error);color:#fff}.admin-btn.small{padding:4px 10px;font-size:11px}.admin-btn:disabled{opacity:.5;cursor:not-allowed}.admin-error{color:var(--color-error);font-size:var(--font-size-sm)}.asset-list{display:flex;flex-direction:column;gap:10px}.asset-list-label{font-size:12px;color:var(--color-text-muted)}.asset-card{display:flex;flex-direction:column;gap:8px;padding:10px;border:1px solid var(--color-border);border-radius:4px;background:var(--color-bg)}.asset-card-head{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:var(--font-weight-bold);color:var(--color-text-muted)}.asset-card-actions{display:flex;gap:6px}.admin-login{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow-y:auto;-webkit-overflow-scrolling:touch;gap:12px;padding:24px}.admin-login h1{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);letter-spacing:.05em;margin-bottom:8px}.text-block{white-space:pre-wrap;overflow-wrap:break-word;line-height:1.7;font-size:var(--font-size-base);color:var(--color-text)}.overlay-desc a,.text-block a{color:var(--color-text);text-decoration:underline;text-decoration-color:var(--color-accent);text-decoration-thickness:2px;text-underline-offset:2px;word-break:break-word}.overlay-desc a:hover,.text-block a:hover{background:var(--color-accent)}.cleanup-character{position:fixed;top:15vh;right:10vw;z-index:5;display:flex;flex-direction:column;align-items:center;pointer-events:none;animation:runIn 2.5s ease-out forwards}@keyframes runIn{0%{transform:translate(40vw,-50vh) scale(0);opacity:0}to{transform:translate(0) scale(.6);opacity:1}}.cleanup-character .character-head{position:relative;width:138px;height:138px}.cleanup-character .head-top,.cleanup-character .head-bottom{position:absolute;top:0;left:0;width:138px;height:138px;background-size:contain;background-position:center;background-repeat:no-repeat;box-sizing:border-box}.cleanup-character .head-top{clip-path:inset(0 0 22% 0)}.cleanup-character .head-bottom{clip-path:inset(78% 0 0 0)}.cleanup-character .speech-line{position:absolute;inset:-10px 120% auto auto;transform:none;min-width:60px;max-width:50vw;width:max-content;font-family:var(--font-family, "Inter", "Helvetica Neue", Arial, sans-serif);font-size:16px;line-height:1.35;color:#1a1a1a;text-align:center;white-space:normal}.cleanup-character .speech-line:after{content:"";position:absolute;left:100%;top:50%;margin-left:6px;transform:translateY(-50%);width:18px;height:10px;border-bottom:3px solid #1a1a1a;border-radius:0 0 14px 14px}@keyframes swingForward{0%,to{transform:rotate(-45deg)}50%{transform:rotate(45deg)}}@keyframes swingBackward{0%,to{transform:rotate(45deg)}50%{transform:rotate(-45deg)}}.is-running .left-arm,.is-running .right-leg{animation:swingForward .6s infinite ease-in-out}.is-running .left-leg{animation:swingBackward .6s infinite ease-in-out}@keyframes canadianTalk{0%,to{transform:translateY(0)}50%{transform:translateY(12px)}}.is-talking .head-bottom{animation:canadianTalk .15s infinite}@keyframes angryShake{0%,to{transform:rotate(0)}50%{transform:rotate(-25deg)}}.is-angry .right-arm{animation:angryShake .15s infinite}
