*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}:root{--nav-height:105px;--font-heading:Georgia, "Times New Roman", serif}body{color:#222;padding-top:var(--nav-height);background:#f8f8f8;font-family:Segoe UI,Roboto,system-ui,sans-serif;line-height:1.6}.timeline-horizontal{justify-content:space-between;margin:4rem 0;padding:3rem 1rem;display:flex;position:relative}.timeline-horizontal:before{content:"";background:#bfa46f;width:90%;height:3px;position:absolute;top:50%;left:5%}.timeline-item{flex:1;justify-content:center;display:flex;position:relative}.timeline-dot{z-index:2;background:#666;border-radius:50%;width:16px;height:16px;position:absolute;top:50%;transform:translateY(-50%)}.timeline-content{text-align:center;color:#555;width:220px;font-size:.9rem;position:absolute}.timeline-item:nth-child(odd) .timeline-content{top:calc(50% + 30px)}.timeline-item:nth-child(2n) .timeline-content{bottom:calc(50% + 30px)}.timeline-content h3{color:#222;margin-bottom:4px;font-size:1rem}.timeline-content small{color:#777;opacity:.7;font-style:italic}.logo img{height:60px;display:block}nav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:100;background-color:#fffc;border-bottom:1px solid #eee;justify-content:center;width:100%;padding:20px 10%;display:flex;position:fixed;top:0;left:0}nav .nav-container{justify-content:space-between;align-items:center;width:100%;max-width:1200px;display:flex}nav .logo{color:#222;font-size:1.5rem;font-weight:700}.nav-toggle{color:#222;cursor:pointer;background:#ffffffeb;border:1px solid #2222221f;border-radius:999px;justify-content:center;align-items:center;width:44px;height:44px;display:none}.nav-toggle i{font-size:1.5rem}nav .nav-links{align-items:center;gap:70px;display:flex;position:absolute;left:50%;transform:translate(-50%)}nav .nav-links a{color:#222;font-weight:500;text-decoration:none;transition:color .3s}nav .nav-links a:hover{color:#bfa46f}.hero-vintage{background-color:#fcfcfc;flex-wrap:wrap;justify-content:space-between;align-items:center;min-height:90vh;padding:0 10%;display:flex}.hero-main-container{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:50px;width:100%;max-width:1200px;margin:0 auto;padding:2rem;display:flex}.hero-content{flex:1;min-width:280px}.hero-name{font-family:var(--font-heading), serif;color:#333;white-space:nowrap;margin-bottom:1rem;font-size:clamp(1.8rem,5vw,3.5rem);font-weight:700}.hero-title-wrapper{align-items:center;gap:15px;margin-bottom:1.5rem;display:flex}.title-line{background-color:#333;width:50px;height:1px}.hero-subtitle{color:#555;font-size:1.2rem;font-weight:500}.hero-description{color:#666;max-width:500px;margin-bottom:2.5rem;font-size:1.1rem;line-height:1.6}.btn-say-hello{color:#fff;background-color:#333;border-radius:1rem;align-items:center;gap:10px;padding:1.2rem 2.5rem;font-weight:600;text-decoration:none;transition:all .3s;display:inline-flex}.btn-say-hello:hover{background-color:#e2725b;transform:translateY(-3px)}.hero-image-wrapper{flex:1;justify-content:flex-end;min-width:280px;display:flex}.blob-shape{background-color:#e2725b;border-radius:60% 40% 30% 70%/60% 30% 70% 40%;width:400px;height:400px;transition:all 1s ease-in-out;animation:8s ease-in-out infinite blob-morph;overflow:hidden}.blob-shape img{object-fit:cover;width:100%;height:100%}@keyframes blob-morph{0%{border-radius:60% 40% 30% 70%/60% 30% 70% 40%}50%{border-radius:30% 60% 70% 40%/50% 60% 30%}to{border-radius:60% 40% 30% 70%/60% 30% 70% 40%}}.hero-left{align-items:center;gap:2rem;display:flex}.hero-icons-vertical{flex-direction:column;gap:1.5rem;display:flex}.hero-icons-vertical .icon-primary{color:#e2725b;font-size:2.3rem;transition:transform .3s,color .3s}.hero-icons-vertical .icon-primary:hover{color:#ff4500;transform:scale(1.2)}.section-spacer{width:100%;height:3rem}section{opacity:0;min-height:100vh;scroll-margin-top:calc(var(--nav-height) + 12px);padding:120px 10%;transition:all .8s ease-out;transform:translateY(30px)}section:nth-of-type(odd){background:linear-gradient(#fdfcfb,#f3f1ee)}section:nth-of-type(2n){background:linear-gradient(#f9f8f7,#eae6e0)}.show{opacity:1!important;transform:translateY(0)!important}h2{color:#222;text-align:center;font-size:2.5rem;font-family:var(--font-heading), serif;margin-bottom:15px}.subtitle{text-align:center;color:#666;margin-bottom:40px;font-size:1.1rem}.about-container{flex-wrap:wrap;justify-content:center;gap:4rem;max-width:1100px;margin:0 auto;padding:2rem 0;display:flex}.about-img-box{flex:1;max-width:400px}.about-img{border-radius:2rem;width:100%;box-shadow:0 10px 30px #0000000d}.about-data{flex:1.2;min-width:280px}.about-info-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));justify-items:center;gap:1.25rem;max-width:900px;margin-bottom:2.5rem;display:grid}.about-card{text-align:center;background-color:#fff;border:1px solid #00000014;border-radius:1rem;width:100%;max-width:320px;padding:1.5rem 1.25rem;transition:transform .35s,box-shadow .35s,border-color .35s}.about-card:hover{border-color:#0000001f;transform:translateY(-8px)scale(1.03);box-shadow:0 18px 40px #0000001f}.about-card.no-hover:hover{box-shadow:none!important;border-color:#00000014!important;transform:none!important}.about__icon,.about-card i{color:#bfa46f;font-size:1.6rem;transition:transform .35s,color .35s}.about-card:hover .about__icon,.about-card:hover i{color:#e2725b;transform:scale(1.12)}.about-card-title{margin:.75rem 0 .25rem;font-size:.95rem;font-weight:600}.about-card-subtitle{color:#555;font-size:.85rem}.about-description{color:#555;text-align:justify;font-size:1rem;line-height:1.8}.skills-main-grid{grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:2rem;max-width:1200px;margin:0 auto;display:grid}.skill-category-card{text-align:left;background:#fff;border-radius:1.25rem;padding:2rem;box-shadow:0 4px 20px #0000000d}.skill-category-card h3{color:#d67d7d;margin-bottom:1.5rem;font-size:1.4rem;font-weight:700}.tech-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem;display:grid}.tech-item{background:#fdfdfd;border-radius:.75rem;flex-direction:column;justify-content:center;align-items:center;padding:.75rem;transition:transform .2s;display:flex}.tech-item:hover{transform:translateY(-5px)}.tech-item img,.tech-icon,.tech-svg-icon,.tech-fallback{width:40px;height:40px;margin-bottom:.5rem}.tech-item span{color:#555;text-align:center;font-size:.75rem;font-weight:500}.tech-icon{color:#222;font-size:48px}.tech-svg-icon{color:#222}.tech-fallback{color:#4d4338;background:#efe8db;border-radius:999px;justify-content:center;align-items:center;font-size:.95rem;font-weight:700;display:inline-flex}.project-filter-bar{flex-wrap:wrap;justify-content:center;gap:10px;margin:0 auto 26px;display:flex}.project-filter{color:#5a5147;cursor:pointer;background:#fffc;border:1px solid #bfa46f57;border-radius:999px;padding:9px 16px;font-weight:600;transition:background-color .25s,color .25s,border-color .25s}.project-filter:hover,.project-filter.is-active{color:#fff;background:#bfa46f;border-color:#bfa46f}.project-filter-empty{text-align:center;color:#6d655d;margin-bottom:22px}.projects-grid{grid-template-columns:repeat(2,minmax(0,360px));justify-content:center;gap:24px;max-width:860px;margin:0 auto;display:grid}.project-card{cursor:pointer;opacity:0;min-height:100%;color:inherit;isolation:isolate;background:linear-gradient(#fff,#fcfcfb);border:1px solid #0f172a14;border-radius:24px;flex-direction:column;text-decoration:none;transition:transform .45s cubic-bezier(.22,1,.36,1),box-shadow .35s,border-color .35s,background .35s,opacity .8s ease-out;display:flex;position:relative;overflow:hidden;transform:translateY(20px);box-shadow:0 14px 30px #0f172a0f,0 2px 8px #0f172a0a}.project-card[hidden]{display:none!important}.project-card:before{content:"";opacity:0;pointer-events:none;z-index:0;background:radial-gradient(circle at 100% 0,#d676571f,#0000 32%),radial-gradient(circle at 0 100%,#70a2ff14,#0000 30%);transition:opacity .35s,transform .35s;position:absolute;inset:0}.project-card:after{content:"";filter:blur(4px);opacity:0;pointer-events:none;z-index:0;background:linear-gradient(135deg,#d676571f,#70a2ff12);border-radius:16px;width:42px;height:42px;transition:transform .35s,opacity .35s;position:absolute;top:14px;right:16px;transform:rotate(8deg)scale(.92)}.project-card:hover{background:linear-gradient(#fff,#fbf8f6);border-color:#d676572e;transform:translateY(-7px)rotate(-.45deg)scale(1.008);box-shadow:0 22px 44px #0f172a17,0 6px 18px #d6765714}.project-card:hover:before{opacity:1;transform:scale(1.02)}.project-card:hover:after{opacity:.85;transform:rotate(16deg)scale(1.05)}.projects-grid>:nth-child(2n):hover{transform:translateY(-7px)rotate(.45deg)scale(1.008)}.project-media{aspect-ratio:16/9;z-index:1;isolation:isolate;background:linear-gradient(135deg,#f1f3f5,#fafafa);border-bottom:1px solid #0f172a0f;border-radius:24px 24px 0 0;position:relative;overflow:hidden}.project-media:before{content:"";opacity:.9;pointer-events:none;z-index:1;background:linear-gradient(#0000 58%,#0f172a29),linear-gradient(135deg,#ffffff0f,#0000 55%);transition:opacity .35s,background .35s;position:absolute;inset:0}.project-media:after{content:"";opacity:0;pointer-events:none;z-index:2;border:1px solid #ffffff2e;border-radius:18px;transition:opacity .35s,transform .35s,border-color .35s;position:absolute;inset:10px;transform:scale(.98)}.project-card img{object-fit:contain;object-position:center;filter:saturate(.96)contrast(1.02);width:100%;height:100%;transition:transform .65s cubic-bezier(.22,1,.36,1),filter .4s;position:absolute;inset:0;transform:scale(.96)}.project-card:hover img{filter:saturate(1.02)contrast(1.04);transform:scale(.99)translateY(-2px)}.project-card:hover .project-media:before{opacity:1;background:linear-gradient(#0000 52%,#0f172a14),linear-gradient(135deg,#fff8f31f,#0000 58%)}.project-card:hover .project-media:after{opacity:1;border-color:#ffffff4d;transform:scale(1)}.project-info{z-index:1;flex-direction:column;flex:1;gap:18px;padding:20px 20px 18px;display:flex;position:relative}.project-type-badge{color:#52525b;letter-spacing:.06em;text-transform:uppercase;background:#f5f5f4;border-radius:999px;align-items:center;padding:6px 11px;font-size:.72rem;font-weight:700;transition:transform .28s,background-color .28s,color .28s;display:inline-flex}.project-badge-row{flex-wrap:wrap;gap:8px;display:flex}.project-status-badge{color:#8b5e50;letter-spacing:.06em;text-transform:uppercase;background:#f7f1ee;border-radius:999px;align-items:center;padding:6px 11px;font-size:.72rem;font-weight:700;transition:transform .28s,background-color .28s,color .28s;display:inline-flex}.project-info h3{color:#18181b;letter-spacing:-.01em;font-size:1.05rem;font-weight:700;line-height:1.4;transition:color .3s,transform .3s}.project-card-footer{flex-direction:column;gap:10px;margin-top:auto;display:flex}.project-link-text{color:#3f3f46;background:#fafafa;border:1px solid #0f172a14;border-radius:999px;align-items:center;gap:8px;width:fit-content;min-height:38px;padding:0 12px;font-size:.88rem;font-weight:600;transition:transform .3s cubic-bezier(.22,1,.36,1),background-color .25s,border-color .25s,color .25s;display:inline-flex}.project-link-text i{font-size:1.2rem;transition:transform .32s cubic-bezier(.22,1,.36,1)}.project-card:hover h3{color:#27272a;transform:translate(1px)}.project-card:hover .project-link-text{color:#9a4d2f;background:#fff8f4;border-color:#d6765733;transform:translate(2px)}.project-card:hover .project-type-badge,.project-card:hover .project-status-badge{transform:translateY(-1px)}.project-card:hover .project-type-badge{color:#6b4d42;background:#f4eee9}.project-card:hover .project-status-badge{color:#9a4d2f;background:#f8e9e1}.project-card:hover .project-link-text i{transform:translate(4px)scale(1.04)}.section.show .project-card{opacity:1!important;transform:translateY(0)!important}.project-detail-page{background:linear-gradient(#fdfcfb,#f3f1ee);padding:60px 10% 100px}.project-detail-hero{opacity:1;grid-template-columns:minmax(320px,1.05fr) minmax(320px,1fr);align-items:start;gap:48px;max-width:1200px;min-height:auto;margin:0 auto;padding:0;display:grid;transform:none}.project-detail-media img{border-radius:24px;width:100%;display:block;box-shadow:0 18px 45px #0000001a}.project-back-link{color:#555;align-items:center;gap:8px;margin-bottom:20px;text-decoration:none;display:inline-flex}.project-back-link:hover{color:#e2725b}.project-detail-copy h1{font-size:clamp(2rem,4vw,3.25rem);line-height:1.1;font-family:var(--font-heading), serif;margin-bottom:16px}.project-detail-description{color:#555;margin-bottom:24px;font-size:1.05rem;line-height:1.8}.project-type-badge-detail,.project-status-badge-detail{margin-bottom:16px}.project-github-link{color:#fff;background:#222;border-radius:999px;align-items:center;gap:8px;margin-bottom:24px;padding:10px 16px;font-weight:600;text-decoration:none;display:inline-flex}.project-github-link:hover{background:#383838}.project-status-note{color:#9a4d2f;margin-bottom:24px;font-weight:600}.project-detail-panel{background:#ffffffd1;border:1px solid #2222220f;border-radius:18px;margin-bottom:18px;padding:22px}.project-detail-panel h2{text-align:left;margin-bottom:14px;font-size:1.15rem}.project-detail-panel p{color:#555}.experience-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:24px;max-width:1080px;margin:0 auto;display:grid}.experience-card{background:#fff;border:1px solid #0f172a14;border-radius:24px;padding:24px;box-shadow:0 14px 30px #0f172a0f,0 2px 8px #0f172a0a}.experience-card-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;display:flex}.experience-card h3{color:#18181b;margin-bottom:6px;font-size:1.15rem;line-height:1.35}.experience-company{color:#9a4d2f;font-weight:600}.experience-meta{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:8px;display:flex}.experience-meta span{color:#52525b;white-space:nowrap;background:#f5f5f4;border-radius:999px;justify-content:center;align-items:center;min-height:32px;padding:0 12px;font-size:.8rem;font-weight:600;display:inline-flex}.experience-points{color:#555;gap:12px;padding-left:20px;line-height:1.7;display:grid}.experience-points li::marker{color:#b06a56}.project-detail-list{color:#555;padding-left:18px}.project-detail-list li+li{margin-top:8px}.project-tech-list{flex-wrap:wrap;gap:10px;display:flex}.project-tech-list span{color:#4d4338;background:#efe8db;border-radius:999px;align-items:center;padding:8px 14px;font-size:.92rem;font-weight:500;display:inline-flex}.contact-section{text-align:center;background-color:#fdfcfb;padding:80px 20px}.contact-container{flex-wrap:wrap;justify-content:center;gap:60px;display:flex}.contact-info{text-align:left;flex:1;min-width:250px;max-width:350px}.contact-info .info-item{align-items:center;gap:15px;margin-bottom:25px;display:flex}.contact-info .info-item i{color:#ff6f61;min-width:35px;font-size:1.8rem}.contact-info .info-item h4{margin:0;font-size:1rem;font-weight:600}.contact-info .info-item a,.contact-info .info-item p{color:#333;margin:0;font-size:.95rem;text-decoration:none}.contact-form{flex-direction:column;flex:1;gap:20px;min-width:300px;max-width:500px;display:flex}.contact-form input,.contact-form textarea{border:1px solid #ccc;border-radius:10px;width:100%;padding:12px 15px;font-size:.95rem;transition:all .3s}.contact-form input:focus,.contact-form textarea:focus{border-color:#ff6f61;outline:none;box-shadow:0 0 8px #ff6f6133}.btn-send{color:#fff;cursor:pointer;background:#ff6f61;border:none;border-radius:12px;justify-content:space-between;align-items:center;gap:14px;min-width:190px;padding:12px 16px 12px 20px;font-size:1rem;font-weight:600;transition:background-color .25s,transform .25s;display:inline-flex}.btn-send i{margin-left:auto;font-size:1.05rem}.btn-send:hover{background:#ff5b4d;transform:translateY(-3px)}.btn-send:active{transform:translateY(-1px)}.contact-status{color:#4d4338;font-weight:600}.footer-section{color:#aaa;text-align:center;background-color:#111;padding:2rem}.footer-container{flex-direction:column;align-items:center;gap:1rem;display:flex}.footer-icons{gap:1rem;display:flex}.footer-icons .icon-secondary{color:#aaa;font-size:1.2rem;transition:color .3s,transform .3s}.footer-icons .icon-secondary:hover{color:#fff;transform:scale(1.2)}footer{text-align:center;color:#888;background:#fff;border-top:1px solid #eee;padding:60px 10%;font-size:.9rem}@media (max-width:992px){.hero-main-container{text-align:center;flex-direction:column-reverse;gap:2rem;padding:1rem}.hero-title-wrapper,.hero-image-wrapper{justify-content:center}.blob-shape{width:300px;height:300px}.project-detail-hero{grid-template-columns:1fr}}@media (max-width:768px){:root{--nav-height:78px}.logo img{height:48px}nav{padding:12px 5%}nav .nav-container{flex-wrap:nowrap;justify-content:space-between;gap:12px;position:relative}.nav-toggle{display:inline-flex}nav .nav-links{background:#fffffff5;border:1px solid #22222214;border-radius:18px;flex-direction:column;align-items:stretch;gap:8px;padding:14px;display:none;position:absolute;top:calc(100% + 10px);left:0;right:0;transform:none;box-shadow:0 18px 45px #00000014}nav.menu-open .nav-links{display:flex}nav .nav-links a{text-align:center;background:#f6f3ee;border-radius:12px;width:100%;padding:10px 14px;font-size:.95rem;line-height:1.2;display:block}nav .nav-links a:hover{background:#ebe3d3}.hero-vintage{padding:0 5%}section{padding:80px 5%}.projects-grid,.experience-grid{grid-template-columns:1fr}.experience-card-header{flex-direction:column}.experience-meta{align-items:flex-start}.skills-main-grid{grid-template-columns:1fr}.tech-grid{grid-template-columns:repeat(2,1fr)}.about-container{text-align:center;flex-direction:column;align-items:center}.about-info-grid{grid-template-columns:repeat(2,1fr)}.contact-container{flex-direction:column}.hero-left{flex-direction:column;align-items:center;gap:1rem}.hero-icons-vertical{flex-direction:row;gap:1rem}.hero-name{white-space:normal;font-size:2.5rem}.hero-description{font-size:1rem}.project-detail-page{padding:36px 6% 80px}.project-detail-panel{padding:18px}.timeline-horizontal{flex-direction:column;gap:2rem;padding:1rem 0}.timeline-horizontal:before{display:none}.timeline-item{justify-content:flex-start}.timeline-dot{margin-right:1rem;position:static;transform:none}.timeline-content{text-align:left;width:auto;position:static}.timeline-item:nth-child(odd) .timeline-content,.timeline-item:nth-child(2n) .timeline-content{top:auto;bottom:auto}}
