:root{--bg:#f7f3ee;--surface:#ede8e3;--text:#2b2420;--text-muted:#5c534d;--rule:#2b242024;--accent:#2a6b6e;--accent-muted:#2a6b6e38;--font-heading:"Lora", Georgia, "Times New Roman", serif;--font-body:"Source Serif 4", Georgia, "Times New Roman", serif;font-family:var(--font-body);font-optical-sizing:auto;color:var(--text);background-color:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:18px;line-height:1.62}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}body{min-height:100dvh;margin:0;position:relative}body:before{content:"";z-index:0;pointer-events:none;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='280' height='280' viewBox='0 0 280 280'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;position:fixed;inset:0}#root{z-index:1;min-height:100dvh;position:relative}a{color:var(--accent);text-underline-offset:3px;text-decoration-thickness:1px}a:hover{color:#1f5356}button{font-family:inherit}.reveal{opacity:0;transition:opacity .7s,transform .7s;transform:translateY(12px)}.reveal--visible{opacity:1;transform:translateY(0)}@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transition:none;transform:none}}.app{max-width:58rem;margin:0 auto;padding:0 clamp(1.35rem,5vw,2.5rem) 3rem}.site-header{z-index:10;background:color-mix(in srgb, var(--bg) 88%, transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--rule);width:100%;position:sticky;top:0}.site-header__inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem 1.5rem;max-width:58rem;margin:0 auto;padding:1.15rem clamp(1.35rem,5vw,2.5rem);display:flex}.site-name{font-family:var(--font-heading);color:var(--text);letter-spacing:.01em;margin:0;font-size:1.2rem;font-weight:500}.site-name a{color:inherit;text-decoration:none}.site-name a:hover{color:var(--accent)}.nav{flex-wrap:wrap;align-items:center;gap:.15rem 1.1rem;display:flex}.nav a{font-family:var(--font-body);color:var(--text-muted);letter-spacing:.02em;border-bottom:1px solid #0000;padding:.25rem 0;font-size:.88rem;font-weight:400;text-decoration:none;transition:color .3s,border-color .3s}.nav a:hover{color:var(--text)}.nav a.active{color:var(--text);border-bottom-color:var(--accent)}.nav a:focus-visible{outline:1px solid var(--accent);outline-offset:4px}.page-section{border-bottom:1px solid var(--rule);padding:3.5rem 0;scroll-margin-top:4.5rem}.page-section--last{border-bottom:none}.section-intro{max-width:40rem;margin-bottom:2rem}.section-kicker{font-family:var(--font-heading);letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin:0 0 .65rem;font-size:.72rem;font-weight:600}.section-heading{font-family:var(--font-heading);color:var(--text);letter-spacing:.01em;margin:0;font-size:clamp(1.55rem,3.5vw,2rem);font-weight:500;line-height:1.28}.section-lead{color:var(--text-muted);max-width:36em;margin:.85rem 0 0}.prose p{color:var(--text);max-width:38em;margin:0}.prose p+p{margin-top:1rem}.page-section--first{padding-top:1.5rem}.project-list{flex-direction:column;gap:1.5rem;display:flex}.project-feature{color:#f7f3ee;background:#2b2420;border:1px solid #f7f3ee14;border-radius:14px;grid-template-columns:1fr;transition:box-shadow .3s;display:grid;overflow:hidden}.project-feature:hover{box-shadow:0 8px 32px #2b24202e}@media (width>=768px){.project-feature{grid-template-columns:minmax(0,1.12fr) minmax(0,1fr);min-height:22rem}}.project-feature__media{background:#1f1a17;justify-content:center;align-items:center;padding:1rem;display:flex}@media (width>=768px){.project-feature__media{padding:1.15rem}}.project-feature__preview{border-radius:10px;width:100%;line-height:0;transition:opacity .3s;display:block;overflow:hidden}.project-feature__preview:hover{opacity:.92}.project-feature__preview:focus-visible{outline-offset:3px;outline:2px solid #f7f3ee}.project-feature__preview img{object-fit:cover;object-position:top center;width:100%;height:100%;min-height:12rem;display:block}@media (width>=768px){.project-feature__preview img{min-height:100%}}.project-feature__placeholder{color:#f7f3ee8c;width:100%;min-height:12rem;font-family:var(--font-heading);border:1px dashed #f7f3ee2e;border-radius:10px;justify-content:center;align-items:center;font-size:1.1rem;display:flex}.project-feature__content{flex-direction:column;padding:1.35rem 1.35rem 1.5rem;display:flex}@media (width>=768px){.project-feature__content{padding:1.65rem 1.75rem 1.75rem}}.project-feature__category{letter-spacing:.12em;text-transform:uppercase;color:#f7f3eeb8;border:1px solid #f7f3ee38;border-radius:999px;align-self:flex-start;margin-bottom:.85rem;padding:.32rem .65rem;font-size:.68rem;font-weight:600;display:inline-flex}.project-feature__title{font-family:var(--font-heading);color:#f7f3ee;margin:0 0 .75rem;font-size:clamp(1.45rem,3vw,1.85rem);font-weight:500;line-height:1.2}.project-feature__summary{color:#f7f3eec7;max-width:34em;margin:0;font-size:.94rem;line-height:1.58}.project-feature__tags{flex-wrap:wrap;gap:.45rem;margin:1rem 0 0;padding:0;list-style:none;display:flex}.project-feature__tags li{letter-spacing:.03em;color:#f7f3eeb8;background:#f7f3ee0a;border:1px solid #f7f3ee29;border-radius:999px;padding:.3rem .6rem;font-size:.72rem;font-weight:500}.project-feature__attribution{color:#f7f3ee80;max-width:34em;margin:.85rem 0 0;font-size:.72rem;line-height:1.45}.project-feature__actions{margin-top:auto;padding-top:1.25rem}.project-feature__cta{color:#2b2420;width:100%;font-family:var(--font-body);background:#f7f3ee;border:none;border-radius:10px;justify-content:center;align-items:center;gap:.45rem;padding:.8rem 1.1rem;font-size:.92rem;font-weight:600;text-decoration:none;transition:background .3s,transform .25s;display:inline-flex}.project-feature__cta:hover{background:#fff}.project-feature__cta--soon{opacity:.7;cursor:not-allowed}.project-feature__cta--soon:hover{background:#f7f3ee}.project-feature__cta:focus-visible{outline-offset:3px;outline:2px solid #f7f3ee}.project-feature__cta-icon{font-size:.95rem;line-height:1}.project-feature__secondary{flex-wrap:wrap;gap:.75rem 1rem;margin-top:.75rem;display:flex}.project-feature__secondary a{color:#f7f3ee9e;font-size:.82rem;text-decoration:none;transition:color .3s}.project-feature__secondary a:hover{color:#f7f3ee;text-decoration:underline}.project-feature__secondary a:focus-visible{outline-offset:3px;outline:1px solid #f7f3ee}.timeline{flex-direction:column;gap:1rem;margin-bottom:2.25rem;display:flex}.timeline-card{border:1px solid var(--rule);background:0 0;padding:1.2rem 1.25rem}.timeline-card__head{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:.35rem 1rem;margin-bottom:.35rem;display:flex}.timeline-card__head h3{font-family:var(--font-heading);color:var(--text);margin:0;font-size:1.1rem;font-weight:500}.timeline-card__period{color:var(--text-muted);letter-spacing:.02em;font-size:.82rem}.timeline-card__role{color:var(--accent);margin:0 0 .5rem;font-size:.92rem;font-weight:600}.timeline-card__detail{color:var(--text-muted);max-width:40em;margin:0;font-size:.95rem}.credentials__title{font-family:var(--font-heading);letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin:0 0 .75rem;font-size:.82rem;font-weight:600}.credentials__list{flex-wrap:wrap;gap:.45rem .65rem;margin:0;padding:0;list-style:none;display:flex}.credentials__list li{color:var(--text);border:1px solid var(--rule);background:var(--surface);padding:.35rem .65rem;font-size:.88rem}.contact-cards{gap:.75rem;display:grid}@media (width>=520px){.contact-cards{grid-template-columns:repeat(2,1fr)}}.contact-card{background:var(--surface);border:1px solid var(--rule);border-left:3px solid var(--accent);flex-direction:column;gap:.35rem;padding:1.15rem 1.2rem;text-decoration:none;transition:border-color .3s,background .3s;display:flex}.contact-card:hover{border-color:var(--accent-muted);background:color-mix(in srgb, var(--surface) 70%, var(--bg))}.contact-card__label{font-family:var(--font-heading);letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-size:.68rem;font-weight:600}.contact-card__value{color:var(--text);overflow-wrap:anywhere;font-size:.98rem}.contact-card__arrow{color:var(--accent);margin-top:.35rem;font-size:1rem;transition:transform .25s}.contact-card:hover .contact-card__arrow{transform:translate(4px)}.contact-card:focus-visible{outline:1px solid var(--accent);outline-offset:3px}.site-footer{border-top:1px solid var(--rule);margin-top:1rem;padding-top:1.5rem}.site-footer p{color:var(--text-muted);letter-spacing:.02em;margin:0;font-size:.82rem}
