*,:after,:before{box-sizing:border-box;margin:0;padding:0;word-wrap:break-word}:root{--bg:#f4f6f9;--bg-secondary:#e8ecf2;--bg-card:#f5f5f5;--text:#0c121d;--text-muted:#526070;--text-faint:#9aaabb;--accent:#10b981;--accent-dark:#10b981;--acent:#34d399;--accent-alt:#475569;--border:rgba(71,85,105,.1);--border-strong:rgba(71,85,105,.18);--hero-grad-1:#7ec9c1;--hero-grad-2:#e2eaf6;--tag-bg:#e2eaf6;--tag-text:#2e3f56;--nav-bg:rgba(244,246,249,.9);--shadow-sm:0 1px 3px rgba(15,22,35,.07),0 1px 2px rgba(15,22,35,.04);--shadow-md:0 4px 16px rgba(15,22,35,.09),0 2px 6px rgba(15,22,35,.05);--shadow-lg:0 12px 40px rgba(15,22,35,.12),0 4px 12px rgba(15,22,35,.07);--chat-bot-bg:#e2eaf6;--chat-user-bg:#10b981;--blk-img-filter:grayscale(1)}[data-theme=dark]{--bg:#0a0f1a;--bg-secondary:#101826;--bg-card:#151e2e;--text:#e8eef6;--text-muted:#7a909f;--text-faint:#3a4a58;--accent:#166448;--accent-dark:#10b981;--accent-alt:#13273e;--border:hsla(0,0%,100%,.07);--border-strong:hsla(0,0%,100%,.13);--hero-grad-1:#1e4844;--hero-grad-2:#0d1829;--tag-bg:#1a2538;--tag-text:#a0b4c8;--nav-bg:rgba(10,15,26,.9);--shadow-sm:0 1px 3px rgba(0,0,0,.35),0 1px 2px rgba(0,0,0,.25);--shadow-md:0 4px 16px rgba(0,0,0,.45),0 2px 6px rgba(0,0,0,.3);--shadow-lg:0 12px 40px rgba(0,0,0,.55),0 4px 12px rgba(0,0,0,.4);--chat-bot-bg:#1a2538;--chat-user-bg:#059669;--blk-img-filter:invert(1)}html{font-size:62.5%;scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:DM Sans,sans-serif;font-size:1.6rem;overflow-x:hidden;transition:background .3s ease,color .3s ease}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--text-faint);border-radius:4px}header{backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);background:var(--nav-bg);border-bottom:1px solid var(--border);height:64px;justify-content:end;padding:0 max(2rem,calc(50vw - 600px));position:sticky;top:0;transition:background .3s ease;z-index:9999}header,nav{align-items:center;display:flex}nav{gap:4px}nav ul{align-items:center;display:flex;gap:2px;list-style:none}nav ul li a{border-radius:8px;color:var(--text-muted);display:block;font-size:1.4rem;font-weight:500;padding:8px 16px;text-decoration:none;transition:all .2s ease}nav ul li a:hover:not(.btn){background:var(--border);color:var(--text)}.btn{align-items:center;border:none;border-radius:10px;cursor:pointer;display:inline-flex;font-family:DM Sans,sans-serif;font-size:1.4rem;font-weight:400;gap:8px;padding:9px 20px;text-decoration:none;transition:all .2s ease}.btn-primary{background:var(--accent);color:#f5f5f5;justify-content:center}.btn-primary:hover{box-shadow:0 6px 20px rgba(16,185,129,.4);color:#f5f5f5;filter:brightness(1.1);text-decoration:none;transform:translateY(-1px)}.btn-ghost{background:transparent;border:1px solid var(--border-strong);color:var(--text)}.btn-ghost:hover{background:var(--bg-secondary);color:var(--text);text-decoration:none;transform:translateY(-1px)}.btn-bg{background:var(--bg-card);color:var(--text)}.btn-bg:hover{color:var(--text);opacity:.85;text-decoration:none;transform:translateY(-1px)}.theme-toggle{align-items:center;background:var(--bg-card);border:1px solid var(--border-strong);border-radius:8px;color:var(--text);cursor:pointer;display:flex;font-size:1.6rem;height:36px;justify-content:center;margin-left:8px;transition:all .2s ease;width:36px}.theme-toggle:hover{background:var(--bg-secondary)}.icon-moon{display:block}.icon-sun,[data-theme=dark] .icon-moon{display:none}[data-theme=dark] .icon-sun{display:block}.mobile-toggle{align-items:center;background:var(--bg-card);border:1px solid var(--border-strong);border-radius:8px;color:var(--text);cursor:pointer;display:none;height:36px;justify-content:center;margin-left:6px;width:36px}@media (max-width:768px){.mobile-toggle{display:flex}header{padding:0 2rem}nav ul{backdrop-filter:blur(16px);background:var(--nav-bg);border-bottom:1px solid var(--border);display:none;flex-direction:column;gap:4px;left:0;padding:12px;position:absolute;right:0;top:64px}nav ul.active{display:flex}nav ul li{width:100%}nav ul li a{text-align:center;width:100%}nav{position:static}}.container{margin:0 auto;max-width:1200px;padding:0 2.4rem}#hero{align-items:center;display:grid;gap:40px;grid-template-columns:1fr 1fr;min-height:calc(100vh - 64px);padding:80px 0 60px}@media (max-width:900px){#hero{grid-template-columns:1fr;min-height:auto;padding:48px 0 40px}.hero-visual{order:-1}}.fadein{animation:fadeInUp .7s ease both}.hero-content{display:flex;flex-direction:column;gap:24px}h1{color:var(--text);font-family:Syne,sans-serif;font-size:clamp(3.8rem,6vw,6rem);font-weight:800;letter-spacing:-.02em;line-height:1.05}.hero-role{color:var(--text-muted);font-size:2rem;font-weight:400;min-height:3rem}.hero-role strong{color:var(--accent-dark);font-weight:600}.hero-desc{color:var(--text-muted);font-size:1.65rem;line-height:1.65;max-width:480px}.hero-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.social-links{display:flex;gap:10px}.social-link{align-items:center;background:var(--bg-card);border:1px solid var(--border-strong);border-radius:10px;color:var(--text-muted);display:flex;height:40px;justify-content:center;text-decoration:none;transition:all .2s ease;width:40px}.social-link:hover{border-color:var(--accent);box-shadow:var(--shadow-sm);color:var(--accent);text-decoration:none;transform:translateY(-2px)}.social-link img{filter:var(--blk-img-filter,grayscale(1));height:20px;object-fit:contain;opacity:.6;transition:all .2s ease;width:20px}.social-link:hover img{filter:var(--blk-img-filter,grayscale(0));opacity:1}.hero-card,.hero-visual{position:relative}.hero-card{align-items:center;background:linear-gradient(135deg,var(--hero-grad-1),var(--hero-grad-2));border:1px solid var(--border);border-radius:28px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:20px;overflow:hidden;padding:36px}.hero-card:before{background:radial-gradient(circle,rgba(16,185,129,.15) 0,transparent 70%);height:300px;right:-30%;top:-50%;width:300px}.hero-card:after,.hero-card:before{content:"";pointer-events:none;position:absolute}.hero-card:after{background:radial-gradient(circle,rgba(71,85,105,.1) 0,transparent 70%);bottom:-30%;height:280px;left:-20%;width:280px}.hero-avatar{align-items:center;background:var(--bg-card);border:3px solid var(--bg-card);border-radius:50%;box-shadow:var(--shadow-md);color:#f5f5f5;display:flex;font-family:Syne,sans-serif;font-size:4.8rem;font-weight:800;height:130px;justify-content:center;overflow:hidden;width:130px}.hero-avatar img{height:100%;object-fit:cover;width:100%}.hero-card-name{color:var(--text);font-family:Syne,sans-serif;font-size:2rem;font-weight:700;text-align:center}.logos-strip{background:var(--bg-secondary);border-bottom:1px solid var(--border);border-top:1px solid var(--border);overflow:hidden;padding:24px 0;position:relative}.logos-strip:after,.logos-strip:before{bottom:0;content:"";pointer-events:none;position:absolute;top:0;width:120px;z-index:2}.logos-strip:before{background:linear-gradient(to right,var(--bg-secondary),transparent);left:0}.logos-strip:after{background:linear-gradient(to left,var(--bg-secondary),transparent);right:0}.marquee{animation:marquee 35s linear infinite;display:flex;gap:0;will-change:transform}.marquee-track{align-items:center;display:flex;flex-shrink:0;gap:36px;padding-right:36px}.marquee-track img{height:36px;max-width:80px;object-fit:contain;transition:all .2s ease;width:auto}@keyframes marquee{0%{transform:translateX(0)}to{transform:translateX(-175%)}}.section-title{margin-bottom:56px;text-align:center}.section-overline{color:var(--accent-dark);display:inline-block;font-size:1.2rem;font-weight:700;letter-spacing:.14em;margin-bottom:10px;text-transform:uppercase}.section-title h2{color:var(--text);font-family:Syne,sans-serif;font-size:clamp(2.8rem,4vw,4rem);font-weight:800;letter-spacing:-.02em;line-height:1.1}.section-title p{color:var(--text-muted);font-size:1.65rem;line-height:1.6;margin-left:auto;margin-right:auto;margin-top:12px;max-width:500px}#about{padding:100px 0}.about-grid{align-items:normal;display:grid;gap:32px;grid-template-columns:1fr 1fr}@media (max-width:900px){.about-grid{grid-template-columns:1fr}}.skills-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow-sm);height:100%;padding:28px}.skills-group{margin-bottom:24px}.skills-group:last-child{margin-bottom:0}.skills-group-label{color:var(--text-faint);font-family:Syne,sans-serif;font-size:1.2rem;font-weight:700;letter-spacing:.1em;margin-bottom:12px;text-transform:uppercase}.skill-tags{display:flex;flex-wrap:wrap;gap:8px}.skill-tag{background:var(--tag-bg);border-radius:8px;color:var(--tag-text);cursor:default;font-size:1.3rem;font-weight:500;padding:6px 14px;transition:all .2s ease}.skill-tag:hover{background:var(--accent-alt);color:#f5f5f5;transform:translateY(-1px)}.about-text-panel{display:flex;flex-direction:column;gap:20px}.about-highlight-card{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow-sm);height:100%;padding:28px}.about-highlight-card h3{color:var(--text);font-family:Syne,sans-serif;font-size:1.9rem;font-weight:700;margin-bottom:14px}.about-highlight-card p{color:var(--text-muted);font-size:1.55rem;line-height:1.7;margin-bottom:12px;text-align:left}.about-highlight-card p:last-child{margin-bottom:0}.work-experience{border-bottom:1px solid var(--border)}.bento-section,.work-experience{background:var(--bg-secondary);border-top:1px solid var(--border);padding:100px 0}.card-grid{display:grid;gap:24px;grid-template-columns:repeat(3,1fr)}@media (max-width:900px){.card-grid{grid-template-columns:1fr}}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;overflow:hidden;transition:all .3s ease}.card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.card__image-wrap{aspect-ratio:16/9;background:var(--bg-secondary);overflow:hidden;position:relative}.card__image-wrap img{height:100%;object-fit:cover;transition:transform .6s ease;width:100%}.card:hover .card__image-wrap img{transform:scale(1.06)}.card__badge{background:var(--bg-card);border-radius:6px;box-shadow:var(--shadow-sm);color:var(--text);font-size:1.15rem;font-weight:600;padding:4px 10px;position:absolute;right:12px;top:12px}.card__body{display:flex;flex:1;flex-direction:column;gap:10px;justify-content:space-between;padding:22px}.card__title{color:var(--text);font-family:Syne,sans-serif;font-size:1.7rem;font-weight:700}.card__company{color:var(--accent-dark);font-size:1.3rem;font-weight:600}.card__description{color:var(--text-muted);font-size:1.5rem;line-height:1.6;margin:0;text-align:left}.card__bullets{display:flex;flex-direction:column;gap:6px;list-style:none;margin-top:4px}.card__bullets li{color:var(--text-muted);font-size:1.35rem;line-height:1.5;padding-left:14px;position:relative}.card__bullets li:before{color:var(--accent-dark);content:"→";font-size:1.1rem;left:0;position:absolute}.card .btn{align-self:center;text-align:center}.chatbot-section{padding:100px 0}.chatbot-wrapper{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-md);display:grid;grid-template-columns:1fr 1.6fr}@media (max-width:900px){.chatbot-wrapper{grid-template-columns:1fr}}.chat-info{background:linear-gradient(160deg,var(--hero-grad-1),var(--hero-grad-2));border-right:1px solid var(--border);display:flex;flex-direction:column;gap:16px;padding:40px}.chat-info h3{color:var(--text);font-family:Syne,sans-serif;font-size:2rem;font-weight:700}.chat-info p{color:var(--text);font-size:1.5rem;line-height:1.7;text-align:left}.chat-box{display:flex;flex-direction:column;gap:16px;padding:28px}.scroll-area{height:280px;padding-right:4px}#chat-log{display:flex;flex-direction:column;gap:14px;list-style:none}#chat-log li{align-items:flex-start;animation:fadeInUp .3s ease;display:flex;gap:10px}#chat-log li.user-template{flex-direction:row-reverse}.avatar{align-items:center;border-radius:10px;display:flex;flex-shrink:0;font-size:1.1rem;font-weight:700;height:36px;justify-content:center;width:36px}.avatar.bot{background:var(--chat-bot-bg);color:var(--text)}.avatar.user{background:var(--chat-user-bg);color:#f5f5f5}.message{background:var(--bg-secondary);border-radius:14px;border-top-left-radius:4px;color:var(--text);font-size:1.4rem;line-height:1.55;max-width:80%;padding:12px 16px;white-space:pre-wrap}.user-template .message{background:var(--accent);border-top-left-radius:14px;border-top-right-radius:4px;color:#f5f5f5}.chat-message{display:flex;gap:10px}.chat-message input{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;color:var(--text);flex:1;font-family:DM Sans,sans-serif;font-size:1.4rem;padding:12px 16px;transition:all .2s ease}.chat-message input:focus{background:var(--bg-card);border-color:var(--accent);outline:none}.chat-message input::placeholder{color:var(--text-faint)}footer{background:var(--bg-card);border-top:1px solid var(--border);padding:40px 0}.footer-inner{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between}.footer-copy{color:var(--text-muted);font-size:1.35rem}.footer-links{display:flex;gap:20px}.footer-links a{color:var(--text-muted);font-size:1.35rem;text-decoration:none;transition:color .2s ease}.footer-links a:hover{color:var(--accent)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}.reveal.visible{opacity:1;transform:translateY(0)}.chatbot-wrapper{border-radius:24px;overflow:hidden}.chat-box{overflow-x:hidden;padding:20px}.message{max-width:100%;overflow-wrap:break-word;white-space:normal;word-break:break-word}.scroll-area{overflow-x:hidden;overflow-y:auto}.chat-message{flex-wrap:wrap;gap:8px}.chat-message input{min-width:0;width:100%}.chat-message .btn{white-space:nowrap}@media (max-width:480px){.chat-box{padding:16px}.message{font-size:1.3rem;padding:8px 12px}.avatar{font-size:1rem;height:28px;width:28px}.chat-message input{padding:10px 12px}}