*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f9f8f6;--text:#1a1a1a;--muted:#7a7a7a;--white:#fff;--green-bg:#e8f5ec;--green-border:#c5dfc9;--green-accent:#2d6a4f;--orange-bg:#fff4e6;--orange-border:#f5d9b3;--orange-accent:#b35900;--purple-bg:#ede7f6;--purple-border:#d1c4e9;--purple-accent:#4527a0;--radius-card:22px;--radius-icon:14px;--radius-badge:8px}body{background-color:var(--bg);color:var(--text);min-height:100vh;font-family:Inter,sans-serif;overflow-x:hidden}.page{flex-direction:column;justify-content:center;align-items:center;width:100%;min-height:100vh;padding:3rem 4vw;display:flex}.name-header{text-align:center;z-index:5;margin-bottom:2.5rem;position:relative}.greeting{color:var(--muted);margin-bottom:.15rem;font-family:Caveat,cursive;font-size:1.4rem;font-weight:500}.name{letter-spacing:-.05em;text-align:center;font-family:Inter,sans-serif;font-size:clamp(3.5rem,8vw,7rem);font-weight:900;line-height:.95}.name-underline{width:70%;max-width:480px;height:auto;margin:.5rem auto 0;display:block}.domain{color:var(--muted);letter-spacing:.03em;margin-top:.6rem;font-size:1rem;font-weight:500}.stage{grid-template-columns:1fr auto 1fr;align-items:center;gap:0;width:100%;max-width:1300px;display:grid}.col{flex-direction:column;gap:2rem;display:flex}.col-left{align-items:flex-end;padding-right:3vw}.col-right{align-items:flex-start;padding-left:3vw}.card-group{flex-direction:column;gap:.45rem;display:flex}.card-label-row{color:var(--muted);align-items:center;gap:.4rem;font-family:Caveat,cursive;font-size:1.15rem;font-weight:500;display:flex}.col-left .card-label-row{justify-content:flex-end}.col-right .card-label-row{justify-content:flex-start}.card{background:var(--white);border-radius:var(--radius-card);width:min(260px,22vw);min-width:200px;color:var(--text);border:1px solid #e2e2e8;flex-direction:column;gap:.4rem;padding:1.25rem;text-decoration:none;transition:transform .22s;display:flex;position:relative}.card:hover{transform:translateY(-5px)}.card.green{background:var(--green-bg);border-color:var(--green-border)}.card.orange{background:var(--orange-bg);border-color:var(--orange-border)}.card.purple{background:var(--purple-bg);border-color:var(--purple-border)}.icon-box{border-radius:var(--radius-icon);background:#0000000f;justify-content:center;align-items:center;width:46px;height:46px;margin-bottom:.2rem;display:flex}.card.green .icon-box{background:#2d6a4f21}.card.orange .icon-box{background:#b3590021}.card.purple .icon-box{background:#4527a021}.arrow-btn{background:#0000000f;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;display:flex;position:absolute;top:1.1rem;right:1.1rem}.card.green .arrow-btn{background:#2d6a4f1f}.card.orange .arrow-btn{background:#b359001f}.card.purple .arrow-btn{background:#4527a01f}.card-name{padding-right:2.2rem;font-size:1rem;font-weight:700;line-height:1.25}.card-sub{color:var(--muted);font-size:.8rem;line-height:1.45}.badge{letter-spacing:.08em;border-radius:var(--radius-badge);width:fit-content;margin-top:.2rem;padding:.2rem .5rem;font-size:.62rem;font-weight:700;display:inline-block}.card.green .badge{color:var(--green-accent);background:#2d6a4f1f}.card.orange .badge{color:var(--orange-accent);background:#b359001f}.card.purple .badge{color:var(--purple-accent);background:#4527a01f}.card:not([class*=\ ]) .badge{color:var(--muted);background:#00000012}.badge-status{letter-spacing:.08em;border:1.5px dashed var(--muted);width:fit-content;color:var(--muted);border-radius:6px;margin-top:.4rem;padding:.25rem .55rem;font-size:.62rem;font-weight:700;display:inline-block}.badge-status.active{border-color:var(--green-accent);color:var(--green-accent);background:#2d6a4f0d}.badge-status.dev{border-color:var(--orange-accent);color:var(--orange-accent);background:#b359000d}.figure-wrap{justify-content:center;align-items:flex-end;width:clamp(240px,28vw,420px);display:flex;position:relative}.figure-img{object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:2;width:100%;max-height:62vh;display:block;position:relative}.plus{color:#e8a020;z-index:3;pointer-events:none;-webkit-user-select:none;user-select:none;opacity:.8;font-size:1.8rem;font-weight:200;line-height:1;position:absolute}.plus-tl{top:28%;left:-18px}.plus-bl{bottom:20%;left:-10px}.plus-tr{top:28%;right:-18px}.plus-br{bottom:20%;right:-10px}@media (width<=900px){.stage{grid-template-rows:auto auto;grid-template-columns:1fr 1fr;gap:1.5rem 2rem}.figure-wrap{grid-area:1/1/auto/3;justify-content:center;width:100%}.figure-img{width:auto;max-width:55vw;max-height:40vh}.col-left{grid-area:2/1;align-items:flex-end;padding-right:1rem}.col-right{grid-area:2/2;align-items:flex-start;padding-left:1rem}.card{width:100%;min-width:0}.col-left .card-label-row{justify-content:flex-end}.col-right .card-label-row{justify-content:flex-start}}@media (width<=580px){.page{padding:2rem 1.25rem}.name{font-size:clamp(2.6rem,10vw,3.5rem)}.stage{flex-direction:column;align-items:center;gap:1.5rem;display:flex}.figure-wrap{width:70vw;max-width:280px}.figure-img{max-width:100%;max-height:38vh}.col-left,.col-right{align-items:center;width:100%;padding:0}.card-label-row{justify-content:center!important}.card-group{align-items:center;width:100%}.card{width:100%;min-width:0;max-width:320px}.plus{display:none}}.card-btn{all:unset;background:var(--white);border-radius:var(--radius-card);width:min(260px,22vw);min-width:200px;color:var(--text);cursor:pointer;box-sizing:border-box;border:1px solid #e2e2e8;flex-direction:column;gap:.4rem;padding:1.25rem;text-decoration:none;transition:transform .2s,border-color .2s;display:flex;position:relative}.card-btn:hover{transform:translateY(-4px)}.card-btn.green{background:var(--green-bg);border-color:var(--green-border)}.card-btn.orange{background:var(--orange-bg);border-color:var(--orange-border)}.card-btn.purple{background:var(--purple-bg);border-color:var(--purple-border)}.card--active{border-width:2px;border-color:var(--text)!important}.card-btn.green.card--active{border-color:var(--green-accent)!important}.card-btn.orange.card--active{border-color:var(--orange-accent)!important}.card-btn.purple.card--active{border-color:var(--purple-accent)!important}.arrow-btn{transition:transform .25s}.arrow-btn--open{transform:rotate(180deg)}@media (width<=900px){.card-btn{width:100%;min-width:0}}@media (width<=580px){.card-btn{width:100%;min-width:0;max-width:320px}}.detail-area{background:var(--white);border:1px solid #e2e2e8;border-radius:24px;width:100%;max-width:1300px;margin-top:2.5rem;padding:2rem 2.5rem;animation:.28s slideDown;position:relative}@keyframes slideDown{0%{opacity:0;transform:translateY(-14px)}to{opacity:1;transform:translateY(0)}}.detail-close{all:unset;cursor:pointer;background:#f0f0f0;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:background .15s;display:flex;position:absolute;top:1.1rem;right:1.1rem}.detail-close:hover{background:#e0e0e0}.detail-title{letter-spacing:-.03em;margin-bottom:1.25rem;font-size:1.4rem;font-weight:800}.detail-section-heading{text-transform:uppercase;letter-spacing:.07em;color:var(--muted);align-items:center;gap:.4rem;margin-bottom:.85rem;font-size:.85rem;font-weight:700;display:flex}.detail-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.25rem;display:grid}.detail-block{flex-direction:column;gap:.35rem;display:flex}.detail-block--wide{grid-column:1/-1}.detail-block-title{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);align-items:center;gap:.35rem;margin-bottom:.15rem;font-size:.8rem;font-weight:700;display:flex}.detail-text{font-size:.95rem;line-height:1.5}.detail-link{color:#0a66c2;align-items:center;gap:.3rem;font-size:.9rem;font-weight:600;text-decoration:none;transition:opacity .15s;display:inline-flex}.detail-link:hover{opacity:.7}.contact-form{flex-direction:column;gap:.75rem;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.form-input{background:var(--bg);color:var(--text);border:1px solid #ddd;border-radius:10px;outline:none;width:100%;padding:.65rem .9rem;font-family:Inter,sans-serif;font-size:.9rem;transition:border-color .15s}.form-input:focus{border-color:var(--text)}.form-textarea{resize:vertical;min-height:100px}.form-submit{all:unset;background:var(--text);color:#fff;cursor:pointer;border-radius:10px;align-items:center;gap:.45rem;width:fit-content;padding:.65rem 1.5rem;font-size:.875rem;font-weight:600;transition:opacity .15s;display:inline-flex}.form-submit:hover{opacity:.8}.form-success{color:var(--green-accent);font-size:.9rem;font-weight:500}@media (width<=580px){.form-row{grid-template-columns:1fr}.detail-area{padding:1.5rem 1.25rem}}.project-card{color:var(--text);border:1px solid #e2e2e8;border-radius:14px;flex-direction:column;gap:.4rem;padding:1rem 1.1rem;text-decoration:none;transition:transform .18s;display:flex}.project-card:hover{transform:translateY(-3px)}.project-card.orange{background:var(--orange-bg);border-color:var(--orange-border)}.project-card.purple{background:var(--purple-bg);border-color:var(--purple-border)}.project-card-header{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.project-card-name{font-size:.95rem;font-weight:700}.project-card-desc{color:var(--muted);font-size:.8rem;line-height:1.45}.ext-card{background:var(--bg);border:1px solid #e2e2e8;border-radius:14px;justify-content:space-between;align-items:center;gap:.75rem;padding:.9rem 1rem;display:flex}.ext-card-header{flex-direction:column;gap:.15rem;min-width:0;display:flex}.ext-card-name{white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;font-weight:700;overflow:hidden}.ext-desc{color:var(--muted);font-size:.72rem}.ext-links{flex-shrink:0;gap:.5rem;display:flex}.browser-link{background:#fff;border:1px solid #e2e2e8;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;text-decoration:none;transition:border-color .15s,transform .15s;display:flex}.browser-link:hover{border-color:#bbb;transform:scale(1.08)}.browser-link img{display:block}.skill-pill-group{flex-direction:column;gap:.6rem;display:flex}.skill-pills{flex-wrap:wrap;gap:.5rem;display:flex}.skill-pill{letter-spacing:.02em;border-radius:20px;padding:.3rem .75rem;font-size:.78rem;font-weight:600}.skill-pill.green{background:var(--green-bg);color:var(--green-accent);border:1px solid var(--green-border)}.skill-pill.orange{background:var(--orange-bg);color:var(--orange-accent);border:1px solid var(--orange-border)}.skill-pill.purple{background:var(--purple-bg);color:var(--purple-accent);border:1px solid var(--purple-border)}.site-footer{text-align:center;color:#888;letter-spacing:.05em;opacity:.25;margin-top:4rem;margin-bottom:2rem;font-size:.7rem}
