:root{--bg: #FFF9DB;--bg-2: #FFF3BF;--text: #222;--muted: rgba(0,0,0,.65);--glass: rgba(255,255,255,.55);--glass-strong: rgba(255,255,255,.7);--border: rgba(0,0,0,.1);--shadow: 0 12px 32px rgba(0,0,0,.08);--radius: 22px;--radius-pill: 999px;--container: 1050px;--font-ui: "Fredoka", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;--font-title: "Fredoka One", "Fredoka", system-ui, sans-serif}*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:var(--font-ui);color:var(--text);background:radial-gradient(1000px 600px at 50% 0%,var(--bg-2),var(--bg))}a{color:inherit;text-decoration:none}a:hover{text-decoration:underline}::selection{background:#ffe0668c}#app{width:100%;display:block}.page-section{padding:92px 18px}.page-section--hero{min-height:92vh;display:grid;place-items:center;padding-top:120px}.container{width:min(var(--container),calc(100% - 36px));margin:0 auto}.section-title{font-family:var(--font-title);font-size:clamp(1.6rem,2.8vw,2.1rem);margin:0 0 14px}.section-sub{color:var(--muted);margin:0 0 26px;line-height:1.55}@media(max-width:600px){.page-section{padding:78px 14px}.page-section--hero{padding-top:110px}}.home-water-layer{position:absolute;inset:0;z-index:0;pointer-events:none}.page-section--hero .container{position:relative;z-index:1}.hero-frame{place-self:center;width:min(400px,100%);height:min(400px,100%);padding:clamp(18px,3vw,28px);text-align:center;align-items:center}.hero-title{font-family:var(--font-title);font-size:clamp(2.4rem,6.2vw,4rem);line-height:.98;margin:0;letter-spacing:.3px}.hero-title .line-break{display:block}.hero-note{margin:14px 0 0;color:var(--muted);line-height:1.55}.about-profile{display:flex;align-items:flex-start;gap:20px;flex-wrap:wrap;margin-top:14px}.about-photo{flex:0 0 240px;max-width:240px;min-width:180px}.about-photo img{width:100%;height:auto;aspect-ratio:6/9;object-fit:cover;border-radius:var(--radius);display:block}.about-text{flex:1 1 360px;display:grid;gap:16px}@media(max-width:860px){.about-profile{flex-direction:column}.about-profile,.about-text{width:100%}.about-photo{max-width:100%;flex:1 1 auto}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:10px 14px;border-radius:var(--radius-pill);border:1px solid var(--border);background:#ffffff8c;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);cursor:pointer;-webkit-user-select:none;user-select:none}.btn:hover{background:#ffffffad}.btn:active{transform:translateY(1px)}.btn--code{background:#ffffff59}.btn--code:hover{background:#ffffffe6}.btn--details{background:linear-gradient(180deg,#fff9db,#fff3bf);box-shadow:inset 0 0 0 1px var(--border);font-weight:500}.btn--details:hover{background:#fff9}.glass{background:var(--glass);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.glass--strong{background:var(--glass-strong)}.card{padding:22px}.pill{border-radius:var(--radius-pill)}@media(pointer:fine){body,a,button,input{cursor:none!important}}.custom-cursor{position:fixed;top:0;left:0;width:12px;height:12px;margin:-6px 0 0 -6px;border-radius:50%;background:var(--text);pointer-events:none;z-index:99999;transform:translate3d(-100px,-100px,0);will-change:transform,width,height;transition:width .2s cubic-bezier(.16,1,.3,1),height .2s cubic-bezier(.16,1,.3,1),margin .2s cubic-bezier(.16,1,.3,1),background .2s ease,border .2s ease,backdrop-filter .2s ease}.custom-cursor.is-hovering{width:54px;height:54px;margin:-27px 0 0 -27px;background:#ffffff0d;border:1.5px solid rgba(0,0,0,.15);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.custom-cursor.is-clicked{width:28px;height:28px;margin:-14px 0 0 -14px;background:#ffffff80;border:2px solid rgba(255,255,255,.9);box-shadow:0 0 0 8px #fff3}.nav-island{position:fixed;top:16px;left:50%;transform:translate(-50%);z-index:10;display:flex;align-items:center;gap:12px;padding:10px 14px}.nav-link{font-weight:600;padding:8px 10px;border-radius:var(--radius-pill)}.nav-link:hover{background:#ffffff8c;text-decoration:none}.nav-link--active{background:#ffffffbf;box-shadow:inset 0 0 0 1px var(--border)}.detail-header{margin-bottom:32px;animation:fadeUp .6s cubic-bezier(.16,1,.3,1) forwards}.detail-title{font-family:var(--font-title);font-size:clamp(2rem,5vw,3rem);margin:0 0 12px;line-height:1.1;color:var(--text)}.detail-meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.detail-year{font-weight:600;color:var(--muted);background:#ffffff80;padding:4px 12px;border-radius:99px;border:1px solid var(--border)}.detail-content{display:flex;flex-direction:column;gap:48px;animation:fadeUp .6s cubic-bezier(.16,1,.3,1) forwards;animation-delay:.1s;opacity:0}.detail-text h3{font-family:var(--font-title);font-size:1.4rem;margin-top:0}.detail-text p{font-size:1.05rem;line-height:1.6;color:#000c;max-width:800px}.project-pagination{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:80px;padding-top:40px;border-top:1px solid var(--border)}.pagination-btn{position:relative;display:flex;flex-direction:column;justify-content:center;padding:40px;border-radius:16px;background:#ffffff4d;border:1px solid var(--border);overflow:hidden;text-decoration:none;color:var(--text);transition:transform .4s cubic-bezier(.16,1,.3,1),border-color .4s ease;min-height:220px}.pagination-btn:hover{text-decoration:none;transform:translateY(-6px);border-color:#00000026}.pagination-next{align-items:flex-end;text-align:right}.pagination-prev{align-items:flex-start;text-align:left}.pagination-content{position:relative;z-index:2;transition:transform .5s cubic-bezier(.16,1,.3,1)}.pagination-prev:hover .pagination-content{transform:translate(12px);color:#faebd7}.pagination-next:hover .pagination-content{transform:translate(-12px);color:#faebd7}.pagination-label{font-size:.85rem;font-weight:700;color:var(--muted);margin-bottom:8px;display:block;text-transform:uppercase;letter-spacing:1.5px}.pagination-title{font-family:var(--font-title);font-size:clamp(1.4rem,2.5vw,2.2rem);line-height:1.2}.pagination-bg{position:absolute;inset:0;z-index:1;opacity:0;transform:scale(.9);transition:opacity .5s ease,transform .6s cubic-bezier(.16,1,.3,1);background:#000}.pagination-bg img{width:100%;height:100%;object-fit:cover;opacity:.35;filter:saturate(1.2)}.pagination-btn:hover .pagination-bg{opacity:1;transform:scale(1)}@media(max-width:768px){.project-pagination{grid-template-columns:1fr;gap:12px}.pagination-btn{min-height:160px;padding:30px 24px}.pagination-next{align-items:flex-start;text-align:left}.pagination-next:hover .pagination-content{transform:translate(12px)}}.projects-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px 24px;margin-top:40px}.project-card{display:flex;flex-direction:column;gap:12px;text-decoration:none;color:inherit;animation:fadeUp .6s cubic-bezier(.16,1,.3,1) forwards;opacity:0;transform:translateY(20px);animation-delay:calc(var(--stagger) * .08s);transition:transform .4s cubic-bezier(.16,1,.3,1)}.project-card:hover{text-decoration:none;transform:translateY(-6px)}.project-cover-wrapper{width:100%;aspect-ratio:4 / 3;border-radius:12px;overflow:hidden;background-color:#ffffff4d;border:1px solid var(--border);position:relative;box-shadow:0 4px 12px #00000008;transition:box-shadow .4s cubic-bezier(.16,1,.3,1),border-radius .4s ease}.project-cover-img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.16,1,.3,1)}.project-shine{position:absolute;top:0;left:-150%;width:50%;height:100%;background:linear-gradient(to right,#fff0,#fff6,#fff0);transform:skew(-25deg);transition:left .7s cubic-bezier(.16,1,.3,1);z-index:2}.project-card:hover .project-cover-wrapper{box-shadow:0 16px 32px #00000014;border-radius:8px}.project-card:hover .project-cover-img{transform:scale(1.08) rotate(1.5deg)}.project-card:hover .project-shine{left:150%}.project-info{display:flex;flex-direction:column;gap:6px;padding:0 2px}.project-header{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.project-title{font-family:var(--font-title);font-size:1.15rem;margin:0;line-height:1.2}.project-year{font-size:.8rem;color:var(--muted);font-weight:500;flex-shrink:0}.project-short{color:var(--muted);margin:0;font-size:.9rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-tech{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.tech-pill{font-size:.7rem;font-weight:600;padding:3px 8px;border-radius:99px;background:#0000000a;color:var(--text);border:1px solid rgba(0,0,0,.05);transition:background .3s ease,border-color .3s ease}.project-card:hover .tech-pill{background:#ffffff80;border-color:#0000001a}@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}@media(max-width:1024px){.projects-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.projects-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.projects-grid{grid-template-columns:1fr}}.project-gallery{display:flex;flex-direction:column;gap:14px}.gallery-img{width:100%;max-width:900px;border:1px solid var(--border);align-self:center;background-color:#fff3;min-height:200px;opacity:0;animation:fadeUp .4s ease forwards}.waterfall{column-count:3;column-gap:14px}.waterfall-item{break-inside:avoid;margin:0 0 14px;padding:14px}.waterfall-thumb{width:100%;height:180px;border-radius:16px;border:1px solid var(--border);background:#ffffff59}.waterfall-caption{margin:10px 2px 0;color:var(--muted);line-height:1.4;font-size:.95rem}@media(max-width:950px){.waterfall{column-count:2}}@media(max-width:600px){.waterfall{column-count:1}.waterfall-thumb{height:160px}}
