@charset "UTF-8";button{background-color:transparent;color:var(--color-text-secondary, #7a7a9a);border:1px solid var(--color-border, rgba(255, 255, 255, .06));padding:8px 18px;border-radius:4px;cursor:pointer;font-family:inherit;font-size:14px;min-width:auto;transition:background-color .2s ease,color .2s ease,border-color .2s ease}button:hover{color:var(--color-accent, #4ade80);border-color:var(--color-border-accent, rgba(74, 222, 128, .22))}button:active{opacity:.8}button:disabled{opacity:.4;cursor:not-allowed}@media (max-width: 980px){button{font-size:13px;padding:6px 14px}}.portfolio-header{position:absolute;width:100%;z-index:10;left:0}.portfolio-header.light{--color-bg: #f0e8d8;--color-surface: #faf5ec;--color-surface-elevated: #ebe4d4;--color-text: #0d1829;--color-text-secondary: #4a3f30;--color-accent: #904800;--color-accent-secondary: #a55c10;--color-border: rgba(13, 24, 41, .1);--color-border-accent: rgba(144, 72, 0, .3)}.portfolio-header--container{max-width:1440px;margin:0 auto;padding:24px 48px 0;display:flex;justify-content:space-between;align-items:center}.portfolio-header .site-logo{font-family:Bebas Neue,sans-serif;font-size:1.875rem;letter-spacing:.22em;padding-right:.22em;color:var(--color-accent);line-height:1;transition:opacity .2s}.portfolio-header .site-logo:hover{opacity:.65}.portfolio-header .main-nav{display:flex;align-items:center;gap:20px;min-width:0}.portfolio-header .main-nav ul{display:flex;flex-wrap:wrap;justify-content:center;gap:4px}.portfolio-header .main-nav ul li{display:inline;padding:6px 14px}.portfolio-header .main-nav ul li>a{font-family:Epilogue,sans-serif;font-size:14px;letter-spacing:.04em;color:var(--color-text-secondary);transition:color .2s ease}.portfolio-header .main-nav ul li>a:hover{color:var(--color-text)}.portfolio-header .main-nav--actions{display:flex;gap:8px}.portfolio-header .main-nav--actions button{font-family:Epilogue,sans-serif;font-size:12px;letter-spacing:.05em;padding:6px 14px;border-radius:4px;min-width:auto;color:var(--color-text-secondary);border-color:var(--color-border);transition:all .2s ease}.portfolio-header .main-nav--actions button:hover{color:var(--color-accent);border-color:var(--color-border-accent);background-color:transparent}@media (max-width: 980px){.portfolio-header{position:static;background-color:var(--color-bg);border-bottom:1px solid var(--color-border)}.portfolio-header--container{padding:12px 16px;flex-direction:column;gap:10px}.portfolio-header .main-nav{flex-direction:column;width:100%;gap:8px}.portfolio-header .main-nav ul{display:flex;flex-wrap:wrap;justify-content:center;gap:0}.portfolio-header .main-nav ul li{padding:4px 10px}.portfolio-header .main-nav--actions{width:100%;justify-content:center;flex-wrap:wrap;margin-bottom:6px}}.header{padding:100px 48px 64px}.header-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 360px;gap:4rem;align-items:center}.header-name{font-family:"Jersey 10",monospace;font-weight:400;font-size:clamp(4.5rem,11vw,10rem);line-height:1.08;letter-spacing:.04em;color:var(--color-text);margin:0;display:flex;flex-direction:column}.header-name span{display:block}.header-sidebar{display:flex;flex-direction:column;gap:2rem;border-left:1px solid var(--color-border);padding-left:2rem;align-self:stretch;justify-content:center}.header-meta{display:flex;flex-direction:column;gap:.75rem}.header-eyebrow{font-family:IBM Plex Mono,monospace;font-size:14px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--color-accent);margin:0}.header-status{position:relative;display:flex;align-items:center;padding-left:20px;font-family:IBM Plex Mono,monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-secondary)}.header-status:before,.header-status:after{content:"";position:absolute;width:6px;height:6px;background-color:#52a67c;opacity:.75}.header-status:before{left:2px;top:calc(50% - 5px)}.header-status:after{left:5px;top:calc(50% - 2px)}.header-tagline{font-size:clamp(.85rem,1.2vw,.95rem);font-weight:300;line-height:1.75;color:var(--color-text-secondary)}.header-tagline p{margin-bottom:0}.header-tagline strong{color:var(--color-text);font-weight:500}.header-cta{font-family:IBM Plex Mono,monospace;font-size:14px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--color-accent);text-decoration:none;white-space:nowrap;align-self:flex-start;transition:color .2s ease}.header-cta:after{content:" →";display:inline-block;transition:transform .2s ease}.header-cta:hover{color:var(--color-text)}.header-cta:hover:after{transform:translate(5px)}@media (max-width: 980px){.header{padding:80px 24px 48px}.header-inner{grid-template-columns:1fr;gap:0}.header-name{font-size:clamp(3.5rem,13vw,6rem)}.header-sidebar{border-left:none;border-top:1px solid var(--color-border);padding-left:0;padding-top:2rem;margin-top:2rem;gap:1.5rem}}@media (max-width: 480px){.header-name{font-size:clamp(3rem,16vw,4.5rem)}}.section-header{overflow:hidden;margin-bottom:2.5rem}.section.with-line-after .section-header{position:relative;padding-bottom:1.5rem;margin-bottom:2rem}.section.with-line-after .section-header h2.gradient-title{position:relative}.section.with-line-after .section-header h2.gradient-title:after{content:"";position:absolute;bottom:50%;transform:translateY(50%);left:calc(100% + 20px);width:100vw;height:1px;background-color:#c8803a2e}.section.side-title .section-inner{display:grid;grid-template-columns:min-content 1fr;column-gap:4rem;align-items:start}.section.side-title .section-header{overflow:visible;margin-bottom:0;padding-bottom:0;border-right:1px solid var(--color-border);padding-right:2rem;align-self:stretch;display:flex;align-items:flex-start}.section.side-title .section-header h2.gradient-title{position:sticky;top:2rem;writing-mode:vertical-lr;text-orientation:upright;font-size:40px;letter-spacing:.01em;text-transform:uppercase;width:auto}.section.side-title .section-header h2.gradient-title:after{display:none}.section.side-title .section-content{min-width:0}@media (max-width: 980px){.section.side-title .section-inner{display:block}.section.side-title .section-header{overflow:hidden;border-right:none;border-bottom:1px solid var(--color-border);padding-right:0;padding-bottom:1.25rem;margin-bottom:2rem;display:block}.section.side-title .section-header h2.gradient-title{position:static;writing-mode:horizontal-tb;transform:none;font-size:clamp(1.8rem,6vw,2.8rem);letter-spacing:-.01em;text-transform:none}}.grid{max-width:100%;display:grid;grid-template-columns:1fr;gap:20px;padding:20px;min-height:0;min-width:0}@media (min-width: 768px){.grid{grid-template-columns:1fr 1fr}}@media (min-width: 992px){.grid{grid-template-columns:1fr 1fr 1fr}}.card{display:flex;flex-direction:column;background-color:var(--color-surface);border:1px solid var(--color-border);overflow:hidden;min-width:0;min-height:0;transition:border-color .2s ease,transform .2s ease}.card:hover{border-color:var(--color-border-accent);transform:translateY(-2px)}.card figure{max-height:260px;overflow:hidden;margin:0;flex:0 0 auto;position:relative}.card figure img{width:100%;object-fit:cover;display:block;transition:transform .3s ease}.card figure figcaption{display:none;position:absolute;bottom:0;font-size:10px;background:var(--color-surface);width:100%}.card:hover figure img{transform:scale(1.02)}.card-content{flex:1;display:flex;flex-direction:column;padding:1.5rem}.card-content .text div{margin-bottom:16px}.card-content h3{font-family:IBM Plex Mono,monospace;font-size:22px;font-weight:700;color:var(--color-text);letter-spacing:-.01em;margin-bottom:.5rem}.card-content p{font-size:16px;color:var(--color-text-secondary);line-height:1.6}.card-content .card-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:auto;padding-top:1rem}.card-content .card-tags span{font-family:Epilogue,sans-serif;font-size:11px;padding:.2rem .55rem;border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-secondary);background-color:var(--color-surface-elevated);letter-spacing:.03em}.card-content a{display:inline-block;font-family:Epilogue,sans-serif;font-size:14px;color:var(--color-accent);margin-top:auto;padding-top:1rem;letter-spacing:.04em;transition:opacity .2s ease}.card-content a:hover{opacity:.7}.card-content a:after{content:" →"}.card-timeline:hover{transform:none}.card-image-trigger{cursor:zoom-in;-webkit-user-select:none;user-select:none}.card-image-trigger:focus-visible{outline:2px solid var(--color-accent);outline-offset:-2px}.card-expand-hint{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;pointer-events:none;background:#00000038;transition:background .2s ease}.card-expand-hint:before,.card-expand-hint:after{content:"";position:absolute;width:10px;height:10px;transition:border-color .2s ease}.card-expand-hint:before{top:10px;right:10px;border-top:2px solid rgba(255,255,255,.65);border-right:2px solid rgba(255,255,255,.65)}.card-expand-hint:after{bottom:10px;left:10px;border-bottom:2px solid rgba(255,255,255,.65);border-left:2px solid rgba(255,255,255,.65)}.card-image-trigger:hover .card-expand-hint{background:#00000061}.card-image-trigger:hover .card-expand-hint:before{border-color:#fffffff2}.card-image-trigger:hover .card-expand-hint:after{border-color:#fffffff2}.img-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#000000e0;display:flex;align-items:center;justify-content:center;padding:1.5rem;cursor:pointer;animation:img-modal-in .18s ease}@keyframes img-modal-in{0%{opacity:0}to{opacity:1}}.img-modal-close{position:fixed;top:1rem;right:1rem;width:36px;height:36px;min-width:unset;padding:0;background:transparent;border:1px solid rgba(255,255,255,.25);border-radius:0;color:#fffc;font-family:Epilogue,sans-serif;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1001;transition:border-color .2s ease,color .2s ease}.img-modal-close:hover{border-color:#ffffffb3;color:#fff}.img-modal-figure{width:768px;max-width:90vw;max-height:90vh;cursor:default;margin:0 auto;display:flex;flex-direction:column;align-items:center;overflow-y:auto}.img-modal-figure img{display:block;width:100%;height:auto;object-fit:contain}.img-modal-figure figcaption{display:block;margin-top:.75rem;font-size:14px;color:#ffffff73;text-align:center;font-family:Epilogue,sans-serif;font-style:italic}@media (max-width: 980px){.card-content{padding:1.25rem}}.icon-list{display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;padding:1rem;font-size:72px;color:var(--color-accent)}@media (max-width: 980px){.icon-list{gap:1rem;font-size:clamp(1.8rem,8vw,3rem);padding:.5rem}}.skills-grid{display:grid;grid-template-columns:1fr;gap:2.5rem}@media (min-width: 768px){.skills-grid{grid-template-columns:repeat(2,1fr);gap:2.5rem 4rem}}@media (min-width: 992px){.skills-grid{grid-template-columns:repeat(4,1fr);gap:2.5rem 3rem}}.skills-category{display:flex;flex-direction:column;gap:.75rem}.skills-category-label{font-family:Epilogue,sans-serif;font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--color-accent);padding-bottom:.6rem;border-bottom:1px solid var(--color-border-accent);margin-bottom:.25rem}.skills-list{list-style:none;display:flex;flex-direction:column;gap:.5rem}.skills-tag{display:flex;align-items:center;gap:.65rem;font-family:Epilogue,sans-serif;font-size:13px;font-weight:400;color:var(--color-text-secondary);transition:color .2s ease}.skills-tag:hover{color:var(--color-text)}.skills-tag:hover:before{background:var(--color-accent);box-shadow:4px 0 0 0 var(--color-accent),0 4px 0 0 var(--color-accent),4px 4px 0 0 var(--color-accent)}.skills-tag:before{content:"";display:inline-block;flex-shrink:0;width:4px;height:4px;background:var(--color-border-accent);box-shadow:4px 0 0 0 var(--color-border-accent),0 4px 0 0 var(--color-border-accent),4px 4px 0 0 var(--color-border-accent);image-rendering:pixelated}#experience .section-header{align-items:flex-start}#experience .card:hover{background-color:var(--color-surface-elevated)}.timeline{position:relative}@media (min-width: 768px){.timeline:before{content:"";position:absolute;left:50%;top:0;bottom:0;width:1px;background:var(--color-border);transform:translate(-50%);z-index:0}}@media (min-width: 0px){.timeline .card-content{font-size:16px}.timeline .card-content h3{font-size:22px}}@media (min-width: 992px){.timeline .card-content{font-size:16px}.timeline .card-content h3{font-size:22px}}.timeline .timeline-card{display:flex;flex-direction:column;margin-bottom:16px}.timeline .timeline-card .timeline-years{font-family:Epilogue,sans-serif;font-size:14px;font-weight:600;letter-spacing:.06em;color:var(--color-accent);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:4px 4px 0 0;text-align:center;padding:8px 16px}@media (min-width: 768px){.timeline .timeline-card{display:grid;grid-template-columns:1fr auto 1fr;gap:10px;margin-bottom:32px;align-items:center}.timeline .timeline-card .timeline-years{background-color:transparent;border:none;border-radius:0;padding:0;color:var(--color-text-secondary);font-weight:400}.timeline .timeline-card .timeline-years p{margin-bottom:0}.timeline .timeline-card:nth-child(odd) .timeline-years{position:relative;grid-column:1;text-align:right;padding-right:28px}.timeline .timeline-card:nth-child(odd) .timeline-years:before{content:"";position:absolute;top:50%;right:0;transform:translateY(-50%);width:18px;height:1px;background:var(--color-accent)}.timeline .timeline-card:nth-child(odd) .card{grid-column:3;grid-row:1;margin-left:28px}.timeline .timeline-card:nth-child(2n) .timeline-years{position:relative;grid-column:3;text-align:left;padding-left:28px}.timeline .timeline-card:nth-child(2n) .timeline-years:before{content:"";position:absolute;top:50%;left:0;transform:translateY(-50%);width:18px;height:1px;background:var(--color-accent)}.timeline .timeline-card:nth-child(2n) .card{grid-column:1;grid-row:1;margin-right:28px}}@keyframes scroll-preview{0%,to{object-position:center top}50%{object-position:center bottom}}#projects .section-header{align-items:flex-start}.projects .grid{grid-template-columns:1fr;padding:0;gap:1.5rem}.projects .card{flex-direction:row;align-items:stretch;border:1px solid var(--color-border);border-radius:0;background-color:var(--color-bg);transition:background-color .2s ease,border-color .2s ease}.projects .card:hover{background-color:var(--color-surface);border-color:var(--color-border-accent);transform:none}.projects .card:hover figure img{animation-play-state:running}.projects .card figure{position:relative;width:260px;min-width:260px;flex-shrink:0;border-radius:0;overflow:hidden;max-height:100%;border-right:1px solid var(--color-border)}.projects .card figure img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center top;animation:scroll-preview 20s ease-in-out infinite;animation-play-state:paused}.projects .card-content{padding:1.75rem 2rem;justify-content:center;text-align:left}.projects .card-content h3{font-size:22px;margin-bottom:.5rem}.projects .card-content p{font-size:16px}.projects .card-content a{text-align:right;font-weight:700}@media (max-width: 980px){.projects .card{flex-direction:column}.projects .card figure{width:100%;min-width:unset;height:200px;position:relative}}@media (max-width: 991px){.projects .card figure img{animation:none}}.footer{text-align:center;font-family:Epilogue,sans-serif;font-size:14px;letter-spacing:.04em;padding:2rem 1rem;color:var(--color-text-secondary);border-top:1px solid var(--color-border);background-color:var(--color-bg)}.footer.light{--color-bg: #f0e8d8;--color-text: #0d1829;--color-text-secondary: #4a3f30;--color-accent: #904800;--color-border: rgba(13, 24, 41, .1)}.footer a{color:var(--color-accent);transition:opacity .2s ease}.footer a:hover{opacity:.7}form{max-width:640px;width:100%;margin:0 auto 80px}form input,form textarea{width:100%;padding:10px 14px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:4px;color:var(--color-text);font-family:Epilogue,sans-serif;font-size:16px;transition:border-color .2s ease}form input:focus,form textarea:focus{outline:none;border-color:var(--color-border-accent)}form input::placeholder,form textarea::placeholder{color:var(--color-text-secondary)}form label{display:block;font-family:Epilogue,sans-serif;font-size:14px;color:var(--color-text-secondary);margin-bottom:.4rem;letter-spacing:.05em}form .form-field{margin-bottom:1.25rem}.contact .icons{display:flex;justify-content:center;gap:1rem;width:100%}.contact .icons .icon-list{display:flex;flex-wrap:nowrap;justify-content:center;gap:1rem;width:80%;border-top:1px solid var(--color-border);padding-top:0}.contact .icons a{display:flex;flex-wrap:wrap;justify-content:center;color:var(--color-text-secondary);text-decoration:none;font-size:4rem;transition:color .2s ease,transform .2s ease;width:50%;padding:40px 20px;border-right:1px solid var(--color-border)}.contact .icons a:last-child{border-right:none}.contact .icons a:hover{color:var(--color-accent);transform:translateY(-2px)}@media (max-width: 980px){.contact .icons .icon-list{width:100%}.contact .icons a{width:100%;font-size:clamp(2rem,10vw,3rem);padding:20px 12px;border-right:none}.contact .icons a:last-child{border-bottom:none}}.project-page{min-height:100svh;padding-top:80px}@media (max-width: 980px){.project-page{padding-top:0}}.project-not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60svh;gap:1rem;font-family:IBM Plex Mono,monospace;font-size:16px;color:var(--color-text-secondary)}.project-not-found a{color:var(--color-accent)}.project-nav{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);background-color:var(--color-bg);position:sticky;top:0;z-index:5}.project-back{font-family:IBM Plex Mono,monospace;font-size:14px;letter-spacing:.05em;color:var(--color-accent);transition:opacity .2s}.project-back:hover{opacity:.7}.project-nav-meta{font-family:IBM Plex Mono,monospace;font-size:14px;letter-spacing:.06em;color:var(--color-text-secondary)}.project-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:1px;background-color:var(--color-border);align-items:start}.project-grid .project-cell--image-1{grid-column:1;grid-row:1}.project-grid .project-cell--narrative-1{grid-column:2;grid-row:1;overflow-y:auto}.project-grid .project-cell--narrative-2{grid-column:1;grid-row:2;overflow-y:auto}.project-grid .project-cell--image-2{grid-column:2;grid-row:2}.project-cell{background-color:var(--color-bg);max-height:90vh}.project-cell--image-1,.project-cell--image-2{background-color:var(--color-surface);display:flex;flex-direction:column;align-self:stretch;overflow:hidden}.project-cell-inner{padding:2.5rem}.project-image-cell{display:flex;flex-direction:column;flex:1;min-height:0}.image-cell-bar{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--color-border);flex-shrink:0}.image-cell-label{font-family:IBM Plex Mono,monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-secondary)}.image-toggle{display:flex;gap:0}.toggle-pill{font-family:IBM Plex Mono,monospace;font-size:11px;letter-spacing:.06em;text-transform:uppercase;padding:4px 12px;background:none;border:1px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;transition:background-color .15s,color .15s,border-color .15s}.toggle-pill:first-child{border-radius:4px 0 0 4px}.toggle-pill:last-child{border-radius:0 4px 4px 0;border-left:none}.toggle-pill.active{background-color:var(--color-accent);border-color:var(--color-accent);color:var(--color-bg)}.toggle-pill:not(.active):hover{border-color:var(--color-border-accent);color:var(--color-text)}.image-frame{flex:1;min-height:0;overflow-y:auto;padding:1.5rem;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.image-frame::-webkit-scrollbar{width:4px}.image-frame::-webkit-scrollbar-track{background:transparent}.image-frame::-webkit-scrollbar-thumb{background-color:var(--color-border);border-radius:99px}.image-frame img{width:100%;height:auto;display:block;border:1px solid var(--color-border)}.image-placeholder{flex:1;display:grid;place-items:center;color:var(--color-text-secondary);font-family:IBM Plex Mono,monospace;font-size:14px;letter-spacing:.06em;opacity:.5}.project-header{padding-bottom:1.75rem;margin-bottom:2rem;border-bottom:1px solid var(--color-border)}.project-name{font-family:"Jersey 10",monospace;font-size:clamp(2.5rem,5vw,4rem);line-height:1;letter-spacing:.02em;color:var(--color-text);margin-bottom:.75rem}.project-one-liner{font-family:IBM Plex Mono,monospace;font-size:16px;color:var(--color-text-secondary);line-height:1.5;margin-bottom:0}.project-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.25rem}.project-tag{font-family:IBM Plex Mono,monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:3px 8px;border:1px solid var(--color-border-accent);color:var(--color-accent)}.project-links{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1.25rem}.project-link{font-family:IBM Plex Mono,monospace;font-size:14px;font-weight:700;letter-spacing:.04em;color:var(--color-accent);border-bottom:1px solid var(--color-border-accent);padding-bottom:1px;transition:border-color .2s,opacity .2s}.project-link:hover{border-color:var(--color-accent);opacity:.8}.project-blocks{display:flex;flex-direction:column;gap:1.75rem}.project-block p{font-size:16px;line-height:1.7;margin-bottom:.6rem}.project-block p:last-child{margin-bottom:0}.project-block-label{font-family:IBM Plex Mono,monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--color-accent);font-weight:600;margin-bottom:.6rem}.project-tech-stack{display:flex;flex-direction:column;gap:1px;background-color:var(--color-border);margin-top:.75rem}.tech-row{display:grid;grid-template-columns:130px 1fr;gap:1rem;padding:.75rem 0;background-color:var(--color-bg);align-items:baseline}.tech-name{font-family:IBM Plex Mono,monospace;font-size:14px;font-weight:700;color:var(--color-text);padding:0}.tech-note{font-family:Epilogue,sans-serif;font-size:14px;color:var(--color-text-secondary);line-height:1.55;padding:0;margin:0}@media (max-width: 768px){.project-grid{display:flex;flex-direction:column;gap:1px}.project-cell--image-1{order:1;min-height:300px}.project-cell--narrative-1{order:2}.project-cell--narrative-2{order:3}.project-cell--image-2{order:4;min-height:300px}.project-cell-inner{padding:1.5rem}.tech-row{grid-template-columns:100px 1fr}.project-nav{padding:.875rem 1rem}.image-cell-bar{padding:.75rem 1rem}}.wib{display:grid;grid-template-columns:repeat(3,1fr);gap:3rem}@media (max-width: 980px){.wib{grid-template-columns:1fr;gap:0}}.wib-row{position:relative;overflow:hidden;display:flex;flex-direction:column;gap:.75rem;padding-top:3rem;border-top:2px solid var(--color-accent);transition:border-color .2s ease;overflow:visible;padding:2rem 0 15px}.wib-row:hover{border-color:var(--color-accent)}.wib-row:hover .wib-title{color:var(--color-accent)}@media (max-width: 980px){.wib-row{padding:3rem 0 1.5rem}.wib-row:first-child{border-top:none}.wib-row:last-child{border-bottom:none}}.wib-label{position:absolute;bottom:-15px;right:-15px;z-index:0;pointer-events:none;font-family:"Jersey 10",monospace;font-size:clamp(4rem,10vw,8rem);line-height:.5;color:var(--color-accent);opacity:.1}@media (max-width: 980px){.wib-label{bottom:10px;right:10px}}.wib-title{position:relative;z-index:1;font-family:IBM Plex Mono,monospace;font-size:clamp(1rem,2vw,1.3rem);font-weight:700;color:var(--color-text);letter-spacing:-.01em;line-height:1.2;transition:color .2s ease}.wib-desc{position:relative;z-index:1;font-size:16px;font-weight:300;line-height:1.7;color:var(--color-text);margin-bottom:0}.skills-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0 3rem}@media (max-width: 980px){.skills-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 460px){.skills-grid{grid-template-columns:1fr}}.skills-category{padding-top:1.75rem;border-top:2px solid var(--color-accent);margin-bottom:2.5rem}@media (max-width: 980px){.skills-category{border-top:none;padding-top:0}}.skills-category-label{display:block;font-family:"Jersey 10",monospace;font-size:42px;color:var(--color-accent);margin-bottom:1rem;letter-spacing:.04em}@media (max-width: 980px){.skills-category-label{font-size:28px}}.skills-list{list-style:none;display:flex;flex-direction:column;gap:.4rem}.skills-tag{position:relative;padding-left:20px;font-size:16px;color:var(--color-text);line-height:1.5}.skills-tag:before,.skills-tag:after{content:"";position:absolute;width:6px;height:6px;background-color:var(--color-accent);opacity:.55}.skills-tag:before{left:2px;top:calc(50% - 5px)}.skills-tag:after{left:5px;top:calc(50% - 2px)}.portfolio>section:nth-of-type(odd){background-color:var(--color-surface)}.portfolio>.section-transition:nth-child(4n+2){background-color:var(--color-surface)}.portfolio>.section-transition:nth-child(4n+2) .st-block{background-color:var(--color-bg)}.section-transition{width:100%}.section-transition .st-blocks{display:flex;flex-direction:column;width:100%;pointer-events:none;overflow:hidden}.section-transition .st-row{display:flex;width:100%;height:clamp(20px,3vw,40px)}.section-transition .st-block{flex:1;background-color:var(--color-surface)}:root{--color-bg: #0d1829;--color-surface: #111f35;--color-surface-elevated: #162540;--color-text: #ede8dc;--color-text-secondary: #8a8070;--color-accent: #c8803a;--color-accent-secondary: #d49050;--color-border: rgba(237, 232, 220, .07);--color-border-accent: rgba(200, 128, 58, .28)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{max-width:100%;font-size:100%;scroll-behavior:smooth}body{max-width:100%;font-family:Epilogue,sans-serif;background-color:#0d1829;color:#ede8dc;line-height:1.6;transition:background-color .3s ease,color .3s ease}#root{padding:0}.portfolio{--color-bg: #0d1829;--color-surface: #111f35;--color-surface-elevated: #162540;--color-text: #ede8dc;--color-text-secondary: #8a8070;--color-accent: #c8803a;--color-accent-secondary: #d49050;--color-border: rgba(237, 232, 220, .07);--color-border-accent: rgba(200, 128, 58, .28);background-color:var(--color-bg);color:var(--color-text)}.portfolio.light{--color-bg: #f0e8d8;--color-surface: #faf5ec;--color-surface-elevated: #ebe4d4;--color-text: #0d1829;--color-text-secondary: #4a3f30;--color-accent: #904800;--color-accent-secondary: #a55c10;--color-border: rgba(13, 24, 41, .1);--color-border-accent: rgba(144, 72, 0, .3);background-color:var(--color-bg);color:var(--color-text)}.portfolio.light .contact label{color:var(--color-text)}.portfolio.light .contact button{color:var(--color-text);border-color:var(--color-text)}.portfolio.light .contact button:hover{background-color:var(--color-text);color:var(--color-bg)}.section{width:100%}.section-inner{max-width:1200px;margin:0 auto;padding:4rem 2rem}@media (max-width: 980px){.section-inner{padding:2rem 1rem}}img{max-width:100%;height:auto;display:block}h1,h2,h3,h4,h5,h6{font-family:IBM Plex Mono,monospace;font-weight:700;letter-spacing:-.01em}p{margin-bottom:10px}a{color:inherit;text-decoration:none}strong{color:var(--color-accent);font-weight:600}h1.gradient-title{width:fit-content;font-family:IBM Plex Mono,monospace;font-weight:700;color:var(--color-text);font-size:72px;letter-spacing:-.03em;line-height:1;margin:0 auto}h2.gradient-title{width:fit-content;font-family:IBM Plex Mono,monospace;font-weight:700;color:var(--color-text);font-size:48px;letter-spacing:-.02em}h3.gradient-title{width:fit-content;font-family:IBM Plex Mono,monospace;font-weight:700;color:var(--color-text);font-size:34px;letter-spacing:-.01em}h4.gradient-title{width:fit-content;font-family:IBM Plex Mono,monospace;font-weight:700;color:var(--color-text);font-size:22px}h5.gradient-title{width:fit-content;font-family:IBM Plex Mono,monospace;font-weight:700;color:var(--color-text);font-size:16px}h6.gradient-title{width:fit-content;font-family:IBM Plex Mono,monospace;font-weight:700;color:var(--color-text);font-size:14px}@media (max-width: 980px){h1.gradient-title{font-size:clamp(2.4rem,10vw,4rem)}h2.gradient-title{font-size:clamp(1.8rem,6vw,2.8rem)}h3.gradient-title{font-size:clamp(1.3rem,4vw,1.8rem)}}html{scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background-color:var(--color-border);border-radius:99px}.container{max-width:1200px;margin:0 auto;padding:0 2rem}.accent{color:var(--color-accent)}
