@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial}}}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.isolate{isolation:isolate}.block{display:block}.flex{display:flex}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.flex-shrink{flex-shrink:1}.border-collapse{border-collapse:collapse}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.flex-wrap{flex-wrap:wrap}.border{border-style:var(--tw-border-style);border-width:1px}.italic{font-style:italic}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.delay-100{transition-delay:.1s}.delay-200{transition-delay:.2s}.delay-300{transition-delay:.3s}.delay-400{transition-delay:.4s}.delay-500{transition-delay:.5s}:root{--bg:#fafaf8;--bg-secondary:#f3f2ef;--bg-card:#fff;--bg-card-hover:#f7f6f3;--border:#e4e2dc;--border-hover:#ccc9bf;--border-accent:#d4c4aa;--text-primary:#1a1a18;--text-secondary:#5a5a54;--text-muted:#a0a099;--accent:#9b6f3c;--accent-dim:#c49a6c;--accent-glow:#9b6f3c14;--pipe:#d0cec8;--green:#2d8a4e;--green-dim:#3aad65;--green-bg:#2d8a4e12;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 16px #00000014, 0 2px 6px #0000000a;--shadow-lg:0 12px 40px #0000001a, 0 4px 12px #0000000f}[data-theme=dark]{--bg:#111110;--bg-secondary:#1a1a18;--bg-card:#1e1e1c;--bg-card-hover:#252522;--border:#2e2e2b;--border-hover:#3f3f3a;--border-accent:#5a4530;--text-primary:#f0ede8;--text-secondary:#a8a49c;--text-muted:#5c5c56;--accent:#c49a6c;--accent-dim:#e0b87a;--accent-glow:#c49a6c1a;--pipe:#3a3a36;--green:#3aad65;--green-dim:#4dc97a;--green-bg:#3aad6514;--shadow-sm:0 1px 3px #0000004d, 0 1px 2px #0003;--shadow-md:0 4px 16px #0006, 0 2px 6px #00000040;--shadow-lg:0 12px 40px #00000080, 0 4px 12px #0000004d}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;overflow-x:hidden}body{background-color:var(--bg);color:var(--text-primary);letter-spacing:.01em;-webkit-font-smoothing:antialiased;font-family:DM Sans,sans-serif;font-weight:300;line-height:1.7;transition:background-color .3s,color .3s;overflow-x:hidden}::selection{background:var(--accent);color:#fff}::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border-hover);border-radius:2px}.font-display{font-family:DM Serif Display,serif}.font-mono{font-family:DM Mono,monospace}@keyframes fadeUp{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.85)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes spin-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes theme-spin{0%{opacity:0;transform:rotate(-30deg)scale(.8)}to{opacity:1;transform:rotate(0)scale(1)}}.theme-icon-enter{animation:.25s cubic-bezier(.16,1,.3,1) both theme-spin}.animate-fade-up{animation:.75s cubic-bezier(.16,1,.3,1) both fadeUp}.animate-fade-in{animation:.5s both fadeIn}.animate-slide-in{animation:.6s cubic-bezier(.16,1,.3,1) both slideIn}.animate-blink{animation:1.2s step-end infinite blink}.animate-float{animation:4s ease-in-out infinite float}.animate-slide-up{animation:.4s cubic-bezier(.16,1,.3,1) both slideUp}@media (prefers-reduced-motion:reduce){.animate-fade-up,.animate-fade-in,.animate-slide-in,.animate-blink,.animate-float,.animate-slide-up{opacity:1;animation:none;transform:none}}.delay-50{animation-delay:50ms}.delay-100{animation-delay:.1s}.delay-150{animation-delay:.15s}.delay-200{animation-delay:.2s}.delay-300{animation-delay:.3s}.delay-400{animation-delay:.4s}.delay-500{animation-delay:.5s}.delay-600{animation-delay:.6s}.delay-700{animation-delay:.7s}.delay-800{animation-delay:.8s}.grain:before{content:"";z-index:1000;pointer-events:none;opacity:.15;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");background-repeat:repeat;background-size:120px;position:fixed;inset:0}.hero-glow{pointer-events:none;z-index:0;background:radial-gradient(#9b6f3c0f 0%,#0000 70%);width:min(800px,100vw);height:600px;position:absolute;top:-200px;left:50%;transform:translate(-50%)}.pipe-sep{color:var(--pipe);-webkit-user-select:none;user-select:none}.link-underline{position:relative}.link-underline:after{content:"";background:var(--accent);width:0;height:1px;transition:width .3s;position:absolute;bottom:-2px;left:0}.link-underline:hover:after{width:100%}.card-hover{transition:border-color .25s,background .25s,transform .25s,box-shadow .25s}.card-hover:hover{border-color:var(--border-accent)!important;background:var(--bg-card-hover)!important;box-shadow:var(--shadow-sm)!important}.tag{letter-spacing:.07em;background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-secondary);border-radius:3px;padding:.2rem .65rem;font-family:DM Mono,monospace;font-size:.7rem;transition:border-color .2s,color .2s,background .2s;display:inline-block}.tag:hover{border-color:var(--accent-dim);color:var(--accent);background:var(--accent-glow)}.section-line{align-items:center;gap:1rem;margin-bottom:3rem;display:flex}.section-line:after{content:"";background:var(--border);flex:1;height:1px}@media (max-width:480px){.section-line{margin-bottom:2rem}}.page-container{z-index:0;width:100%;max-width:860px;margin:0 auto;padding:0 1rem;position:relative}@media (min-width:480px){.page-container{padding:0 1.5rem}}@media (min-width:768px){.page-container{padding:0 2.5rem}}@media (min-width:1024px){.page-container{padding:0 2rem}}@media (min-width:1280px){.page-container{max-width:960px;padding:0 2rem}}.badge-live{letter-spacing:.08em;color:var(--green);background:var(--green-bg);border:1px solid #2d8a4e33;border-radius:100px;align-items:center;gap:.35rem;padding:.2rem .65rem;font-family:DM Mono,monospace;font-size:.65rem;display:inline-flex}.badge-live:before{content:"";background:var(--green);border-radius:50%;width:5px;height:5px;animation:2s ease-in-out infinite pulse-dot;display:block}.badge-oss{letter-spacing:.08em;color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border);border-radius:100px;padding:.2rem .65rem;font-family:DM Mono,monospace;font-size:.65rem}.chatbot-bubble{z-index:999;position:fixed;bottom:1.75rem;right:1.75rem}@media (max-width:480px){.chatbot-bubble{bottom:1rem;right:1rem}}.chatbot-trigger{background:var(--accent);cursor:pointer;width:52px;height:52px;box-shadow:0 0 0 1px #9b6f3c33, var(--shadow-lg);color:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;transition:transform .2s,box-shadow .2s;display:flex}.chatbot-trigger:hover{transform:scale(1.08);box-shadow:0 0 0 1px #9b6f3c66,0 12px 40px #0000002e}.chatbot-panel{background:var(--bg-card);border:1px solid var(--border);width:340px;box-shadow:var(--shadow-lg);border-radius:16px;flex-direction:column;display:none;position:absolute;bottom:68px;right:0;overflow:hidden}@media (max-width:480px){.chatbot-panel{width:calc(100vw - 2rem);bottom:64px;right:0}}.chatbot-panel.open{animation:.3s cubic-bezier(.16,1,.3,1) both slideUp;display:flex}.chatbot-header{border-bottom:1px solid var(--border);background:var(--bg-secondary);align-items:center;gap:.75rem;padding:1rem 1.25rem;display:flex}.chatbot-messages{background:var(--bg);flex-direction:column;gap:.75rem;min-height:180px;max-height:260px;padding:1rem 1.25rem;display:flex;overflow-y:auto}@media (max-width:480px){.chatbot-messages{max-height:40vh}}.chatbot-input-row{border-top:1px solid var(--border);background:var(--bg-card);gap:.5rem;padding:.75rem 1rem;display:flex}.chatbot-input{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);resize:none;border-radius:8px;outline:none;flex:1;padding:.5rem .75rem;font-family:DM Sans,sans-serif;font-size:max(.82rem,16px);transition:border-color .2s,box-shadow .2s}.chatbot-input:focus{border-color:var(--accent-dim);box-shadow:0 0 0 3px var(--accent-glow)}.chatbot-send{background:var(--accent);cursor:pointer;color:#fff;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;transition:opacity .2s,transform .15s;display:flex}.chatbot-send:hover{opacity:.85;transform:scale(1.05)}.msg-bot{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);border-radius:12px 12px 12px 4px;align-self:flex-start;max-width:85%;padding:.6rem .85rem;font-size:.82rem;line-height:1.5}.msg-user{background:var(--accent-glow);border:1px solid var(--border-accent);color:var(--accent);border-radius:12px 12px 4px;align-self:flex-end;max-width:85%;padding:.6rem .85rem;font-size:.82rem;line-height:1.5}.social-icon{border:1px solid var(--border);width:36px;height:36px;color:var(--text-muted);border-radius:8px;justify-content:center;align-items:center;min-width:44px;min-height:44px;text-decoration:none;transition:border-color .2s,color .2s,background .2s,transform .15s;display:inline-flex}.social-icon:hover{border-color:var(--border-accent);color:var(--accent);background:var(--accent-glow);transform:translateY(-2px)}.num-circle{background:var(--bg-secondary);border:1px solid var(--border);width:34px;height:34px;color:var(--text-muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-family:DM Mono,monospace;font-size:.62rem;transition:border-color .2s,color .2s;display:flex}.project-icon{background:var(--bg-secondary);border:1px solid var(--border);width:40px;height:40px;color:var(--accent-dim);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;transition:border-color .2s,color .2s,background .2s;display:flex}.row-hover{border-radius:12px;transition:background .2s}.row-hover:hover{background:var(--bg-card-hover)!important}.row-hover:hover .num-circle{border-color:var(--accent-dim);color:var(--accent)}.row-hover:hover .project-icon{border-color:var(--accent-dim);color:var(--accent);background:var(--accent-glow)}.cta-strip{background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1.5rem;margin-top:5rem;padding:2.5rem;display:flex;position:relative;overflow:hidden}.cta-strip:before{content:"";background:linear-gradient(90deg, transparent, var(--accent-dim), transparent);opacity:.5;height:1px;position:absolute;top:0;left:0;right:0}@media (max-width:600px){.cta-strip{flex-direction:column;align-items:flex-start;margin-top:3rem;padding:1.75rem 1.25rem}}.btn-primary{letter-spacing:.08em;color:#fff;background:var(--accent);cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:.5rem;min-height:44px;padding:.75rem 1.75rem;font-family:DM Mono,monospace;font-size:.78rem;text-decoration:none;transition:opacity .2s,transform .15s,box-shadow .2s;display:inline-flex;box-shadow:0 2px 8px #9b6f3c40}.btn-primary:hover{opacity:.88;transform:translateY(-1px);box-shadow:0 4px 16px #9b6f3c59}@media (max-width:480px){.btn-primary{justify-content:center;width:100%}}.btn-outline{letter-spacing:.08em;color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;white-space:nowrap;background:0 0;border-radius:8px;align-items:center;gap:.5rem;min-height:44px;padding:.75rem 1.75rem;font-family:DM Mono,monospace;font-size:.78rem;text-decoration:none;transition:border-color .2s,color .2s,transform .15s,background .2s;display:inline-flex}.btn-outline:hover{border-color:var(--border-hover);color:var(--text-primary);background:var(--bg-secondary);transform:translateY(-1px)}@media (max-width:480px){.btn-outline{justify-content:center;width:100%}}.skill-dot{background:var(--border-hover);border-radius:50%;flex-shrink:0;width:5px;height:5px;transition:background .2s}.skill-item:hover .skill-dot{background:var(--accent)}.skill-item:hover span{color:var(--text-primary)!important}.highlight-link{letter-spacing:.08em;color:var(--text-muted);word-break:break-all;align-items:center;gap:.35rem;font-family:DM Mono,monospace;font-size:.72rem;text-decoration:none;transition:color .2s;display:inline-flex}.highlight-link:hover{color:var(--accent)}@media (max-width:480px){.highlight-link{font-size:.65rem}}.contact-card{background:var(--bg-card);border:1px solid var(--border);cursor:default;border-radius:14px;padding:1.5rem;transition:border-color .25s,box-shadow .25s,transform .25s,background .25s}.contact-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-md);background:var(--bg-card-hover);transform:translateY(-2px)}@media (max-width:480px){.contact-card{padding:1.25rem 1rem}}.contact-input{background:var(--bg-card);border:1px solid var(--border);width:100%;color:var(--text-primary);resize:none;border-radius:10px;outline:none;padding:.85rem 1rem;font-family:DM Sans,sans-serif;font-size:max(.9rem,16px);transition:border-color .2s,box-shadow .2s}.contact-input:focus{border-color:var(--accent-dim);box-shadow:0 0 0 3px var(--accent-glow)}.contact-input::placeholder{color:var(--text-muted)}.contact-label{letter-spacing:.12em;color:var(--text-muted);margin-bottom:.5rem;font-family:DM Mono,monospace;font-size:.68rem;display:block}.theme-toggle{border:1px solid var(--border);width:34px;height:34px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;min-width:44px;min-height:44px;transition:border-color .2s,color .2s,background .2s,transform .15s;display:inline-flex}.theme-toggle:hover{border-color:var(--border-accent);color:var(--accent);background:var(--accent-glow);transform:translateY(-1px)}.hero-layout{text-align:center;flex-direction:column;align-items:center;gap:2rem;display:flex}.hero-text{flex-direction:column;align-items:center;width:100%;display:flex}.hero-cta,.hero-social{justify-content:center}.hero-photo-col{flex-direction:column;align-items:center;gap:1rem;display:flex}.hero-photo-ring{border:1px solid var(--border-hover);background:var(--bg-secondary);width:160px;height:160px;box-shadow:0 0 0 6px var(--bg-secondary), 0 0 0 7px var(--border);border-radius:50%;flex-shrink:0;position:relative;overflow:hidden}.hero-badge{background:var(--bg-card);border:1px solid var(--border-hover);border-radius:10px;align-items:center;gap:.6rem;padding:.65rem 1rem;display:flex}@media (min-width:480px){.hero-photo-ring{width:180px;height:180px}}@media (min-width:768px){.hero-layout{text-align:left;flex-direction:row;justify-content:space-between;align-items:center;gap:2.5rem}.hero-text{flex:1;align-items:flex-start}.hero-cta,.hero-social{justify-content:flex-start}.hero-photo-col{flex-shrink:0;order:2}.hero-text{order:1}.hero-photo-ring{width:170px;height:170px}}@media (min-width:1024px){.hero-layout{gap:3rem}.hero-photo-ring{width:200px;height:200px}}.gallery-grid{grid-template-columns:repeat(3,1fr);gap:1rem;display:grid}@media (max-width:767px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.gallery-grid{grid-template-columns:1fr}}.projects-grid{gap:1.25rem;display:grid}@media (min-width:768px){.projects-grid{grid-template-columns:repeat(2,1fr)}}.skills-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.5rem 1.5rem;display:grid}@media (max-width:480px){.skills-grid{grid-template-columns:repeat(2,1fr)}}.exp-row{align-items:flex-start;gap:1.25rem;display:flex}@media (max-width:480px){.exp-row{gap:.75rem}}.contact-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;display:grid}@media (max-width:600px){.contact-grid{grid-template-columns:1fr}}main section,main>div{z-index:0;position:relative}button svg,a svg{pointer-events:none}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}
