@import"https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700;800;900&family=Fredoka:wght@400;500;600;700&display=swap";:root{font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;line-height:1.7;font-weight:500;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:700;color:var(--coral, #FF6B6B);text-decoration:none;transition:all .2s ease}a:hover{color:var(--coral-dark, #E85555)}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:Fredoka,Nunito,sans-serif;font-weight:700;line-height:1.2;color:var(--heading-color, #2D2D2D)}button{border-radius:9999px;border:3px solid #2D2D2D;padding:.6em 1.2em;font-size:1em;font-weight:700;font-family:Nunito,sans-serif;cursor:pointer;transition:all .2s ease;position:relative;background:white;box-shadow:3px 3px #2d2d2d}button:hover{transform:translate(-2px,-2px);box-shadow:5px 5px #2d2d2d}button:active{transform:translate(2px,2px);box-shadow:1px 1px #2d2d2d}button:focus,button:focus-visible{outline:3px solid var(--coral, #FF6B6B);outline-offset:2px}.navbar{background:var(--bg-white, #FFFFFF);border-bottom:4px solid var(--border-color, #2D2D2D);width:100%;padding:.9rem 2rem;display:flex;justify-content:space-between;align-items:center;position:fixed;top:0;left:0;z-index:100;box-sizing:border-box;transition:all .3s ease}.navbar-title a{font-size:1.6rem;font-weight:700;color:var(--coral, #FF6B6B);text-decoration:none;transition:all .2s ease;font-family:Fredoka,sans-serif;letter-spacing:.5px}.navbar-title a:hover{transform:scale(1.08) rotate(-2deg);display:inline-block;color:var(--coral-dark, #E85555)}.navbar-menu{display:flex;align-items:center;gap:.5rem}.navbar-menu a{color:var(--text-body, #4A4A4A);font-size:1.35rem;display:flex;align-items:center;justify-content:center;padding:.65rem;border-radius:14px;border:2.5px solid transparent;transition:all .25s cubic-bezier(.34,1.56,.64,1);position:relative;background:transparent}.navbar-menu a:hover{color:var(--coral, #FF6B6B);background-color:#ff6b6b1a;transform:translateY(-4px) scale(1.15);border-color:var(--coral, #FF6B6B)}.navbar-menu a.active{color:#fff;background:var(--coral, #FF6B6B);border-color:var(--border-color, #2D2D2D);box-shadow:2px 2px 0 var(--border-color, #2D2D2D)}@media screen and (max-width: 768px){.navbar{padding:.75rem 1rem;justify-content:center}.navbar-title{display:none}.navbar-menu{gap:.75rem}.navbar-menu a{font-size:1.5rem;padding:.7rem}}.page-section{padding:3rem 1.5rem;max-width:1200px;margin:0 auto}.section-title{font-size:clamp(2rem,5vw,2.8rem);font-weight:700;text-align:center;margin-bottom:3rem;color:var(--heading-color, #2D2D2D);font-family:var(--font-heading, "Fredoka");letter-spacing:.5px;position:relative;display:inline-block;width:100%}.section-title span{color:var(--coral, #FF6B6B);position:relative;display:inline-block}.section-title span:after{content:"";position:absolute;bottom:-4px;left:-4px;right:-4px;height:8px;background:var(--sunny, #FFD93D);border-radius:4px;z-index:-1;transform:rotate(-1deg)}.hero-container{display:flex;flex-direction:column-reverse;align-items:center;gap:2.5rem;padding-top:200px;text-align:center;min-height:calc(100vh - 200px);justify-content:center;position:relative}.hero-content h1{font-size:clamp(2.2rem,6vw,3.5rem);font-weight:700;line-height:1.15;color:var(--heading-color, #2D2D2D);margin-bottom:.75rem;font-family:var(--font-heading, "Fredoka");letter-spacing:0px}.hero-content h2{font-size:clamp(1.2rem,3.5vw,1.8rem);font-weight:700;margin:.75rem 0 1.25rem;color:var(--coral, #FF6B6B);font-family:var(--font-heading, "Fredoka");background:none;-webkit-background-clip:unset;-webkit-text-fill-color:unset;background-clip:unset}.hero-content p{font-size:1.1rem;line-height:1.8;max-width:620px;margin:0 auto 2rem;color:var(--text-body, #4A4A4A);font-weight:500}.hero-buttons{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem}.btn{padding:.9rem 2rem;border-radius:9999px;text-decoration:none;font-weight:800;font-size:1rem;font-family:var(--font-body, "Nunito");transition:all .2s cubic-bezier(.34,1.56,.64,1);border:3px solid var(--border-color, #2D2D2D);display:inline-flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;position:relative;overflow:hidden}.btn-primary{background:var(--coral, #FF6B6B);color:#fff;box-shadow:4px 4px 0 var(--border-color, #2D2D2D)}.btn-primary:hover{background:var(--coral-dark, #E85555);transform:translate(-2px,-2px);color:#fff;box-shadow:6px 6px 0 var(--border-color, #2D2D2D)}.btn-primary:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--border-color, #2D2D2D)}.btn-secondary{background:var(--bg-white, #FFFFFF);color:var(--text-dark, #2D2D2D);box-shadow:4px 4px 0 var(--border-color, #2D2D2D)}.btn-secondary:hover{background:var(--sunny, #FFD93D);color:var(--text-dark, #2D2D2D);transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--border-color, #2D2D2D)}.btn-secondary:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--border-color, #2D2D2D)}.hero-image-wrapper{display:flex;justify-content:center;align-items:center;position:relative}.hero-image-wrapper:before{content:"";position:absolute;top:-10px;right:-10px;bottom:-10px;left:-10px;border-radius:50%;border:5px dashed var(--coral, #FF6B6B);animation:spinDash 12s linear infinite;z-index:0}.hero-image{width:clamp(240px,45vw,300px);height:clamp(240px,45vw,300px);aspect-ratio:1 / 1;border-radius:50%;object-fit:cover;border:5px solid var(--border-color, #2D2D2D);box-shadow:6px 6px 0 var(--border-color, #2D2D2D);position:relative;z-index:1;background:var(--bg-white)}.skills-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;max-width:900px;margin:0 auto}.skill-card{background:var(--bg-white, #FFFFFF);border-radius:20px;padding:2rem 1.5rem;text-align:center;transition:all .25s cubic-bezier(.34,1.56,.64,1);border:3px solid var(--border-color, #2D2D2D);box-shadow:4px 4px 0 var(--border-color, #2D2D2D);position:relative;overflow:hidden}.skill-card:before{display:none}.skill-card:nth-child(1){background:#FFE8E8}.skill-card:nth-child(2){background:#E8F4FD}.skill-card:nth-child(3){background:#E8FFF0}.skill-card:nth-child(4){background:#F3E8FF}.skill-card:nth-child(5){background:#FFF8E1}.skill-card:hover{transform:translate(-3px,-6px);box-shadow:7px 9px 0 var(--border-color, #2D2D2D)}.skill-card svg{font-size:3.5rem;margin-bottom:1rem;transition:all .3s cubic-bezier(.34,1.56,.64,1);filter:none}.skill-card:hover svg{transform:scale(1.2) rotate(-8deg);filter:none}.skill-card h3{font-size:1.05rem;font-weight:800;color:var(--heading-color, #2D2D2D);margin:0;font-family:var(--font-body, "Nunito")}.projects-grid{display:grid;grid-template-columns:1fr;gap:2rem}.view-all-projects{text-align:center;margin-top:3rem}@media (min-width: 500px){.skills-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 768px){.page-section{padding:4.5rem 2rem}.skills-grid{grid-template-columns:repeat(5,1fr);gap:1.5rem}.projects-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 992px){.page-section{padding:6rem 2rem}.hero-container{flex-direction:row;justify-content:space-between;text-align:left;gap:5rem;padding-top:140px}.hero-content p{margin:0 0 2rem}.hero-buttons{justify-content:flex-start}.hero-image{width:clamp(320px,28vw,400px);height:clamp(320px,28vw,400px)}.projects-grid{grid-template-columns:repeat(3,1fr)}}.project-card{background:var(--card-bg, #FFFFFF);border-radius:20px;border:3px solid var(--border-color, #2D2D2D);overflow:hidden;display:flex;flex-direction:column;box-shadow:5px 5px 0 var(--border-color, #2D2D2D);transition:all .25s cubic-bezier(.34,1.56,.64,1);z-index:1;position:relative}.project-card:before{display:none}.project-card:hover{transform:translate(-4px,-6px);z-index:10;box-shadow:9px 11px 0 var(--border-color, #2D2D2D)}.project-card-image-wrapper{height:220px;overflow:hidden;position:relative;border-bottom:3px solid var(--border-color, #2D2D2D)}.project-card-image-wrapper:after{display:none}.project-card-image{width:100%;height:100%;object-fit:cover;transition:transform .4s cubic-bezier(.34,1.56,.64,1)}.project-card:hover .project-card-image{transform:scale(1.06)}.project-card-date{position:absolute;top:.75rem;right:.75rem;z-index:4;background:var(--sunny, #FFD93D);color:var(--text-dark, #2D2D2D);padding:.35rem .8rem;border-radius:9999px;font-size:.78rem;font-weight:800;border:2.5px solid var(--border-color, #2D2D2D);box-shadow:2px 2px 0 var(--border-color, #2D2D2D);font-family:var(--font-body, "Nunito")}.project-content{padding:1.5rem;flex-grow:1;display:flex;flex-direction:column;background:var(--card-bg, #FFFFFF);position:relative;z-index:1}.project-tags{display:flex;flex-wrap:wrap;gap:.45rem;min-height:70px;align-content:flex-start;margin-bottom:1rem}.tag{padding:.3rem .85rem;border-radius:9999px;font-size:.78rem;font-weight:800;border:2px solid var(--border-color, #2D2D2D);transition:all .2s cubic-bezier(.34,1.56,.64,1);color:var(--text-dark, #2D2D2D);font-family:var(--font-body, "Nunito");background:#FFE8E8}.tag:nth-child(2){background:#E8F4FD}.tag:nth-child(3){background:#E8FFF0}.tag:nth-child(4){background:#F3E8FF}.tag:nth-child(5){background:#FFF8E1}.tag:nth-child(6){background:#FFE0F0}.tag:nth-child(7){background:#E0F7FA}.tag:hover{transform:translateY(-3px) rotate(-2deg);box-shadow:2px 2px 0 var(--border-color, #2D2D2D)}.project-content h3{font-size:1.3rem;margin-bottom:.75rem;color:var(--heading-color, #2D2D2D);font-weight:700;line-height:1.3;font-family:var(--font-heading, "Fredoka")}.project-content p{color:var(--text-body, #4A4A4A);font-size:.95rem;margin-bottom:1.25rem;line-height:1.7;flex-grow:1;font-weight:500}.project-links{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:auto;padding-top:1.25rem;min-height:60px;align-items:center;border-top:3px dashed #E0E0E0}.project-card .btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.55rem 1.2rem;border-radius:9999px;font-size:.88rem;font-weight:800;text-decoration:none;cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden;font-family:var(--font-body, "Nunito")}.project-card .btn-primary{background:var(--coral, #FF6B6B);color:#fff;border:2.5px solid var(--border-color, #2D2D2D);box-shadow:3px 3px 0 var(--border-color, #2D2D2D)}.project-card .btn-primary:hover{background:var(--coral-dark, #E85555);color:#fff;transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--border-color, #2D2D2D)}.project-card .btn-secondary{background:var(--bg-white, #FFFFFF);color:var(--text-dark, #2D2D2D);border:2.5px solid var(--border-color, #2D2D2D);box-shadow:3px 3px 0 var(--border-color, #2D2D2D)}.project-card .btn-secondary:hover{background:var(--sunny, #FFD93D);color:var(--text-dark, #2D2D2D);transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--border-color, #2D2D2D)}.project-card .btn-secondary svg,.project-card .btn-secondary span{position:relative;z-index:1}.certificate-card{background:var(--card-bg, #FFFFFF);border-radius:20px;overflow:hidden;display:flex;flex-direction:column;box-shadow:5px 5px 0 var(--border-color, #2D2D2D);transition:all .25s cubic-bezier(.34,1.56,.64,1);z-index:1;position:relative;border:3px solid var(--border-color, #2D2D2D)}.certificate-card:before{display:none}.certificate-card:hover{transform:translate(-4px,-6px);z-index:10;box-shadow:9px 11px 0 var(--border-color, #2D2D2D)}.certificate-card-image-wrapper{height:220px;overflow:hidden;position:relative;border-bottom:3px solid var(--border-color, #2D2D2D)}.certificate-card-image-wrapper:after{display:none}.certificate-card-image{width:100%;height:100%;object-fit:cover;transition:transform .4s cubic-bezier(.34,1.56,.64,1)}.certificate-card:hover .certificate-card-image{transform:scale(1.06)}.certificate-card-date{position:absolute;top:.75rem;right:.75rem;z-index:4;background:var(--mint, #6BCB77);color:#fff;padding:.35rem .8rem;border-radius:9999px;font-size:.78rem;font-weight:800;border:2.5px solid var(--border-color, #2D2D2D);box-shadow:2px 2px 0 var(--border-color, #2D2D2D);font-family:var(--font-body, "Nunito")}.certificate-content{padding:1.5rem;flex-grow:1;display:flex;flex-direction:column;position:relative;z-index:1}.certificate-course{color:var(--mint-dark, #55B563);font-size:.82rem;font-weight:800;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.06em;font-family:var(--font-body, "Nunito");background:none;-webkit-background-clip:unset;-webkit-text-fill-color:unset;background-clip:unset}.certificate-content h3{font-size:1.3rem;margin-bottom:.75rem;color:var(--heading-color, #2D2D2D);font-weight:700;line-height:1.3;font-family:var(--font-heading, "Fredoka")}.certificate-content p{color:var(--text-body, #4A4A4A);font-size:.95rem;margin-bottom:1.25rem;line-height:1.7;flex-grow:1;font-weight:500}.certificate-list{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:auto;padding-top:1.25rem;border-top:3px dashed #E0E0E0}.list-item{background:#E8FFF0;color:var(--mint-dark, #55B563);padding:.3rem .85rem;border-radius:9999px;font-size:.78rem;font-weight:800;transition:all .25s cubic-bezier(.34,1.56,.64,1);border:2px solid var(--mint, #6BCB77);font-family:var(--font-body, "Nunito")}.list-item:hover{background:var(--mint, #6BCB77);color:#fff;transform:translateY(-3px) rotate(-2deg);box-shadow:2px 2px 0 var(--border-color, #2D2D2D);border-color:var(--border-color, #2D2D2D)}.project-page-container{padding:120px 2rem 4rem}.project-page-header{max-width:800px;margin:0 auto 4rem;text-align:center}.project-page-title{font-size:clamp(2.2rem,5vw,3rem);font-weight:700;margin-bottom:1rem;color:var(--heading-color, #2D2D2D);font-family:var(--font-heading, "Fredoka")}.project-page-title span{color:var(--coral, #FF6B6B);position:relative}.project-page-title span:after{content:"";position:absolute;bottom:-2px;left:-4px;right:-4px;height:8px;background:var(--sunny, #FFD93D);border-radius:4px;z-index:-1;transform:rotate(-1deg)}.project-page-subtitle{font-size:1.1rem;line-height:1.7;color:var(--text-body, #4A4A4A);max-width:650px;margin:0 auto;font-weight:500}.projects-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;max-width:1200px;margin:0 auto}@media (min-width: 768px){.projects-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 992px){.projects-grid{grid-template-columns:repeat(3,1fr)}}.profile-page-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:120px 1rem 2rem;position:relative}.profile-container{width:100%;max-width:500px;margin:0 auto}.profile-card{background:var(--bg-white, #FFFFFF);border-radius:28px;border:3px solid var(--border-color, #2D2D2D);padding:3.5rem;text-align:center;display:flex;flex-direction:column;align-items:center;box-shadow:6px 6px 0 var(--border-color, #2D2D2D);position:relative;overflow:visible;transition:all .25s cubic-bezier(.34,1.56,.64,1)}.profile-card:hover{transform:translate(-3px,-5px);box-shadow:9px 11px 0 var(--border-color, #2D2D2D)}.profile-image-wrapper{width:170px;height:170px;border-radius:50%;margin-top:-105px;margin-bottom:1.75rem;border:5px solid var(--border-color, #2D2D2D);box-shadow:5px 5px 0 var(--border-color, #2D2D2D);transition:all .3s cubic-bezier(.34,1.56,.64,1);position:relative;background:var(--bg-white);overflow:hidden}.profile-image-wrapper:before{content:"";position:absolute;top:-12px;right:-12px;bottom:-12px;left:-12px;border-radius:50%;border:4px dashed var(--coral, #FF6B6B);animation:spinDash 12s linear infinite;z-index:-1}@keyframes spinDash{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.profile-image-wrapper:hover{transform:scale(1.08) rotate(-3deg)}.profile-image{width:100%;height:100%;object-fit:cover;border-radius:50%;position:relative;z-index:1}.profile-name{font-size:2.2rem;font-weight:700;color:var(--heading-color, #2D2D2D);line-height:1.2;margin:0;font-family:var(--font-heading, "Fredoka")}.profile-title{font-size:1.15rem;font-weight:700;color:var(--coral, #FF6B6B);margin:.75rem 0 1.75rem;font-family:var(--font-heading, "Fredoka");background:none;-webkit-background-clip:unset;-webkit-text-fill-color:unset;background-clip:unset}.about-me-text{font-size:1rem;line-height:1.8;color:var(--text-body, #4A4A4A);margin-bottom:2.25rem;max-width:90%;font-weight:500}.profile-social-links{display:flex;gap:1rem;margin-bottom:2.25rem}.profile-social-links a{color:var(--text-body, #4A4A4A);font-size:1.6rem;transition:all .25s cubic-bezier(.34,1.56,.64,1);display:flex;align-items:center;justify-content:center;padding:.75rem;border-radius:50%;border:3px solid var(--border-color, #2D2D2D);background:var(--bg-white);box-shadow:3px 3px 0 var(--border-color, #2D2D2D);width:52px;height:52px}.profile-social-links a:hover{transform:translate(-2px,-3px) scale(1.1);box-shadow:5px 6px 0 var(--border-color, #2D2D2D)}.profile-social-links a.linkedin:hover{color:#0077b5;background:#E3F2FD;border-color:#0077b5}.profile-social-links a.github:hover{color:#24292e;background:#F5F5F5;border-color:#24292e}.profile-social-links a.instagram:hover{color:#e4405f;background:#FFE8EF;border-color:#e4405f}.profile-cta-btn{display:inline-flex;align-items:center;gap:.75rem;background:var(--sky-blue, #4ECDC4);color:#fff;font-weight:800;padding:1rem 2.5rem;border-radius:9999px;text-decoration:none;transition:all .25s cubic-bezier(.34,1.56,.64,1);border:3px solid var(--border-color, #2D2D2D);box-shadow:4px 4px 0 var(--border-color, #2D2D2D);font-family:var(--font-body, "Nunito");font-size:1rem;position:relative;overflow:hidden}.profile-cta-btn:before{display:none}.profile-cta-btn:hover{transform:translate(-2px,-3px);color:#fff;box-shadow:6px 7px 0 var(--border-color, #2D2D2D);background:var(--sky-blue-dark, #3BB5AD)}.profile-cta-btn:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--border-color, #2D2D2D)}.profile-cta-btn svg,.profile-cta-btn span{position:relative;z-index:1}@media (max-width: 600px){.profile-page-wrapper{align-items:flex-start;padding-top:100px}.profile-card{padding:3rem 2rem}.profile-image-wrapper{width:150px;height:150px;margin-top:-95px}.profile-name{font-size:1.9rem}.about-me-text{font-size:.95rem;max-width:100%}.profile-social-links{gap:.75rem}.profile-social-links a{font-size:1.4rem;width:48px;height:48px}}.project-detail-wrapper{min-height:100vh;padding:0}.project-detail-container{max-width:1150px;margin:0 auto;padding:140px 1.5rem 4rem}.detail-page-header{text-align:center;margin-bottom:4rem}.detail-page-title{font-size:clamp(2.2rem,8vw,3.5rem);font-weight:700;line-height:1.15;color:var(--coral, #FF6B6B);margin-bottom:1.25rem;font-family:var(--font-heading, "Fredoka");background:none;-webkit-background-clip:unset;-webkit-text-fill-color:unset;background-clip:unset}.detail-page-date{color:var(--text-body, #4A4A4A);margin-bottom:1.75rem;font-size:1rem;font-weight:700}.detail-page-tags{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.detail-page-tag{background:#FFE8E8;color:var(--text-dark, #2D2D2D);padding:.45rem 1rem;border-radius:9999px;font-size:.85rem;font-weight:800;border:2px solid var(--border-color, #2D2D2D);transition:all .25s cubic-bezier(.34,1.56,.64,1);font-family:var(--font-body, "Nunito")}.detail-page-tag:nth-child(2){background:#E8F4FD}.detail-page-tag:nth-child(3){background:#E8FFF0}.detail-page-tag:nth-child(4){background:#F3E8FF}.detail-page-tag:nth-child(5){background:#FFF8E1}.detail-page-tag:nth-child(6){background:#FFE0F0}.detail-page-tag:hover{transform:translateY(-3px) rotate(-2deg);box-shadow:2px 2px 0 var(--border-color, #2D2D2D)}.detail-page-content{display:grid;grid-template-columns:1fr;gap:3rem;align-items:flex-start}.section-subtitle{font-size:1.4rem;font-weight:700;color:var(--heading-color, #2D2D2D);margin-bottom:1.25rem;font-family:var(--font-heading, "Fredoka")}.detail-page-description{background:var(--bg-white, #FFFFFF);padding:2.5rem;border-radius:20px;border:3px solid var(--border-color, #2D2D2D);box-shadow:5px 5px 0 var(--border-color, #2D2D2D)}.detail-page-description p{font-size:1.05rem;line-height:1.8;color:var(--text-body, #4A4A4A);margin:0;text-align:justify;font-weight:500}.detail-page-image-wrapper{border-radius:20px;overflow:hidden;box-shadow:5px 5px 0 var(--border-color, #2D2D2D);transition:all .25s cubic-bezier(.34,1.56,.64,1);position:relative;border:3px solid var(--border-color, #2D2D2D)}.detail-page-image-wrapper:before{display:none}.detail-page-image-wrapper:hover{transform:translate(-3px,-4px);box-shadow:8px 9px 0 var(--border-color, #2D2D2D)}.detail-page-image{width:100%;height:auto;display:block;cursor:zoom-in;transition:transform .3s ease}.detail-page-image-wrapper:hover .detail-page-image{transform:scale(1.02)}.features-section,.documentation-section{margin-top:4rem;padding-top:4rem;border-top:4px dashed #E0E0E0}.section-heading{font-size:clamp(1.8rem,5vw,2.4rem);font-weight:700;color:var(--heading-color, #2D2D2D);text-align:center;margin-bottom:1rem;font-family:var(--font-heading, "Fredoka")}.documentation-description{text-align:center;color:var(--text-body, #4A4A4A);font-size:1rem;line-height:1.7;max-width:700px;margin:0 auto 3rem;font-weight:500}.features-grid{display:grid;gap:1.25rem;grid-template-columns:1fr;margin-top:2.5rem}.feature-card{background:var(--bg-white, #FFFFFF);padding:1.5rem 1.75rem;border-radius:16px;border:3px solid var(--border-color, #2D2D2D);box-shadow:4px 4px 0 var(--border-color, #2D2D2D);transition:all .25s cubic-bezier(.34,1.56,.64,1);display:flex;align-items:center;gap:1rem}.feature-card:nth-child(odd){background:#FFF8E1}.feature-card:nth-child(2n){background:#E8FFF0}.feature-card:hover{transform:translate(-2px,-4px);box-shadow:6px 8px 0 var(--border-color, #2D2D2D)}.feature-icon{flex-shrink:0;width:32px;height:32px;border-radius:50%;background:var(--coral, #FF6B6B);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1rem;border:2px solid var(--border-color, #2D2D2D);box-shadow:2px 2px 0 var(--border-color, #2D2D2D)}.feature-card p{font-size:1rem;line-height:1.7;color:var(--text-body, #4A4A4A);margin:0;flex:1;font-weight:600}.documentation-grid{display:grid;gap:2rem;grid-template-columns:1fr;margin-top:2.5rem}.documentation-image-wrapper{border-radius:16px;overflow:hidden;box-shadow:4px 4px 0 var(--border-color, #2D2D2D);position:relative;transition:all .25s cubic-bezier(.34,1.56,.64,1);border:3px solid var(--border-color, #2D2D2D)}.documentation-image-wrapper:hover{transform:translate(-3px,-4px);box-shadow:7px 8px 0 var(--border-color, #2D2D2D)}.documentation-image{width:100%;height:100%;display:block;object-fit:cover;aspect-ratio:16 / 10;cursor:zoom-in;transition:transform .3s ease}.documentation-image-wrapper:hover .documentation-image{transform:scale(1.04)}.documentation-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:rgba(255,107,107,.85);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.documentation-overlay span{color:#fff;font-weight:800;font-size:1.1rem;font-family:var(--font-heading, "Fredoka");transform:scale(.9);transition:transform .3s ease}.documentation-image-wrapper:hover .documentation-overlay{opacity:1}.documentation-image-wrapper:hover .documentation-overlay span{transform:scale(1)}.detail-back-button-wrapper{text-align:center;margin-top:4rem}.image-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#000000e0;display:flex;flex-direction:column;z-index:1000;padding:4rem 2rem;cursor:zoom-out;overflow-y:auto}.image-modal-content{max-width:95vw;height:auto;border-radius:12px;border:4px solid white;margin:auto}@media (min-width: 640px){.features-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 768px){.documentation-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 992px){.detail-page-content{grid-template-columns:1.2fr 1fr;gap:3.5rem}.documentation-grid{grid-template-columns:repeat(3,1fr)}}.chatbot-container{position:fixed;bottom:2rem;right:2rem;z-index:1000}.chatbot-toggle-btn{background-color:var(--coral, #FF6B6B);color:#fff;border:3px solid var(--border-color, #2D2D2D);width:60px;height:60px;border-radius:50%;display:flex;justify-content:center;align-items:center;cursor:pointer;box-shadow:4px 4px 0 var(--border-color, #2D2D2D);transition:all .25s cubic-bezier(.34,1.56,.64,1)}.chatbot-toggle-btn:hover{transform:translate(-2px,-3px) scale(1.08);box-shadow:6px 7px 0 var(--border-color, #2D2D2D)}.chatbot-toggle-btn:active{transform:translate(1px,1px);box-shadow:2px 2px 0 var(--border-color, #2D2D2D)}.chat-window{background-color:var(--bg-white, #FFFFFF);width:370px;height:550px;border-radius:24px;box-shadow:6px 6px 0 var(--border-color, #2D2D2D);display:flex;flex-direction:column;overflow:hidden;position:absolute;bottom:80px;right:0;border:3px solid var(--border-color, #2D2D2D)}.chat-header{background-color:var(--coral, #FF6B6B);padding:1rem 1.25rem;display:flex;justify-content:space-between;align-items:center;color:#fff;flex-shrink:0;border-bottom:3px solid var(--border-color, #2D2D2D)}.chat-header h3{margin:0;font-size:1.1rem;font-weight:700;font-family:var(--font-heading, "Fredoka");color:#fff}.close-btn{background:none;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.5rem;opacity:.9;transition:all .2s ease;box-shadow:none;padding:.3rem}.close-btn:hover{opacity:1;transform:scale(1.2) rotate(90deg);box-shadow:none}.chat-body{flex-grow:1;padding:1.25rem;overflow-y:auto;display:flex;flex-direction:column;gap:.75rem;background-color:var(--bg-cream, #FFF9EC)}.chat-body::-webkit-scrollbar{width:6px}.chat-body::-webkit-scrollbar-thumb{background:#D4D4D4;border-radius:3px}.message{display:flex;max-width:85%}.message.user{align-self:flex-end}.message.bot{align-self:flex-start}.message>p,.bot-message-content{padding:.8rem 1.1rem;border-radius:16px;line-height:1.6;margin:0;font-size:.93rem;word-wrap:break-word;font-weight:600;font-family:var(--font-body, "Nunito")}.message.user>p{background-color:var(--coral, #FF6B6B);color:#fff;border-bottom-right-radius:6px;border:2px solid var(--border-color, #2D2D2D);box-shadow:2px 2px 0 var(--border-color, #2D2D2D)}.message.bot .bot-message-content,.message.bot>p{background-color:var(--bg-white, #FFFFFF);color:var(--text-body, #4A4A4A);border-bottom-left-radius:6px;border:2px solid var(--border-color, #2D2D2D);box-shadow:2px 2px 0 var(--border-color, #2D2D2D)}.chat-footer{padding:1rem;background-color:var(--bg-white, #FFFFFF);display:flex;gap:.75rem;align-items:center;flex-shrink:0;border-top:3px solid var(--border-color, #2D2D2D)}.chat-footer input{flex-grow:1;background-color:var(--bg-cream, #FFF9EC);border:2.5px solid var(--border-color, #2D2D2D);border-radius:9999px;padding:.7rem 1.2rem;color:var(--text-dark, #2D2D2D);font-size:.93rem;font-family:var(--font-body, "Nunito");font-weight:600}.chat-footer input:focus{outline:none;border-color:var(--coral, #FF6B6B);box-shadow:0 0 0 3px #ff6b6b26}.chat-footer input::placeholder{color:#aaa;font-weight:500}.send-btn{background-color:var(--coral, #FF6B6B);border:2.5px solid var(--border-color, #2D2D2D);color:#fff;border-radius:50%;width:44px;height:44px;display:flex;justify-content:center;align-items:center;cursor:pointer;flex-shrink:0;transition:all .2s cubic-bezier(.34,1.56,.64,1);box-shadow:2px 2px 0 var(--border-color, #2D2D2D)}.send-btn:hover{transform:translate(-1px,-2px) scale(1.08);box-shadow:3px 4px 0 var(--border-color, #2D2D2D)}.send-btn:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--border-color, #2D2D2D)}.send-btn:disabled{background-color:#d4d4d4;border-color:#b0b0b0;transform:none;cursor:not-allowed;box-shadow:2px 2px #b0b0b0}.typing-indicator{display:flex;align-items:center;padding:.75rem 1rem}.typing-indicator span{height:8px;width:8px;background-color:var(--coral, #FF6B6B);border-radius:50%;display:inline-block;margin:0 2px;animation:wave 1.3s linear infinite}.typing-indicator span:nth-child(2){animation-delay:-1.1s}.typing-indicator span:nth-child(3){animation-delay:-.9s}@keyframes wave{0%,60%,to{transform:initial}30%{transform:translateY(-10px)}}@media (max-width: 768px){.chatbot-container{bottom:1rem;right:1rem}.chat-window{width:90vw;max-width:370px;height:70vh;max-height:550px;bottom:75px}}:root{--font-body: "Nunito", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-heading: "Fredoka", "Nunito", sans-serif;--bg-cream: #FFF9EC;--bg-white: #FFFFFF;--bg-pattern: #FFF3D6;--coral: #FF6B6B;--coral-dark: #E85555;--sky-blue: #4ECDC4;--sky-blue-dark: #3BB5AD;--lavender: #A78BFA;--lavender-dark: #8B6FE0;--mint: #6BCB77;--mint-dark: #55B563;--sunny: #FFD93D;--sunny-dark: #F0C830;--peach: #FFB085;--bubblegum: #FF85B3;--text-dark: #2D2D2D;--text-body: #4A4A4A;--text-light: #6B6B6B;--heading-color: #2D2D2D;--border-color: #2D2D2D;--border-light: #E0E0E0;--cartoon-shadow: 4px 4px 0px #2D2D2D;--cartoon-shadow-sm: 3px 3px 0px #2D2D2D;--cartoon-shadow-lg: 6px 6px 0px #2D2D2D;--cartoon-shadow-hover: 6px 6px 0px #2D2D2D;--cartoon-shadow-active: 2px 2px 0px #2D2D2D;--card-bg: #FFFFFF;--card-border: 3px solid var(--border-color);--card-radius: 20px;--component-bg: #FFFFFF;--component-border: #E0E0E0;--navbar-bg: #FFFFFF;--icon-color-default: #6B6B6B;--icon-color-hover: var(--coral);--icon-bg-active: rgba(255, 107, 107, .15);--tag-text: #2D2D2D;--tag-border: transparent;--primary-btn-text: #FFFFFF;--btn-secondary-bg: #F5F5F5;--btn-secondary-text: #2D2D2D;--btn-secondary-border: #2D2D2D;--btn-secondary-bg-hover: #EDEDED;--btn-secondary-text-hover: #2D2D2D;--cert-course-text: var(--mint-dark);--cert-list-item-bg: rgba(107, 203, 119, .12);--cert-list-item-text: var(--mint-dark);--title-color: #2D2D2D;--card-date-bg: var(--sunny);--card-date-text: #2D2D2D;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: 12px;--radius-md: 16px;--radius-lg: 20px;--radius-xl: 28px;--radius-full: 9999px}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-body);background-color:var(--bg-cream);color:var(--text-body);position:relative;min-height:100vh;line-height:1.7;font-size:16px;font-weight:500;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background-image:radial-gradient(circle,#E8DFC7 1px,transparent 1px);background-size:28px 28px;opacity:.4;z-index:-1;pointer-events:none}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:700;line-height:1.2;color:var(--heading-color)}h1{font-size:3.2em;line-height:1.1}a{font-weight:600;color:var(--coral);text-decoration:none;transition:color .3s ease}a:hover{color:var(--coral-dark)}button{border-radius:var(--radius-full);border:3px solid var(--border-color);padding:.6em 1.2em;font-size:1em;font-weight:700;font-family:var(--font-body);cursor:pointer;transition:all .2s ease;position:relative;background:var(--bg-white);box-shadow:var(--cartoon-shadow-sm)}button:hover{transform:translate(-2px,-2px);box-shadow:var(--cartoon-shadow-hover)}button:active{transform:translate(2px,2px);box-shadow:var(--cartoon-shadow-active)}button:focus,button:focus-visible{outline:3px solid var(--coral);outline-offset:2px}
