*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #F5F3EC;--bg2: #E9E5D8;--bg-dark: #10251C;--card: #FFFFFF;--text: #17231C;--muted: #5F6B63;--light: #F5F3EC;--accent: #1F5B3F;--moss: #8A9A5B;--ochre: #C49A5A;--border: #D8D2C2;--font: "Montserrat", system-ui, sans-serif;--toggle-bg: rgba(0,0,0,.07);--toggle-icon: "☾";color-scheme:light}[data-theme=dark]{--bg: #0f1a14;--bg2: #162219;--bg-dark: #070e0a;--card: #162219;--text: #e4e0d4;--muted: #8fa090;--light: #e4e0d4;--accent: #3d9b6d;--moss: #a0b46a;--ochre: #d4aa68;--border: #253d2a;--toggle-bg: rgba(255,255,255,.1);--toggle-icon: "☀";color-scheme:dark}html{scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg);color:var(--text);overflow-x:hidden;transition:background .3s ease,color .3s ease}#theme-toggle{position:absolute;top:1.2rem;right:2rem;z-index:10;width:34px;height:34px;border-radius:50%;border:1px solid var(--border);background:var(--card);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;box-shadow:0 2px 8px #0000001a;transition:background .2s,border-color .2s,transform .15s}#theme-toggle:hover{transform:scale(1.1)}#intro{max-width:1080px;margin:0 auto;padding:3rem 2rem 2.5rem;display:flex;align-items:center;gap:1.5rem;position:relative}.intro-photo-wrap{position:relative;flex-shrink:0}.intro-photo{width:56px;height:56px;border-radius:50%;object-fit:cover;border:2px solid var(--border);transition:border-color .3s}.intro-badge{position:absolute;bottom:-4px;right:-6px;background:var(--accent);color:#fff;font-size:.5rem;font-weight:700;letter-spacing:.05em;padding:.14rem .38rem;border-radius:999px;border:2px solid var(--bg);white-space:nowrap;transition:background .3s,border-color .3s}.intro-text{flex:1;min-width:0}.intro-name{font-size:1.35rem;font-weight:800;letter-spacing:-.025em;color:var(--text);line-height:1}.intro-name em{font-style:normal;color:var(--accent)}.intro-role{font-size:.7rem;font-weight:600;color:var(--muted);margin-top:.2rem;letter-spacing:.03em}.intro-bio{font-size:.78rem;color:var(--text);line-height:1.55;margin-top:.5rem;opacity:.9;white-space:nowrap}.intro-contacts{display:flex;align-items:center;gap:.4rem;margin-top:.4rem;flex-wrap:wrap}.intro-contact-link{font-size:.7rem;font-weight:500;color:var(--muted);text-decoration:underline;text-underline-offset:3px;text-decoration-color:#0003}.intro-contact-link:hover{color:var(--accent)}.intro-contact-sep{font-size:.7rem;color:var(--muted);opacity:.4}.intro-chips{display:flex;flex-direction:column;gap:.3rem;align-items:flex-end;flex-shrink:0}.chip-row{display:flex;flex-wrap:nowrap;gap:.3rem;align-items:center;justify-content:flex-end}.intro-chip{font-size:.62rem;font-weight:600;padding:.22rem .65rem;border-radius:999px;background:var(--card);color:var(--muted);border:1px solid var(--border);transition:background .3s,border-color .3s,color .3s}.etsy-chip{background:#f2642112;color:#c05a1a;border-color:#f2642133}[data-theme=dark] .etsy-chip{background:#f264211f;color:#e07840}.vibe-chip{background:#1f5b3f12;color:var(--accent);border-color:#1f5b3f38}.intro-divider{max-width:1080px;margin:0 auto;border:none;border-top:1px solid var(--border)}#projects{padding:2.5rem 2rem 5rem}.projects-wrap{max-width:1080px;margin:0 auto}.projects-layout{display:grid;grid-template-columns:340px 1fr;gap:1.25rem;align-items:start}.project-list-wrap{overflow:hidden;border-radius:16px;background:var(--card);border:1px solid var(--border);box-shadow:0 2px 12px #10251c0d;display:flex;flex-direction:column;transition:background .3s,border-color .3s}.project-list{flex:1;display:flex;flex-direction:column;overflow:hidden}.project-list{scrollbar-width:none}.project-list::-webkit-scrollbar{display:none}.project-card{padding:0 1.25rem;cursor:pointer;border-bottom:1px solid var(--border);border-left:3px solid transparent;transition:height .32s cubic-bezier(.4,0,.2,1),border-color .18s,background .18s;position:relative;overflow:hidden;flex-shrink:0;display:flex;align-items:center}.project-card:last-child{border-bottom:none}.project-card:hover:not(.active){background:var(--bg)}.card-header{display:flex;align-items:center;gap:.6rem;width:100%}.project-card.active .card-header{padding-bottom:0}.card-num{font-size:.56rem;font-weight:700;letter-spacing:.1em;color:var(--muted);flex-shrink:0;min-width:1.4rem}.card-title{font-size:.82rem;font-weight:700;color:var(--text);line-height:1.2;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-card.active .card-title{white-space:normal;overflow:visible;text-overflow:unset}.card-detail{overflow:hidden;opacity:0;transform:translateY(-4px);transition:opacity .22s ease .18s,transform .22s ease .18s;pointer-events:none}.project-card.active{background:var(--bg-dark);border-left-color:var(--moss);flex-direction:column;align-items:flex-start;padding:.9rem 1.25rem 1.1rem}.project-card.active .card-num{color:var(--moss)}.project-card.active .card-title{color:var(--light)}.project-card.active .card-detail{opacity:1;transform:translateY(0);pointer-events:auto}.card-desc{font-size:.7rem;color:#f5f3ec8c;line-height:1.65;margin-top:.55rem;padding-top:.55rem;border-top:1px solid rgba(255,255,255,.08)}.card-pain-list{margin-top:.5rem;display:flex;flex-direction:column;gap:.35rem}.card-pain-item{display:flex;align-items:flex-start;gap:.42rem;font-size:.67rem;color:#f5f3ecbf;line-height:1.5;font-weight:500}.card-pain-check{flex-shrink:0;margin-top:.1rem;width:13px;height:13px;border-radius:3px;background:#8a9a5b33;border:1px solid rgba(138,154,91,.35);display:flex;align-items:center;justify-content:center;font-size:.48rem;color:var(--moss)}.card-tech-row{display:flex;flex-wrap:wrap;gap:.28rem;margin-top:.55rem}.card-visit-mobile,.card-browser-mobile{display:none}.card-tech-pill{display:inline-block;font-size:.58rem;font-weight:700;padding:.18rem .55rem;border-radius:999px;background:#ffffff14;color:#f5f3eccc;border:1px solid rgba(255,255,255,.12)}.browser-wrap{border-radius:18px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 2px 24px #10251c17;border:1px solid var(--border);min-height:300px;transition:border-color .3s;position:sticky;top:1rem}.browser-chrome{display:flex;align-items:center;gap:.65rem;padding:0 .85rem;height:36px;flex-shrink:0;background:#eeecea;border-bottom:1px solid var(--border);transition:background .3s,border-color .3s}[data-theme=dark] .browser-chrome{background:#1a2a1f}.tlights{display:flex;gap:4px}.tl{width:10px;height:10px;border-radius:50%;border:1px solid rgba(0,0,0,.07)}.tl-r{background:#ff5f57}.tl-y{background:#febc2e}.tl-g{background:#28c840}.url-bar{flex:1;height:22px;background:#e1ded8;border-radius:5px;display:flex;align-items:center;gap:.3rem;padding:0 .55rem;min-width:0;border:1px solid #D0CCC5;transition:background .3s}[data-theme=dark] .url-bar{background:#0f1a14;border-color:var(--border)}.url-lock{font-size:.6rem;color:#9a9a9a;flex-shrink:0}.url-text{font-size:.65rem;color:#555;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:var(--font)}[data-theme=dark] .url-text{color:var(--muted)}.url-host{font-weight:600;color:#333}[data-theme=dark] .url-host{color:var(--text)}.visit-btn{flex-shrink:0;font-size:.62rem;font-weight:700;padding:.22rem .58rem;border-radius:4px;background:var(--accent);color:#fff;text-decoration:none;transition:background .15s}.visit-btn:hover{background:#174d33}.browser-content{overflow:hidden;position:relative;background:#fff;cursor:ns-resize;transition:background .3s;height:500px}[data-theme=dark] .browser-content{background:#0f1a14}.loading-bar{position:absolute;top:0;left:0;height:2px;background:var(--accent);width:0;opacity:0;transition:opacity .2s;z-index:5}#project-screenshot{width:100%;display:none;position:absolute;top:0;left:0;transform:translateY(0);will-change:transform}.screenshot-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;background:var(--bg)}.ph-ring{width:40px;height:40px;border-radius:50%;border:2px dashed var(--border)}.ph-text{font-size:.7rem;color:var(--muted);font-weight:500}.pull-indicator{position:absolute;left:0;right:0;z-index:10;display:flex;align-items:flex-end;justify-content:center;gap:.5rem;padding:1.2rem 1rem .65rem;color:#fff;font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;opacity:0;pointer-events:none;transition:opacity .15s}.pull-indicator.pull-next{bottom:0;background:linear-gradient(to top,rgba(16,37,28,.85) 0%,transparent 100%)}.pull-indicator.pull-prev{top:0;align-items:flex-start;padding:.65rem 1rem 1.2rem;background:linear-gradient(to bottom,rgba(16,37,28,.85) 0%,transparent 100%)}.pull-progress{position:absolute;bottom:0;left:0;height:2px;background:linear-gradient(to right,var(--moss),var(--accent))}.pull-indicator.pull-prev .pull-progress{bottom:auto;top:0}#contact{background:var(--bg-dark);padding:4.5rem 2rem 4rem;transition:background .3s}.contact-inner{max-width:600px;margin:0 auto;text-align:center}.clbl{font-size:.62rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--moss);margin-bottom:.6rem}.ctitle{font-size:clamp(2rem,5vw,3rem);font-weight:800;letter-spacing:-.03em;color:var(--light);line-height:1.1;margin-bottom:.9rem}.ctitle em{font-style:italic;color:var(--ochre)}.csub{color:#f5f3ec61;font-size:.85rem;line-height:1.7;margin-bottom:2rem}.cwrite{display:inline-block;font-size:clamp(1.8rem,4vw,2.6rem);font-weight:800;letter-spacing:-.025em;color:var(--light);text-decoration:underline;text-underline-offset:6px;text-decoration-color:#f5f3ec33;text-decoration-thickness:2px;margin-bottom:1.5rem;transition:color .18s,text-decoration-color .18s}.cwrite:hover{color:var(--ochre);text-decoration-color:#d4a35980}.cwrite em{font-style:normal;font-size:.7em;opacity:.6}.avbadge{display:inline-flex;align-items:center;gap:.38rem;padding:.32rem .8rem;border-radius:999px;background:#8a9a5b1f;border:1px solid rgba(138,154,91,.25);color:var(--moss);font-size:.6rem;font-weight:700;letter-spacing:.07em}.avdot{width:5px;height:5px;border-radius:50%;background:#86efac;animation:pdot 2s ease-in-out infinite}@keyframes pdot{0%,to{box-shadow:0 0 #86efac80}50%{box-shadow:0 0 0 4px #86efac00}}footer{background:var(--bg-dark);padding:1.1rem 2rem;display:flex;align-items:center;justify-content:center;border-top:1px solid rgba(255,255,255,.07)}.fbrand{font-weight:600;color:#f5f3ec59;font-size:.68rem;letter-spacing:.02em;text-align:center}.fbrand em{font-style:italic;color:var(--accent);font-weight:700}@media (max-width: 768px){#theme-toggle{top:.75rem;right:1rem;width:30px;height:30px;font-size:.85rem}#intro{flex-wrap:wrap;padding:2.75rem 1.1rem 1rem;gap:.75rem;align-items:flex-start}.intro-text{min-width:0;flex:1 1 calc(100% - 68px)}.intro-bio{white-space:normal;font-size:.73rem}.intro-name{font-size:1.05rem}.intro-role{font-size:.65rem}.intro-photo{width:48px;height:48px}.intro-chips{width:100%;flex-direction:column;align-items:flex-start;gap:.25rem}.chip-row{flex-wrap:nowrap;gap:.18rem}.intro-chip{font-size:.52rem;padding:.13rem .38rem}.intro-contact-link{font-size:.65rem}.intro-divider{margin:.5rem 1.1rem 0}#projects{padding:0 0 2.5rem}.projects-wrap{max-width:100%;margin:0;padding:0}.projects-layout{display:flex;flex-direction:column;gap:0}.browser-wrap{display:flex;order:1;border-radius:0;border-left:none;border-right:none;border-top:1px solid var(--border);box-shadow:none;height:auto!important;min-height:unset;position:static}.browser-chrome{height:32px;padding:0 .8rem}.tl{width:8px;height:8px}.url-text{font-size:.58rem}.visit-btn{font-size:.58rem;padding:.18rem .45rem}.browser-wrap{display:none!important}.card-browser-mobile{display:flex;flex-direction:column;width:calc(100% + 2rem);margin:0 -1rem .85rem;border-radius:8px;overflow:hidden;border:1px solid rgba(255,255,255,.07)}.card-browser-chrome{display:flex;align-items:center;gap:.5rem;padding:0 .7rem;height:28px;background:#ffffff0f;border-bottom:1px solid rgba(255,255,255,.07);flex-shrink:0;backdrop-filter:blur(4px)}.card-browser-chrome .tlights{display:flex;gap:3px}.card-browser-chrome .tl{width:8px;height:8px}.card-browser-chrome .url-bar{flex:1;height:18px;background:#0000004d;border-radius:4px;display:flex;align-items:center;gap:.25rem;padding:0 .4rem;min-width:0;border:1px solid rgba(255,255,255,.08)}.cbm-url{font-size:.55rem;color:#f5f3ec99;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-browser-chrome .url-lock{font-size:.5rem;color:#fff6;flex-shrink:0}.card-browser-chrome .visit-btn{font-size:.55rem;padding:.15rem .4rem;flex-shrink:0}.card-browser-content{overflow:hidden;max-height:52vw;background:#fff}.card-screenshot-mobile-img{width:100%;display:block;object-fit:cover;object-position:top center}.project-list-wrap{order:2;border-radius:0;border:none;border-top:1px solid var(--border);box-shadow:none;margin:0}.project-card.active{padding:.75rem 1rem 1rem;align-items:flex-start}.card-title{font-size:.76rem}.card-num{font-size:.52rem;min-width:1.1rem}.card-desc{font-size:.7rem}.card-pain-item{font-size:.65rem}.card-tech-pill{font-size:.54rem}.card-visit-mobile{display:inline-flex;align-items:center;gap:.3rem;margin-top:.75rem;font-size:.68rem;font-weight:700;padding:.4rem .9rem;border-radius:6px;background:var(--accent);color:#fff;text-decoration:none}#contact{padding:2.5rem 1.1rem}.ctitle{font-size:clamp(1.5rem,7.5vw,2.2rem)}.csub{font-size:.78rem}.cwrite{font-size:clamp(1.15rem,5.5vw,1.7rem)}footer{flex-direction:column;text-align:center;padding:.9rem 1.1rem}}
