.about{background-color:#f9fafb}.about-content{display:grid;grid-template-columns:2fr 1fr;gap:4rem;align-items:center}@media(max-width:768px){.about-content{grid-template-columns:1fr;gap:2rem}}.about-text p{font-size:1.125rem;margin-bottom:1.5rem;color:#374151;line-height:1.7}@media(max-width:768px){.about-text p{font-size:1rem}}.about-stats{display:grid;grid-template-columns:1fr 1fr;gap:2rem}@media(max-width:640px){.about-stats{grid-template-columns:1fr;gap:1rem}}.stat{text-align:center;padding:2rem;background:#fff;border-radius:1rem;box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);transition:all .3s ease;position:relative;overflow:hidden}.stat:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(135deg,#475569,#3b82f6)}.stat:hover{transform:translateY(-8px);box-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,.04)}.stat h3{font-size:2.25rem;font-weight:700;background:linear-gradient(135deg,#475569,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:rgba(0,0,0,0);background-clip:text;margin-bottom:.5rem}.stat p{color:#6b7280;font-weight:500}.btn-primary{background:linear-gradient(135deg,#475569,#334155)!important;color:#fff!important;border:none!important;padding:.75rem 2rem!important;border-radius:.75rem!important;font-weight:500!important;font-size:1rem!important;transition:all .2s ease!important;box-shadow:0 2px 8px rgba(71,85,105,.2)!important;transform:translateY(0)!important}.btn-primary:hover{background:linear-gradient(135deg,#334155,#1e293b)!important;transform:translateY(-1px)!important;box-shadow:0 4px 12px rgba(71,85,105,.3)!important}.btn-primary:active{transform:translateY(0)!important;box-shadow:0 1px 4px rgba(71,85,105,.2)!important}.btn-primary:focus{outline:none!important;box-shadow:0 0 0 3px rgba(71,85,105,.3)!important}.btn-secondary{background:hsla(0,0%,100%,.9)!important;backdrop-filter:blur(8px)!important;border:1px solid hsla(0,0%,100%,.3)!important;color:#374151!important;padding:.75rem 2rem!important;border-radius:.75rem!important;font-weight:500!important;font-size:1rem!important;transition:all .2s ease!important;transform:translateY(0)!important}.btn-secondary:hover{background:#fff!important;transform:translateY(-1px)!important;box-shadow:0 4px 12px rgba(0,0,0,.1)!important;color:#1f2937!important}.btn-secondary:active{transform:translateY(0)!important;box-shadow:0 1px 4px rgba(0,0,0,.1)!important}.btn-secondary:focus{outline:none!important;box-shadow:0 0 0 3px rgba(59,130,246,.3)!important}.btn-outline{background:rgba(0,0,0,0)!important;border:2px solid #475569!important;color:#475569!important;padding:.75rem 2rem!important;border-radius:.75rem!important;font-weight:500!important;font-size:1rem!important;transition:all .2s ease!important;transform:translateY(0)!important}.btn-outline:hover{background:#475569!important;color:#fff!important;transform:translateY(-1px)!important;box-shadow:0 4px 12px rgba(71,85,105,.3)!important}.btn-outline:active{transform:translateY(0)!important;box-shadow:0 1px 4px rgba(71,85,105,.2)!important}.btn-outline:focus{outline:none!important;box-shadow:0 0 0 3px rgba(71,85,105,.3)!important}.contact{background-color:#f9fafb}.contact-content{display:grid;grid-template-columns:1fr 1fr;gap:4rem}@media(max-width:768px){.contact-content{grid-template-columns:1fr;gap:2rem}}.contact-info h3{font-size:1.875rem;font-weight:600;color:#111827;margin-bottom:1rem}.contact-info p{color:#6b7280;margin-bottom:2rem;line-height:1.6}.contact-details{display:flex;flex-direction:column;gap:1rem}.contact-item{display:flex;align-items:center;gap:1rem;color:#374151}.contact-item i{width:20px;color:#475569}.contact-item a{color:#475569;text-decoration:none}.contact-item a:hover{text-decoration:underline}.contact-form{background:#fff;padding:2rem;border-radius:1rem;box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06)}.form-group{margin-bottom:1.5rem}.form-group input,.form-group textarea{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:.75rem;font-size:1rem;transition:border-color .3s ease;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#475569}.form-group textarea{resize:vertical;min-height:120px}.notification{position:fixed;top:90px;right:20px;padding:1rem 1.5rem;border-radius:.75rem;box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05);z-index:1050;max-width:400px;font-weight:500;display:flex;align-items:center;justify-content:space-between;gap:1rem}.notification-success{background:#10b981;color:#fff}.notification-error{background:#ef4444;color:#fff}.notification-close{background:none;border:none;color:inherit;cursor:pointer;padding:4px;border-radius:.25rem;display:flex;align-items:center;justify-content:center;transition:background-color .3s ease}.notification-close:hover{background-color:hsla(0,0%,100%,.2)}.notification-close:focus{outline:2px solid hsla(0,0%,100%,.5);outline-offset:2px}.timeline{position:relative;max-width:900px;margin:0 auto}.timeline:before{content:"";position:absolute;left:50%;top:0;bottom:0;width:2px;background:linear-gradient(90deg,#475569,#3b82f6);transform:translateX(-50%)}@media(max-width:768px){.timeline:before{left:20px}}.timeline-item{position:relative;margin-bottom:3rem;display:flex;align-items:center}@media(max-width:768px){.timeline-item{flex-direction:column;align-items:flex-start}}.timeline-marker{position:absolute;left:50%;transform:translateX(-50%);width:20px;height:20px;background:#475569;border-radius:9999px;border:4px solid #fff;box-shadow:0 0 0 4px #e5e7eb;z-index:1}@media(max-width:768px){.timeline-marker{left:20px;transform:translateX(-50%)}}.timeline-content{background:#fff;padding:2rem;border-radius:1rem;box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);width:calc(50% - 40px);position:relative;min-height:-moz-fit-content;min-height:fit-content}@media(max-width:768px){.timeline-content{width:calc(100% - 80px);margin-left:80px}}.timeline-content h3{font-size:1.5rem;font-weight:600;color:#111827;margin-bottom:.5rem}.timeline-content h4{font-size:1.25rem;color:#475569;margin-bottom:.5rem}.timeline-content-right{margin-left:calc(50% + 40px)}.timeline-content-left{margin-right:calc(50% + 40px);margin-left:0}.timeline-date{color:#6b7280;font-size:.875rem;margin-bottom:1rem;display:block}.experience-list{list-style:none}.experience-list li{color:#374151;position:relative;padding:.5rem 0 .5rem 1.5rem;line-height:1.6;word-wrap:break-word;overflow-wrap:break-word}.experience-list li:before{content:"▶";position:absolute;left:0;color:#475569;font-size:.75rem}.experience-list li:hover{color:#374151;transform:none;background:none}.chat-toggle{position:fixed;bottom:20px;right:20px;width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);border:none;cursor:pointer;box-shadow:0 4px 20px rgba(102,126,234,.4);z-index:1000;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.chat-toggle:hover{box-shadow:0 6px 25px rgba(102,126,234,.6);transform:translateY(-2px)}.chat-toggle.open{background:linear-gradient(135deg,#ff6b6b,#ee5a24);box-shadow:0 4px 20px rgba(255,107,107,.4)}.chat-toggle .chat-icon{color:#fff;font-size:28px;transition:all .3s ease;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.chat-toggle .chat-icon svg{width:28px;height:28px}.chat-toggle .chat-badge{position:absolute;top:-5px;right:-5px;background:#ff6b6b;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:10px;animation:pulse 2s infinite;border:2px solid #fff;box-shadow:0 2px 4px rgba(0,0,0,.2)}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.chat-window{position:fixed;bottom:90px;right:20px;width:350px;height:600px;background:#fff;border-radius:16px;box-shadow:0 10px 40px rgba(0,0,0,.15);z-index:999;display:flex;flex-direction:column;overflow:hidden;border:1px solid #e1e5e9}@media(max-width:480px){.chat-window{width:calc(100vw - 40px);height:calc(100vh - 120px);bottom:10px;right:10px;left:10px}}.chat-header{background:linear-gradient(135deg,#667eea,#764ba2);padding:16px 20px;color:#fff}.chat-header .chat-title{display:flex;align-items:center;gap:12px}.chat-header .chat-title .chat-avatar{width:50px;height:50px;border-radius:50%;overflow:hidden;border:2px solid hsla(0,0%,100%,.3);background:linear-gradient(135deg,#475569,#3b82f6);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(71,85,105,.3)}.chat-header .chat-title .chat-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.chat-header .chat-title .chat-avatar img[src$=".svg"]{width:40px;height:40px;-o-object-fit:contain;object-fit:contain;padding:2px;filter:brightness(1.1) contrast(1.1)}.chat-header .chat-title .chat-info h3{margin:0;font-size:16px;font-weight:600}.chat-header .chat-title .chat-info .status-container{display:flex;flex-direction:column;gap:2px}.chat-header .chat-title .chat-info .status{font-size:12px;opacity:.8;display:flex;align-items:center;gap:4px}.chat-header .chat-title .chat-info .status:before{content:"";width:8px;height:8px;background:#4ade80;border-radius:50%;display:inline-block}.chat-header .chat-title .chat-info .backend-indicator{font-size:10px;opacity:.7;background:hsla(0,0%,100%,.2);padding:2px 6px;border-radius:8px;display:inline-block;width:-moz-fit-content;width:fit-content}.chat-header .chat-title .chat-info .chatbot-badge{font-size:9px;opacity:.9;background:rgba(102,126,234,.4);color:#fff;padding:2px 6px;border-radius:8px;display:inline-block;margin-left:6px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border:1px solid hsla(0,0%,100%,.2)}.chat-messages{flex:1;padding:20px;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:12px;background:#f8fafc;max-width:none;word-wrap:break-word;overflow-wrap:break-word;min-width:0;width:100%;min-height:0}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.chat-messages::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#94a3b8}.chat-messages .message{display:flex;max-width:85%;min-width:0;flex-shrink:0;width:-moz-fit-content;width:fit-content}.chat-messages .message.user{align-self:flex-end;justify-content:flex-end}.chat-messages .message.user .message-content{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:18px 18px 4px 18px}.chat-messages .message.caroline{align-self:flex-start;justify-content:flex-start}.chat-messages .message.caroline .message-content{background:#fff;color:#334155;border-radius:18px 18px 18px 4px;border:1px solid #e2e8f0}.chat-messages .message .message-content{padding:12px 16px;position:relative;box-shadow:0 2px 8px rgba(0,0,0,.1);overflow-wrap:break-word;word-wrap:break-word;word-break:break-word;hyphens:auto;min-width:0;max-width:100%;width:100%;box-sizing:border-box;display:block}.chat-messages .message .message-content p{margin:0;font-size:14px;line-height:1.4;word-wrap:break-word}.chat-messages .message .message-content .message-text{font-size:14px;line-height:1.6;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;hyphens:auto;width:100%;max-width:100%;box-sizing:border-box;display:block;min-width:0}.chat-messages .message .message-content .message-text p{margin:0 0 8px}.chat-messages .message .message-content .message-text p:last-child{margin-bottom:0}.chat-messages .message .message-content .message-text h1,.chat-messages .message .message-content .message-text h2,.chat-messages .message .message-content .message-text h3,.chat-messages .message .message-content .message-text h4,.chat-messages .message .message-content .message-text h5,.chat-messages .message .message-content .message-text h6{margin:12px 0 8px;font-weight:600;line-height:1.3}.chat-messages .message .message-content .message-text h3{font-size:16px;color:#1e293b}.chat-messages .message .message-content .message-text ol,.chat-messages .message .message-content .message-text ul{margin:8px 0;padding-left:24px;list-style:disc;box-sizing:border-box}.chat-messages .message .message-content .message-text ul{list-style-type:disc}.chat-messages .message .message-content .message-text ol{list-style-type:decimal}.chat-messages .message .message-content .message-text li{margin:4px 0;line-height:1.6}.chat-messages .message .message-content .message-text strong{font-weight:600;color:#1e293b}.chat-messages .message .message-content .message-text em{font-style:italic}.chat-messages .message .message-content .message-text code{background:rgba(0,0,0,.1);padding:2px 4px;border-radius:3px;font-family:Courier New,monospace}.chat-messages .message .message-content .message-text pre{background:rgba(0,0,0,.05);padding:8px;border-radius:4px;overflow-x:auto;margin:8px 0}.chat-messages .message .message-content .message-text blockquote{border-left:3px solid #667eea;padding-left:12px;margin:8px 0;font-style:italic}.chat-messages .message .message-content .message-text:after,.chat-messages .message .message-content .message-text:before{content:""}.chat-messages .message .message-content .message-text .tech-skills{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0}.chat-messages .message .message-content .message-text ul ul li{margin:2px 4px 2px 0}.chat-messages .message .message-content .message-text code,.chat-messages .message .message-content .message-text ul ul li code{background:#f1f5f9;color:#475569;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;border:1px solid #e2e8f0;white-space:nowrap;display:inline-block;font-family:inherit;vertical-align:middle}.chat-messages .message .message-content .message-text li em:not(.skill-tag):not([class*=skill])[data-skill=true],.chat-messages .message .message-content .message-text li span:not(.skill-tag):not([class*=skill])[data-skill=true],.chat-messages .message .message-content .message-text li strong:not(.skill-tag):not([class*=skill])[data-skill=true]{background:#f1f5f9;color:#475569;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;border:1px solid #e2e8f0;white-space:nowrap;display:inline-block;margin:2px}.chat-messages .message .message-content .message-text .skill-list{display:flex;flex-wrap:wrap;gap:6px}.chat-messages .message .message-content .message-text .skill-list .skill-item{background:#f1f5f9;color:#475569;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;border:1px solid #e2e8f0;white-space:nowrap;display:inline-block}.chat-messages .message .message-content .message-text .skill-category{margin:12px 0}.chat-messages .message .message-content .message-text .skill-category strong{display:inline-block;margin-right:8px;margin-bottom:0;color:#1e293b;vertical-align:top;line-height:1.4}.chat-messages .message .message-content .message-text .skill-category>:not(strong){display:inline-block;vertical-align:top}.chat-messages .message .message-content .message-text span{display:inline;word-wrap:break-word;max-width:100%}.chat-messages .message .message-content .message-text ol,.chat-messages .message .message-content .message-text ul{overflow-wrap:break-word;word-wrap:break-word}.chat-messages .message .message-content .message-text div,.chat-messages .message .message-content .message-text h1,.chat-messages .message .message-content .message-text h2,.chat-messages .message .message-content .message-text h3,.chat-messages .message .message-content .message-text h4,.chat-messages .message .message-content .message-text h5,.chat-messages .message .message-content .message-text h6,.chat-messages .message .message-content .message-text li,.chat-messages .message .message-content .message-text ol,.chat-messages .message .message-content .message-text p,.chat-messages .message .message-content .message-text ul{overflow-wrap:break-word!important;word-wrap:break-word!important;word-break:break-word!important;max-width:100%!important;hyphens:auto!important;box-sizing:border-box!important;min-width:0!important}.chat-messages .message .message-content .message-text *{max-width:100%;box-sizing:border-box;min-width:0}.chat-messages .message .message-content .message-text ol,.chat-messages .message .message-content .message-text ul{width:100%;max-width:100%}.chat-messages .message .message-content .message-text .skill-category,.chat-messages .message .message-content .message-text .skill-list{display:flex!important;flex-wrap:wrap!important;gap:4px!important;max-width:100%!important;overflow-wrap:break-word!important;min-width:0!important}.chat-messages .message .message-content .message-text .badge,.chat-messages .message .message-content .message-text .tag,.chat-messages .message .message-content .message-text code{white-space:nowrap;display:inline-block;max-width:100%;overflow:hidden;text-overflow:ellipsis}.chat-messages .message .message-content .message-text li{display:list-item;list-style-position:inside;max-width:100%;width:100%;box-sizing:border-box;overflow-wrap:break-word;word-wrap:break-word;word-break:break-word;margin:8px 0}.chat-messages .message .message-content .message-text li text{display:inline}.chat-messages .message .message-content .message-text li em,.chat-messages .message .message-content .message-text li span,.chat-messages .message .message-content .message-text li strong{display:inline;vertical-align:baseline;max-width:100%;box-sizing:border-box}.chat-messages .message .message-content .message-text li strong{margin-right:8px;margin-bottom:0;vertical-align:top;line-height:1.4;min-width:-moz-fit-content;min-width:fit-content}.chat-messages .message .message-content .message-text li:has(strong){display:list-item;list-style-position:inside;max-width:100%;width:100%;box-sizing:border-box;overflow-wrap:break-word;word-wrap:break-word;word-break:break-word}.chat-messages .message .message-content .message-text li:has(strong) strong{display:inline;margin-right:8px;margin-bottom:0}.chat-messages .message .message-content .message-text li:has(strong)>:not(strong){display:inline;vertical-align:baseline}.chat-messages .message .message-content .message-text ol li,.chat-messages .message .message-content .message-text ul li{line-height:1.6;margin:6px 0;display:list-item;list-style-position:inside;max-width:100%;width:100%;box-sizing:border-box;overflow-wrap:break-word;word-wrap:break-word;word-break:break-word}.chat-messages .message .message-content .message-text ol li *,.chat-messages .message .message-content .message-text ul li *{vertical-align:baseline;max-width:100%;box-sizing:border-box}.chat-messages .message .message-content .message-text ol li:has(strong),.chat-messages .message .message-content .message-text ul li:has(strong){display:list-item;list-style-position:inside;max-width:100%;width:100%;box-sizing:border-box;overflow-wrap:break-word;word-wrap:break-word;word-break:break-word}.chat-messages .message .message-content .message-text ol li:has(strong) strong,.chat-messages .message .message-content .message-text ul li:has(strong) strong{display:inline;margin-right:8px}.chat-messages .message .message-content .message-text li{font-size:14px;line-height:1.4}.chat-messages .message .message-content .message-text li>*{vertical-align:baseline;display:inline}.chat-messages .message .message-content .message-text li em,.chat-messages .message .message-content .message-text li span,.chat-messages .message .message-content .message-text li strong,.chat-messages .message .message-content .message-text li text{display:inline;vertical-align:baseline;font-size:inherit;line-height:inherit}.chat-messages .message .message-content .message-time{font-size:11px;opacity:.7;margin-top:4px;display:block}.chat-messages .typing-indicator{display:flex;gap:4px;padding:8px 0}.chat-messages .typing-indicator span{width:8px;height:8px;background:#94a3b8;border-radius:50%;animation:typing 1.4s ease-in-out infinite}.chat-messages .typing-indicator span:first-child{animation-delay:-.32s}.chat-messages .typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes typing{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}.chat-input{padding:16px 20px;background:#fff;border-top:1px solid #e2e8f0}.chat-input .input-container{display:flex;gap:8px;align-items:center}.chat-input .input-container input{flex:1;padding:12px 16px;border:1px solid #e2e8f0;border-radius:24px;font-size:14px;outline:none;transition:all .2s ease;background:#f8fafc}.chat-input .input-container input:focus{border-color:#667eea;background:#fff;box-shadow:0 0 0 3px rgba(102,126,234,.1)}.chat-input .input-container input:disabled{opacity:.6;cursor:not-allowed}.chat-input .input-container input::-moz-placeholder{color:#94a3b8}.chat-input .input-container input::placeholder{color:#94a3b8}.chat-input .input-container .send-button{width:40px;height:40px;border-radius:50%;padding:0;background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.chat-input .input-container .send-button:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 12px rgba(102,126,234,.4)}.chat-input .input-container .send-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.chat-input .input-container .send-button svg{width:16px!important;height:16px!important;pointer-events:none;flex-shrink:0}@media(max-width:768px){.chat-toggle{bottom:15px;right:15px;width:55px;height:55px}.chat-toggle .chat-icon{font-size:24px}.chat-toggle .chat-icon svg{width:24px;height:24px}.chat-window{bottom:80px;right:15px;width:320px;height:550px}}@media(prefers-reduced-motion:reduce){.chat-toggle,.chat-window,.message,.typing-indicator span{animation:none;transition:none}}@media(prefers-color-scheme:dark){.chat-window{background:#1e293b;border-color:#334155}.chat-window .chat-messages{background:#0f172a}.chat-window .chat-messages .message.caroline .message-content{background:#334155;color:#e2e8f0;border-color:#475569}.chat-window .chat-input{background:#1e293b;border-color:#334155}.chat-window .chat-input .input-container input{background:#334155;border-color:#475569;color:#e2e8f0}.chat-window .chat-input .input-container input:focus{background:#475569;border-color:#667eea}.chat-window .chat-input .input-container input::-moz-placeholder{color:#94a3b8}.chat-window .chat-input .input-container input::placeholder{color:#94a3b8}.message-text a{word-wrap:break-word;overflow-wrap:break-word;max-width:100%}.message-text a,.message-text a:hover{color:#3b82f6;text-decoration:underline}.message-text a[href^="mailto:"]{color:#059669;font-weight:500}.message-text a[href^="mailto:"]:hover{color:#059669}.message-text a[href^=http],.message-text a[href^=http]:hover{color:#7c3aed}.message-text :contains("@"){color:#059669;font-weight:500;cursor:pointer}.message-text :contains("@"):hover{color:#059669;text-decoration:none}}.footer{background-color:#111827;color:#fff;padding:2rem 0}.footer-content{display:flex;justify-content:space-between;align-items:center}@media(max-width:768px){.footer-content{flex-direction:column;gap:1rem;text-align:center}}.footer-social{display:flex;gap:1rem}.footer-social a{width:40px;height:40px;background-color:hsla(0,0%,100%,.1);border-radius:9999px;display:flex;align-items:center;justify-content:center;color:#fff;text-decoration:none;transition:all .3s ease}.footer-social a:hover{background-color:#475569}.footer-social a i{font-size:1rem}.hero{min-height:100vh;display:flex;align-items:center;background:linear-gradient(135deg,#0f172a,#1e293b 50%,#334155);background-image:url(/goldenGateBridge.jpg);background-size:cover;background-position:50%;background-repeat:no-repeat;background-attachment:scroll;color:#fff;position:relative;overflow:hidden;background-color:#1e293b}@media(max-width:1024px)and (min-width:769px){.hero{padding-top:100px;min-height:calc(100vh - 100px)}}@media(max-width:768px){.hero{padding-top:120px;min-height:calc(100vh - 120px);background-attachment:scroll}}@media(max-width:640px){.hero{padding-top:80px;min-height:calc(100vh - 80px)}}.hero:before{background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="50" cy="50" r="1" fill="white" opacity="0.1"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>');opacity:.1}.hero:after,.hero:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0}.hero:after{background:linear-gradient(135deg,rgba(15,23,42,.3),rgba(59,130,246,.2),rgba(251,191,36,.1));z-index:0;display:block}.hero-container{max-width:1200px;margin:0 auto;padding:0 1.5rem;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;position:relative;z-index:1}@media(max-width:768px){.hero-container{grid-template-columns:1fr;text-align:center;gap:3rem;padding:3rem 1.5rem}}@media(max-width:640px){.hero-container{padding:1.5rem 1rem;gap:1.5rem}}.hero-content{background:rgba(15,23,42,.85);padding:2rem;border-radius:.75rem;backdrop-filter:blur(15px);border:1px solid hsla(0,0%,100%,.1);box-shadow:0 8px 32px rgba(0,0,0,.3);position:relative;z-index:2}@media(max-width:1024px)and (min-width:769px){.hero-content{margin-top:2rem;margin-bottom:2rem}}@media(max-width:768px){.hero-content{padding:2rem;max-width:90%;margin:3rem 1.5rem}}@media(max-width:640px){.hero-content{padding:1.5rem;max-width:95%;margin:1rem 1rem 1.5rem}}.hero-title{font-size:3rem;font-weight:700;margin-bottom:1rem;line-height:1.1;text-shadow:0 2px 4px rgba(0,0,0,.3);letter-spacing:-.02em}@media(max-width:768px){.hero-title{font-size:2.25rem;line-height:1.2}}@media(max-width:640px){.hero-title{font-size:1.875rem;line-height:1.3}}.highlight{background:linear-gradient(135deg,#3b82f6,#2563eb);-webkit-background-clip:text;-webkit-text-fill-color:rgba(0,0,0,0);background-clip:text;font-weight:700;text-shadow:none;white-space:nowrap;display:inline-block}@media(max-width:640px){.highlight{white-space:normal}}.hero-subtitle{font-size:1.5rem;font-weight:500;margin-bottom:1.5rem;opacity:.95;text-shadow:0 1px 3px rgba(0,0,0,.3);color:#f8fafc}@media(max-width:768px){.hero-subtitle{font-size:1.25rem}}.hero-description{font-size:1.125rem;margin-bottom:2rem;opacity:.8;line-height:1.7;text-shadow:0 1px 2px rgba(0,0,0,.3)}@media(max-width:768px){.hero-description{font-size:1rem}}.hero-buttons{display:flex;gap:1rem;margin-bottom:2rem}@media(max-width:768px){.hero-buttons{gap:1.5rem;justify-content:center}}@media(max-width:640px){.hero-buttons{flex-direction:column;align-items:center;gap:1rem}}.hero-social{display:flex;gap:1rem;justify-content:flex-start}@media(max-width:768px){.hero-social{gap:1.5rem;justify-content:center}}.social-link{width:50px;height:50px;background:hsla(0,0%,100%,.15);border-radius:9999px;display:flex;align-items:center;justify-content:center;color:#fff;text-decoration:none;transition:all .3s ease;backdrop-filter:blur(8px);border:1px solid hsla(0,0%,100%,.2)}.social-link:hover{background:linear-gradient(135deg,#475569,#3b82f6);color:#fff;transform:translateY(-2px);box-shadow:0 8px 20px rgba(245,158,11,.3)}.social-link i{font-size:1.125rem}.hero-image{display:flex;justify-content:center;align-items:center}.hero-image-container{width:300px;height:300px;border-radius:9999px;overflow:hidden;border:3px solid rgba(0,0,0,0);background-color:#f1f5f9;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);background-clip:padding-box;box-shadow:0 20px 40px rgba(0,0,0,.3),0 0 0 3px linear-gradient(135deg,#475569,#3b82f6);backdrop-filter:blur(8px);position:relative;transition:all .3s ease}.hero-image-container:hover{transform:scale(1.02);box-shadow:0 25px 50px rgba(245,158,11,.2),0 0 0 3px linear-gradient(135deg,#475569,#3b82f6)}@media(max-width:768px){.hero-image-container{width:250px;height:250px}}@media(max-width:640px){.hero-image-container{width:200px;height:200px}}.hero-image-container:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(255,255,255,.1),rgba(255,255,255,.05));z-index:1;pointer-events:none}.hero-photo{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;-o-object-position:center top;object-position:center top;transition:transform .3s ease}.hero-photo:hover{transform:scale(1.05)}.navbar{position:fixed;top:0;width:100%;background:linear-gradient(135deg,rgba(255,255,255,.95),rgba(255,255,255,.9));backdrop-filter:blur(20px);z-index:1030;transition:all .3s ease;border-bottom:1px solid hsla(0,0%,100%,.2);box-shadow:0 4px 30px rgba(0,0,0,.1)}.navbar:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,rgba(59,130,246,.05),rgba(147,51,234,.05) 50%,rgba(236,72,153,.05));opacity:0;transition:opacity .3s ease}.navbar:hover:before{opacity:1}.navbar.scrolled{background:linear-gradient(135deg,rgba(255,255,255,.98),rgba(255,255,255,.95));box-shadow:0 8px 40px rgba(0,0,0,.15);border-bottom:1px solid rgba(59,130,246,.2)}.navbar.scrolled:before{opacity:1}.nav-container{max-width:1200px;margin:0 auto;padding:0 1.5rem;display:flex;justify-content:space-between;align-items:center;height:70px}.nav-logo,.nav-logo a{position:relative}.nav-logo a{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#475569,#334155,#3b82f6);background-size:200% 200%;-webkit-background-clip:text;-webkit-text-fill-color:rgba(0,0,0,0);background-clip:text;text-decoration:none;transition:all .3s ease;animation:gradientShift 3s ease-in-out infinite}.nav-logo a:hover{transform:scale(1.05);filter:drop-shadow(0 0 8px rgba(59,130,246,.3))}.nav-logo a:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#475569,#334155,#3b82f6);background-size:200% 200%;opacity:0;transition:opacity .3s ease;animation:gradientShift 3s ease-in-out infinite;z-index:-1;border-radius:8px;padding:4px;margin:-4px}.nav-logo a:hover:before{opacity:.1}@keyframes gradientShift{0%,to{background-position:0 50%}50%{background-position:100% 50%}}.nav-menu{display:flex;gap:2rem}@media(max-width:768px){.nav-menu{position:fixed;left:-100%;top:70px;flex-direction:column;background-color:#fff;width:100%;text-align:center;transition:.3s;box-shadow:0 10px 27px rgba(0,0,0,.05);padding:2rem 0}.nav-menu.active{left:0}}.nav-link{color:#111827;text-decoration:none;font-weight:500;transition:all .3s ease;position:relative;padding:8px 16px;border-radius:8px;overflow:hidden}.nav-link:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(59,130,246,.1),transparent);transition:left .5s ease}.nav-link:after{content:"";position:absolute;bottom:0;left:50%;width:0;height:2px;background:linear-gradient(90deg,#475569,#3b82f6,#2563eb);transition:all .3s ease;transform:translateX(-50%);border-radius:1px}.nav-link:hover{color:#475569;transform:translateY(-2px);box-shadow:0 4px 12px rgba(59,130,246,.15)}.nav-link:hover:before{left:100%}.nav-link:hover:after{width:100%}.nav-link:active{transform:translateY(0)}.nav-toggle{display:none;flex-direction:column;cursor:pointer;padding:8px;border-radius:8px;transition:all .3s ease;position:relative;overflow:hidden}.nav-toggle:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(59,130,246,.1),rgba(139,92,246,.1));opacity:0;transition:opacity .3s ease;border-radius:8px}.nav-toggle:hover:before{opacity:1}@media(max-width:768px){.nav-toggle{display:flex}}.nav-toggle .bar{width:25px;height:3px;background:linear-gradient(90deg,#475569,#3b82f6);margin:3px 0;transition:all .3s ease;border-radius:2px;position:relative;z-index:1}.nav-toggle:hover .bar{background:linear-gradient(90deg,#334155,#3b82f6);transform:scale(1.1)}.nav-toggle.active .bar:nth-child(2){opacity:0;transform:scale(0)}.nav-toggle.active .bar:first-child{transform:translateY(8px) rotate(45deg);background:linear-gradient(90deg,#ef4444,#dc2626)}.nav-toggle.active .bar:nth-child(3){transform:translateY(-8px) rotate(-45deg);background:linear-gradient(90deg,#ef4444,#dc2626)}.projects{background-color:#f9fafb}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}@media(max-width:768px){.projects-grid{grid-template-columns:1fr}}#personal-projects-heading,#professional-projects-heading{margin-bottom:1rem;margin-top:2rem;color:#6b7280;font-weight:600}.project-card{background:#fff;border-radius:1rem;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.1);transition:all .3s ease;border:1px solid rgba(0,0,0,.05);display:flex;flex-direction:column}.project-card>div:nth-child(2){display:flex;flex-direction:column;flex:1}.project-card:hover{box-shadow:0 8px 40px rgba(0,0,0,.15);transform:translateY(-2px)}.project-image{height:200px;display:flex;align-items:center;justify-content:center;color:#fff;position:relative;overflow:hidden;border-radius:12px;background:linear-gradient(135deg,#475569,#3b82f6)}.project-image.project-image-screenshot{background:rgba(0,0,0,0)!important;padding:0!important;height:auto!important;background-image:none!important;background-color:rgba(0,0,0,0)!important}.project-image.project-image-screenshot:before{display:none!important}.project-image.project-image-screenshot img{border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.15);background:#fff!important;display:block!important;width:100%!important;height:200px!important;-o-object-fit:cover!important;object-fit:cover!important;background-color:#fff!important;background-image:none!important}.project-image.project-image-icon{background:linear-gradient(135deg,#475569,#3b82f6)}.project-image.project-image-icon:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,rgba(255,255,255,.1),transparent);z-index:1}.project-image.project-image-icon i{font-size:3rem;z-index:2;position:relative}.project-content{padding:2rem}.project-content h3{font-size:1.5rem;font-weight:600;color:#111827;margin-bottom:1rem}.project-content p{color:#6b7280;margin-bottom:1.5rem;line-height:1.6}.project-tech{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem;margin-bottom:1.5rem}.project-tech>*{padding:.4375rem 1rem!important}.tech-tag{background:linear-gradient(135deg,#64748b,#3b82f6);color:#fff;padding:.25rem 1rem;border-radius:9999px;font-size:.875rem;font-weight:500;box-shadow:0 2px 8px rgba(245,158,11,.3);transition:all .3s ease}.tech-tag:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(245,158,11,.4)}.project-link{color:#475569;text-decoration:none;font-weight:600;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:color .3s ease;margin-top:auto;align-self:center}.project-link:hover{color:#334155}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:3rem}@media(max-width:768px){.skills-grid{grid-template-columns:1fr}}.skill-category h3{font-size:1.5rem;font-weight:600;color:#111827;margin-bottom:2rem;text-align:center}.skill-item{margin-bottom:1.5rem}.skill-name{display:block;font-weight:500;color:#374151;margin-bottom:.5rem}.skill-bar{height:8px;background:#e5e7eb;border-radius:.25rem;overflow:hidden}.skill-progress{height:100%;background:linear-gradient(90deg,#475569,#3b82f6);border-radius:.25rem;transition:width 1s ease}