@font-face{font-family:Alegreya;src:url(/fonts/Alegreya-Regular.ttf) format("truetype");font-weight:400;font-style:normal}@font-face{font-family:Coiny;src:url(/fonts/Coiny-Regular.ttf) format("truetype");font-weight:400;font-style:normal}@font-face{font-family:Pretendard;src:url(/fonts/Pretendard-Regular.otf) format("opentype");font-weight:400;font-style:normal}*{margin:0;padding:0;box-sizing:border-box}:root{font-family:system-ui,-apple-system,Arial,sans-serif;line-height:1.5;font-weight:400}body{margin:0;min-width:320px;min-height:100vh;background-attachment:fixed}#root{min-height:100vh}a{color:inherit;text-decoration:none}button{font-family:inherit;border:none;background:none;cursor:pointer}h1,h2,h3,h4,h5,h6{margin:0}ul{list-style:none;padding:0;margin:0}.navigation{text-align:center;background:#fff;border-bottom:2px solid #000}.logo{color:#000;text-shadow:-2px -2px 0 #fff,2px -2px 0 #fff,-2px 2px 0 #fff,2px 2px 0 #fff;padding:2rem 0 calc(2rem - 4px) 0;font-family:Coiny;font-weight:700;letter-spacing:2px;display:flex;justify-content:center;align-items:center}.letter-container{box-shadow:inset 0 0 0 2px #0e0e0e;border:none;border-radius:20%;background-color:#e0e0e0;padding:0;cursor:pointer;width:clamp(35px,4vw,50px);height:clamp(35px,4vw,50px)}.letter-container span{margin:0;display:block;border-radius:20%;text-align:center;background-color:#fff;color:#0e0e0e;border:2px solid #0e0e0e;transform:translateY(-4px);font-size:clamp(1.2rem,2.2vw,28px)}.nav-links{list-style:none;padding:0;margin:0;display:flex;justify-content:center;gap:3rem;background-color:#f1f1f1;padding:1rem 0;border-top:2px solid #000}.nav-links li{margin:0}.nav-links a{text-decoration:none;color:#000;font-family:Alegreya;font-size:1.4rem;font-weight:600;transition:opacity .3s;position:relative;text-transform:lowercase}.nav-links a:hover{opacity:.6}.nav-links a.active{text-decoration:none;color:#000}.nav-links a.active:after{content:"";position:absolute;bottom:-8px;left:0;right:0;height:3px;background-color:#000}.home{min-height:calc(100vh - 180px);display:flex;flex-direction:column;align-items:center;padding:2rem;background:#fff;position:relative}.overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-image:url(/images/overlay.png);background-repeat:repeat;pointer-events:none;z-index:1}.profile-section{margin:1rem 0;position:relative;z-index:2}.profile-image{width:180px;height:180px;border-radius:20%;object-fit:cover;border:2px solid #000}.profile-image-shadow{width:180px;height:180px;border-radius:20%;border:2px solid #000;position:absolute;top:5px;z-index:-1;background-color:#a5a5a5}.social-links{display:flex;gap:1.5rem;justify-content:space-between;margin:1rem 0;position:relative;z-index:2;width:100%;max-width:400px}.social-links a{color:#000;transition:transform .2s,opacity .3s;display:flex;align-items:center;justify-content:center}.social-links a:hover{transform:scale(1.1);opacity:.7}.bio{font-family:Pretendard;color:#000;margin-bottom:1.2rem}.buttons{display:flex;flex-direction:column;gap:1.5rem;margin:2rem 0;width:100%;max-width:400px;position:relative;z-index:2}.action-button{box-shadow:inset 0 0 0 2px #0e0e0e;border:none;border-radius:11px;background-color:#e0e0e0;padding:0;cursor:pointer}.button-face{font-family:Pretendard;font-size:clamp(.875rem,1.1vw,.9625rem);margin:0;letter-spacing:.078125rem;text-transform:uppercase;display:block;border-radius:10px;padding:.75rem 1rem;text-align:center;background-color:#fff;color:#0e0e0e;border:2px solid #0e0e0e;transform:translateY(-4px)}.button-face:hover{background-color:#d7d7d7}.action-button:hover{background-color:#969696}.action-button:active .button-face{transform:translateY(-2px)}.footer{margin-top:auto;padding:2rem 0;font-size:.9rem;color:#333;position:relative;z-index:2}.about{min-height:calc(100vh - 180px);display:flex;flex-direction:column;padding:1.2rem;background:#fff;position:relative}.about-container{max-width:600px;width:100%;margin:0 auto;position:relative;z-index:2;padding:2rem 0}.about-card{background-color:#f8f8f8;border:3px solid #000;border-radius:20px;position:relative;box-shadow:0 12px #000;overflow:hidden}.card-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;position:relative;z-index:10}.language-toggle{font-size:1rem;font-family:Alegreya;font-weight:600}.language-toggle span{cursor:pointer;transition:opacity .3s}.language-toggle span:hover{opacity:.6}.language-toggle span.active{color:#000;font-weight:700;text-decoration:underline}.card-image-section{display:flex;justify-content:center;background:linear-gradient(to bottom,#fff,#f8f8f8)}.card-image-container{width:200px;height:200px;border-radius:20px;overflow:hidden;border:3px solid #000;box-shadow:0 6px #000}.card-image{width:100%;height:100%;object-fit:cover}.card-content{padding:1rem;background-color:#fff}.card-title{font-family:Alegreya;font-size:1.5rem;font-weight:700;text-align:center}.card-text{font-size:1.1rem;line-height:1.8;margin:0;color:#333}.card-text .paragraph{margin:0 0 1.2rem}.card-text .paragraph:last-of-type{margin-bottom:0}.card-text .paragraph br{display:block;content:"";margin:.3rem 0}.card-text a{color:#000;font-weight:700;text-decoration:underline;transition:opacity .3s ease}.card-text a:hover{opacity:.6}.tech{display:flex;flex-wrap:wrap;gap:.75rem;margin:1.5rem 0}.tech-tag{display:inline-block;padding:.5rem 1.25rem;background-color:#fff;border:2px solid #000;border-radius:25px;font-family:Alegreya;font-size:.95rem;font-weight:600;color:#000;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 3px #000;transition:transform .2s ease,box-shadow .2s ease}.tech-tag:hover{transform:translateY(-2px);box-shadow:0 5px #000}.projects{min-height:calc(100vh - 180px);display:flex;flex-direction:column;align-items:center;padding:2rem;background:#fff;position:relative}.projects-content{max-width:800px;margin:0 auto;width:100%;padding:2rem}.projects-grid{display:flex;flex-direction:column;gap:5rem;margin-bottom:2rem}.project-item{display:flex;align-items:center;gap:2rem;position:relative}.project-info{flex:1;position:relative}.project-tab{background-color:#fff;border:3px solid #000;padding:.75rem 2rem;font-size:1.2rem;font-weight:600;font-family:Pretendard;display:inline-block;position:absolute;top:-35px;left:10px;z-index:2;box-shadow:0 3px #000;border-radius:11px}.project-details{background-color:#fff;border:3px solid #000;padding:2rem;font-family:Pretendard;box-shadow:0 6px #000;border-radius:11px}.project-description{font-size:1rem;margin-bottom:.5rem;font-weight:500}.project-timeline{font-size:.9rem;color:#666}.project-image{flex-shrink:0;width:150px;height:150px;position:absolute;right:10px;top:-15px;border:2px solid black;border-radius:11px}.project-image img{width:100%;height:100%;object-fit:cover;border-radius:11px}@media(max-width:768px){.projects{padding:1rem}.projects-content{padding:3rem 1rem 1rem}.projects-grid{gap:5rem}.project-item{flex-direction:column;align-items:stretch;gap:1rem}.project-info{width:100%}.project-description,.project-timeline{width:calc(100% - 20px)}.project-tab{font-size:1rem;padding:.5rem 1.5rem;top:-25px}.project-details{padding:2.5rem 1rem 1.5rem;display:flex;justify-content:space-between;align-items:center}.project-image{width:80px;height:80px;margin:0 auto;position:relative;right:0;top:0}.project-description{font-size:.9rem}.project-timeline{font-size:.8rem}}.footer{margin-top:auto;padding:2rem 0;font-size:.9rem;color:#333;text-align:center}.not-yet{min-height:calc(100vh - 180px);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background:#fff;position:relative}.not-yet-container{max-width:600px;width:100%;margin:0 auto;position:relative;z-index:2}.not-yet-content{background-color:#f8f8f8;border:3px solid #000;border-radius:20px;padding:4rem 2rem;text-align:center;box-shadow:0 12px #000}.not-yet-title{font-family:Pretendard;font-size:2rem;margin:0 0 1.5rem;color:#000}.not-yet-message{font-family:Pretendard;font-size:1.2rem;line-height:1.8;color:#333;margin:0 0 2rem}.back-button{display:inline-block;text-decoration:none;box-shadow:inset 0 0 0 3px #000;border:none;border-radius:11px;background-color:#000;padding:0;cursor:pointer;transition:transform .1s}.back-button:hover{transform:translateY(-2px)}.back-button:active{transform:translateY(0)}.back-button .button-face{font-family:Pretendard;font-size:1rem;font-weight:600;margin:0;text-transform:uppercase;display:block;border-radius:10px;padding:1rem 2rem;text-align:center;background-color:#fff;color:#000;border:3px solid #000;transform:translateY(-6px);transition:transform .1s}.back-button:hover .button-face{transform:translateY(-8px)}.back-button:active .button-face{transform:translateY(-2px)}@media(max-width:768px){.not-yet{padding:1rem}.not-yet-content{padding:3rem 1.5rem}.not-yet-title{font-size:2rem}.not-yet-message{font-size:1rem}}.gf-container{max-width:900px;margin:0 auto;padding:20px}.gf-header{text-align:center;padding:60px 20px;background:#ffffffe6;border-radius:20px;margin-bottom:30px;box-shadow:0 4px 6px #0000001a}.gf-header h1{font-size:3em;color:#e91e63;margin-bottom:10px;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.gf-subtitle{font-size:1.3em;color:#4caf50;font-weight:500}.gf-tagline{font-size:1.1em;color:#666;margin-top:15px;font-style:italic}.gf-section{background:#fff;padding:40px;margin-bottom:30px;border-radius:15px;box-shadow:0 2px 8px #0000001a}.gf-section h2{color:#e91e63;font-size:2em;margin-bottom:20px;padding-bottom:10px;border-bottom:3px solid #ffc0cb}.gf-section h3{color:#4caf50;font-size:1.4em;margin:25px 0 15px}.gf-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-top:30px}.gf-feature-card{padding:25px;background:linear-gradient(135deg,#fff5f7,#f1f8f4);border-radius:12px;border-left:4px solid #e91e63;transition:transform .3s ease,box-shadow .3s ease}.gf-feature-card:hover{transform:translateY(-5px);box-shadow:0 4px 12px #00000026}.gf-feature-icon{font-size:2.5em;margin-bottom:10px}.gf-feature-title{font-size:1.2em;font-weight:600;color:#333;margin-bottom:10px}.gf-feature-desc{color:#666;font-size:.95em}.gf-system-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:25px;margin-top:20px}.gf-system-card{padding:20px;background:#f9f9f9;border-radius:10px;border-top:3px solid #4caf50}.gf-system-card h4{color:#e91e63;margin-bottom:12px;font-size:1.1em}.gf-section ul{list-style:none;padding-left:0}.gf-section li{padding:8px 0;color:#555}.gf-section li:before{content:"🌿 ";margin-right:8px}.gf-stats{display:flex;justify-content:space-around;flex-wrap:wrap;margin:30px 0;padding:20px;background:linear-gradient(135deg,#e8f5e9,#fff5f7);border-radius:12px}.gf-stat{text-align:center;padding:15px}.gf-stat-number{font-size:2.5em;font-weight:700;color:#e91e63}.gf-stat-label{color:#666;margin-top:5px}.gf-footer{text-align:center;padding:30px;color:#666;background:#fffc;border-radius:15px;margin-top:30px}.gf-badge{display:inline-block;padding:5px 12px;background:#4caf50;color:#fff;border-radius:20px;font-size:.85em;margin:5px}.gf-cta-button{display:inline-block;padding:15px 40px;background:linear-gradient(135deg,#e91e63,#f06292);color:#fff;text-decoration:none;border-radius:30px;font-size:1.1em;font-weight:600;margin:20px 10px;transition:transform .3s ease,box-shadow .3s ease;box-shadow:0 4px 15px #e91e634d}.gf-cta-button:hover{transform:translateY(-3px);box-shadow:0 6px 20px #e91e6366}.gf-cta-button.secondary{background:linear-gradient(135deg,#4caf50,#66bb6a);box-shadow:0 4px 15px #4caf504d}.gf-cta-button.secondary:hover{box-shadow:0 6px 20px #4caf5066}@media(max-width:768px){.gf-header h1{font-size:2em}.gf-subtitle{font-size:1.1em}.gf-section{padding:25px}.gf-features{grid-template-columns:1fr}.gf-stat-number{font-size:2em}}.grow-flower{min-height:calc(100vh - 180px);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background:#fff;position:relative}.grow-flower-container{max-width:600px;width:100%;margin:0 auto;position:relative;z-index:2}.grow-flower-content{background-color:#f8f8f8;border:3px solid #000;border-radius:20px;padding:4rem 2rem;text-align:center;box-shadow:0 12px #000}.grow-flower-title{font-family:Pretendard;font-size:2.5rem;margin:0 0 1.5rem;color:#000}.grow-flower-message{font-family:Pretendard;font-size:1.2rem;line-height:1.8;color:#333;margin:0 0 2rem}.store-buttons{display:flex;flex-direction:column;gap:1.5rem;align-items:center;font-family:Coiny}.store-button{display:inline-block;text-decoration:none;box-shadow:inset 0 0 0 3px #000;border:none;border-radius:11px;background-color:#000;padding:0;cursor:pointer;transition:transform .1s;width:100%;max-width:300px}.store-button:hover{transform:translateY(-2px)}.store-button:active{transform:translateY(0)}.store-button .button-face{font-size:1.1rem;font-weight:600;margin:0;display:block;border-radius:10px;padding:1rem 2rem;text-align:center;background-color:#fff;color:#000;border:3px solid #000;transform:translateY(-6px);transition:transform .1s}.apple-store .button-face{background-color:#000;color:#fff}.google-play .button-face{background-color:#4285f4;color:#fff;border-color:#4285f4}.store-button:hover .button-face{transform:translateY(-8px)}.store-button:active .button-face{transform:translateY(-2px)}.footer{margin-top:auto;padding:2rem 0;font-size:.9rem;color:#333;text-align:center;position:relative;z-index:2}@media(max-width:768px){.grow-flower{padding:1rem}.grow-flower-content{padding:3rem 1.5rem}.grow-flower-title{font-size:2rem}.grow-flower-message{font-size:1rem}.store-buttons{gap:1rem}}.app{min-height:100vh}
