@charset "UTF-8";html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;font-size:100%;font:inherit;vertical-align:baseline}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}body{line-height:1}ol,ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:"";content:none}table{border-collapse:collapse;border-spacing:0}*{box-sizing:border-box}:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.6;font-weight:400;color-scheme:light;color:#181a1f;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.f-body{font-family:var(--font-body)}.f-spectral{font-family:var(--font-spectral)}.color-white{color:#fff}.w-full{width:100%}.h-full{height:100%}.rounded{border-radius:50%}.uppercase{text-transform:uppercase}.bold{font-weight:700}.fw-normal{font-weight:400}.black{font-weight:900}.text-center{text-align:center}.text-white{color:#fff}.block{display:block}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.flex-col{flex-direction:column}.items-center{align-items:center}.items-stretch{align-items:stretch}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-around{justify-content:space-around}.justify-between{justify-content:space-between}.align-center{align-self:center}.align-end{align-self:flex-end}.mx-auto{margin:0 auto}.ml-auto{margin-left:auto}.mr-auto{margin-right:auto}.z-index{z-index:1}.o-hidden{overflow:hidden}.br-20{border-radius:20px}.br-18{border-radius:18px}.fit-cover{object-fit:cover}.pt-none{pointer-events:none!important}:root{--color-bg-primary: #ffffff;--color-bg-secondary: #ffffff;--color-bg-tertiary: #f8f9fa;--color-bg-hover: #f8f9fa;--color-text-primary: #181a1f;--color-text-secondary: rgba(0, 0, 0, .7);--color-text-tertiary: rgba(0, 0, 0, .5);--color-text-quaternary: rgba(0, 0, 0, .4);--color-border-primary: rgba(0, 0, 0, .1);--color-border-secondary: rgba(0, 0, 0, .2);--color-border-hover: rgba(0, 0, 0, .3);--color-shadow-sm: rgba(0, 0, 0, .05);--color-shadow-md: rgba(0, 0, 0, .08);--color-shadow-lg: rgba(0, 0, 0, .1);--color-card-bg: #ffffff;--color-input-bg: #ffffff;--color-badge-bg: rgba(0, 0, 0, .05);--color-badge-bg-hover: rgba(0, 0, 0, .1);--color-badge-border: rgba(0, 0, 0, .15);--color-dev-bg: rgba(255, 193, 7, .15);--color-dev-text: #f57c00;--color-dev-border: rgba(255, 193, 7, .3);--color-dev-shadow: rgba(255, 193, 7, .2);--color-qa-bg: rgba(83, 158, 233, .15);--color-qa-text: #539ee9;--color-qa-border: rgba(83, 158, 233, .3);--color-qa-shadow: rgba(83, 158, 233, .2);--color-staging-bg: rgba(33, 150, 243, .15);--color-staging-text: #1976d2;--color-staging-border: rgba(33, 150, 243, .3);--color-staging-shadow: rgba(33, 150, 243, .2);--color-production-bg: rgba(76, 175, 80, .15);--color-production-text: #388e3c;--color-production-border: rgba(76, 175, 80, .3);--color-production-shadow: rgba(76, 175, 80, .2);--color-arcade-bg: rgba(158, 25, 210, .15);--color-arcade-text: #9e19d2;--color-arcade-border: rgba(158, 25, 210, .3);--color-arcade-shadow: rgba(158, 25, 210, .2);--color-env-bg: rgba(210, 25, 25, .15);--color-env-text: rgb(210, 25, 25);--color-env-border: rgba(210, 25, 25, .3);--color-env-shadow: rgba(210, 25, 25, .2);--color-star-bg: rgba(255, 255, 255, .9);--color-star-border: #424242;--color-star-active-bg: #858585;--color-star-active-hover: #6d6d6d;--color-more-badge-bg: #e0e0e0;--color-more-badge-hover: #d0d0d0;--color-more-badge-text: #424242;--color-tooltip-bg: white;--color-tooltip-text: #424242;--color-btn-active-bg: #181a1f;--color-btn-active-text: white;--color-placeholder-bg-start: #f5f5f5;--color-placeholder-bg-end: #e0e0e0;--color-service-badge-bg: #ffffff;--color-service-badge-border: rgba(0, 0, 0, .1)}html.dark-mode{--color-bg-primary: #0f1419;--color-bg-secondary: #0f1419;--color-bg-tertiary: #22272e;--color-bg-hover: #2d333b;--color-text-primary: #e6edf3;--color-text-secondary: rgba(255, 255, 255, .75);--color-text-tertiary: rgba(255, 255, 255, .55);--color-text-quaternary: rgba(255, 255, 255, .4);--color-border-primary: rgba(255, 255, 255, .12);--color-border-secondary: rgba(255, 255, 255, .18);--color-border-hover: rgba(255, 255, 255, .28);--color-shadow-sm: rgba(0, 0, 0, .3);--color-shadow-md: rgba(0, 0, 0, .4);--color-shadow-lg: rgba(0, 0, 0, .5);--color-card-bg: #1a1f26;--color-input-bg: #22272e;--color-badge-bg: rgba(255, 255, 255, .08);--color-badge-bg-hover: rgba(255, 255, 255, .14);--color-badge-border: rgba(255, 255, 255, .18);--color-dev-bg: rgba(255, 193, 7, .22);--color-dev-text: #ffa726;--color-dev-border: rgba(255, 193, 7, .4);--color-dev-shadow: rgba(255, 193, 7, .3);--color-qa-bg: rgba(83, 158, 233, .22);--color-qa-text: #64b5f6;--color-qa-border: rgba(83, 158, 233, .4);--color-qa-shadow: rgba(83, 158, 233, .3);--color-staging-bg: rgba(33, 150, 243, .22);--color-staging-text: #42a5f5;--color-staging-border: rgba(33, 150, 243, .4);--color-staging-shadow: rgba(33, 150, 243, .3);--color-production-bg: rgba(76, 175, 80, .22);--color-production-text: #66bb6a;--color-production-border: rgba(76, 175, 80, .4);--color-production-shadow: rgba(76, 175, 80, .3);--color-arcade-bg: rgba(158, 25, 210, .22);--color-arcade-text: #ba68c8;--color-arcade-border: rgba(158, 25, 210, .4);--color-arcade-shadow: rgba(158, 25, 210, .3);--color-env-bg: rgba(210, 25, 25, .22);--color-env-text: rgb(239, 83, 80);--color-env-border: rgba(210, 25, 25, .4);--color-env-shadow: rgba(210, 25, 25, .3);--color-star-bg: rgba(26, 31, 38, 1);--color-star-border: #e6edf3;--color-star-active-bg: rgb(90, 101, 116);--color-star-active-hover: rgb(138, 142, 145);--color-more-badge-bg: rgba(255, 255, 255, .12);--color-more-badge-hover: rgba(255, 255, 255, .18);--color-more-badge-text: #e6edf3;--color-tooltip-bg: #22272e;--color-tooltip-text: #e6edf3;--color-btn-active-bg: #e6edf3;--color-btn-active-text: #0f1419;--color-placeholder-bg-start: #22272e;--color-placeholder-bg-end: #2d333b;--color-service-badge-bg: #3a3a3a;--color-service-badge-border: rgba(255, 255, 255, .2)}html,body{background:var(--color-bg-primary);color:var(--color-text-primary)}.loading{position:fixed;inset:0;width:100%;height:100%;background-color:var(--color-bg-primary);display:flex;align-items:center;justify-content:center;z-index:9999}.spinner{width:32px;height:32px;border:1px solid var(--color-border-primary);border-left-color:var(--color-text-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.project-card{background:var(--color-card-bg);border:1px solid var(--color-border-primary);border-radius:12px;padding:1.5rem .75rem 1em;text-align:left;transition:transform .2s ease,box-shadow .2s ease;display:flex;flex-direction:column}.project-card:hover{transform:translateY(-4px);border-color:var(--color-border-hover);box-shadow:0 8px 24px var(--color-shadow-lg)}.project-card.hidden{display:none!important}.project-card .project-poster{width:calc(100% + 1.5rem);margin:-1.5rem -.75rem 0rem;border-radius:12px 12px 0 0;overflow:hidden;aspect-ratio:16/9;background:linear-gradient(135deg,#0000000d,#00000005);position:relative;isolation:isolate;will-change:transform}.project-card .project-poster img{width:100%;height:100%;object-fit:cover;transition:transform .2s ease;backface-visibility:hidden}.project-card .project-poster:hover img{transform:scale(1.05)}.project-card .project-poster.placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-placeholder-bg-start) 0%,var(--color-placeholder-bg-end) 100%)}.project-card .project-poster.placeholder:before{content:"📷";font-size:3rem;opacity:.3}.project-card .favorite-star{position:absolute;top:.5rem;right:.5rem;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--color-star-bg);border:none;border-radius:50%;cursor:pointer;transition:all .2s ease;z-index:10;padding:0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 2px 8px var(--color-shadow-md)}.project-card .favorite-star svg{width:15px;height:15px;stroke:var(--color-star-border);fill:transparent;transition:all .2s ease}.project-card .favorite-star:hover{background:var(--color-star-bg);transform:scale(1.15);box-shadow:0 4px 12px var(--color-shadow-lg)}.project-card .favorite-star:hover svg{stroke:var(--color-star-active-bg)}.project-card .favorite-star.is-favorite{background:var(--color-star-active-bg)}.project-card .favorite-star.is-favorite svg{fill:#fff;stroke:#fff}.project-card .favorite-star.is-favorite:hover{background:var(--color-star-active-hover);transform:scale(1.15) rotate(10deg)}@media(max-width:767px){.project-card .favorite-star{width:32px;height:32px}.project-card .favorite-star svg{width:18px;height:18px}}.project-card h3{color:var(--color-text-primary);font-size:.9em;word-wrap:break-word;overflow-wrap:break-word}.project-links{display:flex;flex-direction:column;gap:.5rem}.links-tools,.links-envs{display:flex;gap:.5rem}.link-badge{display:inline-flex;align-items:center;justify-content:center;padding:.5em;max-height:40px;max-width:40px;height:2.25em;border-radius:6px;width:2.25em;font-size:1em;font-weight:500;text-decoration:none;transition:transform .2s ease,box-shadow .2s ease;background:var(--color-badge-bg);color:var(--color-text-primary);border:1px solid var(--color-badge-border)}.link-badge:hover{background:var(--color-badge-bg-hover);transform:translateY(-4px);box-shadow:0 8px 24px var(--color-shadow-lg)}.link-badge.has-date-tooltip{position:relative}.link-badge.has-date-tooltip:before{content:"";position:absolute;top:3px;right:3px;width:6px;height:6px;background:currentColor;border-radius:50%;opacity:.4;z-index:1;transition:opacity .2s ease}.link-badge.has-date-tooltip .date-tooltip-panel{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%) translateY(10px);background:var(--color-tooltip-bg);border-radius:6px;box-shadow:0 8px 24px var(--color-shadow-lg);padding:8px 12px;font-size:12px;font-weight:600;white-space:nowrap;opacity:0;visibility:hidden;transition:all .3s cubic-bezier(.68,-.55,.265,1.55);z-index:1000;color:var(--color-tooltip-text)}.link-badge.has-date-tooltip .date-tooltip-panel:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%) rotate(45deg);width:12px;height:12px;background:var(--color-tooltip-bg);box-shadow:0 8px 24px var(--color-shadow-lg)}.link-badge.has-date-tooltip:hover .date-tooltip-panel{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.link-badge.has-date-tooltip:hover:before{opacity:.7}.link-badge.figma,.link-badge.firebase,.link-badge.notion,.link-badge.github,.link-badge.service-badge{background:var(--color-service-badge-bg);border:1px solid var(--color-service-badge-border)}.link-badge.figma svg,.link-badge.firebase svg,.link-badge.notion svg,.link-badge.github svg,.link-badge.service-badge svg{display:block;width:100%;height:100%}.link-badge.development{background:var(--color-dev-bg);color:var(--color-dev-text);border-color:var(--color-dev-border)}.link-badge.development:hover{background:var(--color-dev-bg);box-shadow:0 4px 12px var(--color-dev-shadow)}.link-badge-env{height:100%;max-width:initial;width:fit-content;background:var(--color-env-bg);color:var(--color-env-text);border-color:var(--color-env-border)}.link-badge-env .env-name{font-size:.8em;padding:0 .35em}.link-badge-env:hover{background:var(--color-env-bg);box-shadow:0 4px 12px var(--color-env-shadow)}.link-badge.qa{background:var(--color-qa-bg);color:var(--color-qa-text);border-color:var(--color-qa-border)}.link-badge.qa:hover{background:var(--color-qa-bg);box-shadow:0 4px 12px var(--color-qa-shadow)}.link-badge.arcade{background:var(--color-arcade-bg);color:var(--color-arcade-text);border-color:var(--color-arcade-border)}.link-badge.arcade:hover{background:var(--color-arcade-bg);box-shadow:0 4px 12px var(--color-arcade-shadow)}.link-badge.staging{background:var(--color-staging-bg);color:var(--color-staging-text);border-color:var(--color-staging-border)}.link-badge.staging:hover{background:var(--color-staging-bg);box-shadow:0 4px 12px var(--color-staging-shadow)}.link-badge.production{background:var(--color-production-bg);color:var(--color-production-text);border-color:var(--color-production-border)}.link-badge.production:hover{background:var(--color-production-bg);box-shadow:0 4px 12px var(--color-production-shadow)}.link-badge.more-badge{position:relative;display:flex;align-items:center;justify-content:center;background:var(--color-more-badge-bg);border-radius:6px;cursor:pointer;transition:transform .2s ease;aspect-ratio:1}.link-badge.more-badge .more-badge-label{font-size:.8em;font-weight:600;color:var(--color-more-badge-text)}.link-badge.more-badge:hover{background:var(--color-more-badge-hover);transform:translateY(-4px)}.link-badge.more-badge:hover .more-badges-panel{opacity:1;visibility:visible;transform:translateY(0)}.more-badges-panel{position:absolute;bottom:calc(100% + 8px);right:0;max-width:200px;background:var(--color-tooltip-bg);border-radius:8px;box-shadow:0 4px 12px var(--color-shadow-lg);padding:12px;display:flex;justify-content:center;gap:8px;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .3s cubic-bezier(.68,-.55,.265,1.55);z-index:100}.more-badges-panel:before{content:"";position:absolute;bottom:-6px;right:12px;width:12px;height:12px;background:var(--color-tooltip-bg);transform:rotate(45deg);box-shadow:2px 2px 4px var(--color-shadow-sm)}.more-badges-panel .link-badge{margin:0;width:40px}.more-badges-panel .link-badge:hover{transform:none}@media(max-width:767px){.more-badges-panel{right:auto;left:0;min-width:160px}.more-badges-panel:before{right:auto;left:12px}}.project-meta{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}.date{color:var(--color-text-tertiary);font-size:.7em;display:flex;align-items:center;gap:.35em}.date svg{flex-shrink:0;opacity:.7;align-self:center;width:.75rem}#filters-container{position:sticky;top:0;z-index:100;background:var(--color-bg-secondary);padding-top:1rem;padding-bottom:1rem;transition:transform .15s ease,box-shadow .15s ease;box-shadow:0 2px 8px #0000}@media(max-width:1439px){#filters-container{max-width:1360px;margin:0 auto;padding:1rem}}#filters-container.is-stuck{box-shadow:0 2px 8px var(--color-shadow-md)}#filters-container.hide-on-scroll{transform:translateY(-100%)}#filters-container>*{max-width:1360px;margin-left:auto;margin-right:auto}.search-container{margin-bottom:1rem}.search-input{width:100%;padding:.75rem 1.25rem;font-size:1rem;color:var(--color-text-primary);background:var(--color-input-bg);border:1px solid var(--color-border-secondary);border-radius:50px;outline:none}.search-input:focus{border-color:var(--color-border-hover);background:var(--color-input-bg);box-shadow:0 0 0 3px var(--color-shadow-sm)}.search-input::placeholder{color:var(--color-text-quaternary)}.filters-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}@media(max-width:768px){.filters-row{flex-direction:column;align-items:stretch}}.layout-switch{display:flex;gap:.5rem;align-items:center}@media(max-width:768px){.layout-switch{justify-content:stretch}}.layout-btn{display:flex;align-items:center;gap:.5rem;height:40px;padding:0 1rem;background:var(--color-bg-secondary);border:1px solid var(--color-border-secondary);border-radius:8px;color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease;font-size:.9rem}.layout-btn:hover{background:var(--color-bg-hover);border-color:var(--color-border-hover)}.layout-btn.active{background:var(--color-btn-active-bg);border-color:var(--color-btn-active-bg);color:var(--color-btn-active-text)}@media(max-width:768px){.layout-btn{flex:1;justify-content:center}}.layout-btn-favorites .star-icon{stroke:currentColor;fill:transparent;transition:all .2s ease}.layout-btn-favorites:hover .star-icon{stroke:#858585}.layout-btn-favorites.active{background:#858585;border-color:#858585;color:#fff}.layout-btn-favorites.active .star-icon{fill:#fff;stroke:#fff}.layout-btn-favorites.active:hover{background:#6d6d6d;border-color:#6d6d6d}.layout-btn-theme{position:relative}.layout-btn-theme .theme-icon{stroke:currentColor}.layout-btn-theme .theme-icon-moon{opacity:1}.layout-btn-theme .theme-icon-sun{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);opacity:0}html.dark-mode .layout-btn-theme .theme-icon-moon{opacity:0}html.dark-mode .layout-btn-theme .theme-icon-sun{opacity:1}.sort-controls{display:flex;align-items:center;gap:.5rem}@media(max-width:768px){.sort-controls{width:100%}}.sort-select-wrapper{position:relative;display:inline-flex;align-items:center;height:40px}@media(max-width:768px){.sort-select-wrapper{width:100%}}.sort-icon{position:absolute;left:.5rem;display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;fill:var(--color-text-primary);flex-shrink:0;pointer-events:none;z-index:1}.sort-icon svg{width:100%;height:100%;display:block}.sort-select{position:relative;padding:.5rem 1.5rem .5rem 2rem;font-size:.9rem;font-weight:500;color:var(--color-text-primary);background:var(--color-bg-secondary);border:1px solid var(--color-border-secondary);border-radius:8px;cursor:pointer;outline:none;appearance:none;-webkit-appearance:none;-moz-appearance:none;height:100%;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23181a1f' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .25rem center;background-size:1rem}html.dark-mode .sort-select{background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23e6edf3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e")}.sort-select:hover{background-color:var(--color-bg-hover);border-color:var(--color-border-hover)}.sort-select:focus{border-color:var(--color-text-primary);box-shadow:0 0 0 3px var(--color-shadow-sm);transition:none}@media(max-width:768px){.sort-select{width:100%;font-size:.85rem}}.sort-select option{padding:.5rem;font-weight:500;color:var(--color-text-primary);background:var(--color-bg-secondary)}.project-counter{display:inline-flex;align-items:center;justify-content:center;gap:.25rem;height:40px;padding:0 .75rem;background:var(--color-bg-secondary);border:1px solid var(--color-border-secondary);border-radius:8px;font-size:.9rem;font-weight:500;color:var(--color-text-primary);flex-shrink:0}.project-counter #project-count-visible{color:var(--color-text-primary)}.project-counter .project-count-separator{color:var(--color-text-tertiary);margin:0 .125rem}.project-counter #project-count-total{color:var(--color-text-tertiary)}.airtable-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--color-bg-secondary);border:1px solid var(--color-border-secondary);border-radius:8px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;text-decoration:none;flex-shrink:0}.airtable-btn img{width:24px;height:24px;display:block}.airtable-btn:hover{transform:translateY(-4px);box-shadow:0 4px 12px var(--color-shadow-lg)}@media(max-width:768px){.airtable-btn img{width:20px;height:20px}}.grid-icon{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:2px;width:14px;height:14px}.grid-icon div{background:currentColor;border-radius:2px}.list-icon{display:flex;flex-direction:column;justify-content:space-between;width:14px;height:14px}.list-icon span{display:block;width:100%;height:3px;background:currentColor;border-radius:2px}.projects-container{width:100%}.projects-grid-layout{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;width:100%}@media(max-width:1439px){.projects-grid-layout{gap:1rem}}.projects-grid-layout .project-card{display:flex;flex-direction:column;height:100%;gap:1em}.projects-grid-layout .project-card.has-badge-hovered{z-index:1}.projects-grid-layout .project-card .project-infos{flex:1;display:flex;flex-direction:column;gap:.25em}.projects-grid-layout .project-card .list-main-row{display:contents}.projects-grid-layout .project-card .project-data{margin-top:auto;padding-top:1em}.projects-grid-layout .project-card .project-meta{margin-right:auto;flex-direction:row;flex-wrap:wrap}.projects-grid-layout .project-card .meta-row{display:contents}@media(max-width:767px){.projects-grid-layout{grid-template-columns:1fr}}.projects-list-layout{display:flex;flex-direction:column;gap:.75rem;width:100%;padding-top:.25rem}@media(max-width:1023px){.projects-list-layout{gap:1.5rem}}.projects-list-layout .project-data{display:flex;flex-direction:column;gap:1rem;align-content:flex-end;align-items:flex-end;margin-left:auto;order:3;align-self:center}@media(max-width:1023px){.projects-list-layout .project-data{margin-top:auto;margin-right:auto;margin-left:initial;align-content:initial;align-items:initial}}.projects-list-layout .more-badges-panel{bottom:initial;top:calc(100% + 8px);box-shadow:0 -4px 12px #00000026}.projects-list-layout .more-badges-panel:before{bottom:initial;top:-6px;box-shadow:-2px -2px 4px #0000000d}.projects-list-layout .project-card{width:100%;flex-direction:row;align-items:center;gap:1rem;padding:.5rem}.projects-list-layout .project-card:hover,.projects-list-layout .project-card.has-badge-hovered{z-index:1}@media(max-width:1023px){.projects-list-layout .project-card{align-items:flex-start;gap:1rem}}.projects-list-layout .project-card .project-infos{display:flex;gap:1rem;width:100%;justify-content:center;flex:1;align-self:stretch}@media(max-width:1023px){.projects-list-layout .project-card .project-infos{display:flex;flex:1;flex-direction:column;width:100%;gap:.25em;align-self:stretch;justify-content:space-between}}@media(max-width:639px){.projects-list-layout .project-card .project-infos{flex-direction:column;align-items:center}}.projects-list-layout .project-card .project-poster{width:100%;max-width:100px;aspect-ratio:16/9;margin:0;border-radius:8px;flex-shrink:0;position:relative}@media(max-width:1023px){.projects-list-layout .project-card .project-poster img{position:absolute;top:0;left:0}}.projects-list-layout .project-card .project-poster.placeholder:before{font-size:1.5rem}@media(max-width:1023px){.projects-list-layout .project-card .project-poster{width:17.5%;height:100%;max-width:initial;min-width:auto;aspect-ratio:initial;min-height:90px}.projects-list-layout .project-card .project-poster.placeholder:before{font-size:3rem}}@media(max-width:767px){.projects-list-layout .project-card .project-poster{display:none}}.projects-list-layout .project-card .list-main-row{align-self:center;display:flex;flex-direction:row;gap:1em}@media(max-width:1023px){.projects-list-layout .project-card .list-main-row{margin-right:auto;flex-direction:column;gap:.25em}}.projects-list-layout .project-card h3{margin:0;flex-shrink:0}@media(max-width:1023px){.projects-list-layout .project-card h3{min-width:auto}}.projects-list-layout .project-card .project-links{margin:0;flex-shrink:0;flex-direction:row}@media(max-width:1023px){.projects-list-layout .project-card .project-links{margin:0 auto}}@media(max-width:767px){.projects-list-layout .project-card .project-links{margin-top:1em}}@media(max-width:639px){.projects-list-layout .project-card .project-links{flex-wrap:wrap}}.projects-list-layout .project-card .project-links .links-envs{margin-bottom:0}.projects-list-layout .project-card .project-meta{display:flex;flex-direction:column;align-self:center;transform:translateY(2px)}.projects-list-layout .project-card .project-meta.none{display:none}@media(max-width:1023px){.projects-list-layout .project-card .project-meta{margin-right:auto;margin-left:initial;flex-wrap:wrap;transform:translateY(0)}}.loading,.no-projects,.error{grid-column:1/-1;text-align:center;padding:3rem;font-size:1.2rem;color:#0009}.error{color:#181a1f;background:#0000000d;border:1px solid rgba(0,0,0,.2);border-radius:8px}body{--text: calc((16px) * var(--h-demult, 1))}@media(min-width:1024px)and (max-width:1919px){body{--text: calc((.4464285714vw + 9.4285714286px) * var(--h-demult, 1))}}@media(min-width:1920px){body{--text: calc((18px) * var(--h-demult, 1))}}body{min-height:100vh;font-size:var(--text);color:#181a1f;margin:0;padding:0}body h1{line-height:1.2;font-weight:700}#app{min-height:100vh;padding:2rem 0;width:100vw}@media(max-width:1439px){#app{padding:0;width:100%}}.container{max-width:1360px;margin:0 auto;padding-top:1rem}@media(max-width:1439px){.container{padding:1rem}}header{text-align:center;margin-bottom:3rem;padding-bottom:2rem;border-bottom:2px solid rgba(0,0,0,.1)}h1{font-size:3rem;margin:0 0 .5rem;color:#181a1f}@media(max-width:768px){h1{font-size:2rem}}.subtitle{font-size:1.2rem;color:#0009;margin:0}@media(max-width:768px){.subtitle{font-size:1rem}}#projects-list{width:100%}.tp-dfwv{width:276px!important;z-index:5}canvas{position:fixed;width:100%;height:100%;top:0;left:0;z-index:2}.background{width:100%;height:100%;position:fixed}.touch-gui{position:fixed;bottom:5px;left:5px;z-index:5;display:none}@media screen and (hover:none)and (pointer:coarse){.touch-gui{display:block}}.wrapper{position:relative;z-index:1;width:100%;min-height:calc(var(--vh, 1vh) * 100);overflow:hidden;scroll-behavior:auto;overflow-y:scroll;overscroll-behavior-y:none;height:100svh;pointer-events:all;scrollbar-width:none;-ms-overflow-style:none}.wrapper::-webkit-scrollbar{display:none}.content-scroll{position:relative;min-height:calc(var(--vh, 1vh) * 100);width:100%;overscroll-behavior-y:contain;z-index:30}
