.banner{width:100%;overflow:hidden;height:2.25rem}.banner__track{display:flex;gap:.75rem;width:max-content;animation:marquee 30s linear infinite}.banner__chip{display:inline-flex;align-items:center;padding:0 .875rem;height:1.75rem;border-radius:9999px;font-size:.75rem;font-weight:500;background:var(--colour-surface);border:1px solid var(--colour-border);color:var(--colour-fg);white-space:nowrap;flex-shrink:0}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.typewriter-cursor{display:inline-block;width:4px;height:.85em;background:var(--colour-bg);margin-left:.25rem;vertical-align:middle}.typewriter-cursor--blink{animation:blink 1s infinite}@keyframes fade-in-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hero{position:relative;width:100%;min-height:680px;border-radius:1rem;overflow:hidden;margin:4.5rem auto 0}.hero__bg{position:absolute;inset:0}.hero__bg-image{width:100%;height:100%;object-fit:cover}.hero__overlay{position:absolute;inset:0;background:var(--overlay-bg)}.hero__content{position:relative;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:680px;padding:0 1.25rem;text-align:center}.hero__title{font-size:2.25rem;font-weight:700;color:var(--colour-surface);margin-bottom:1.5rem;opacity:0;animation:fade-in-up .8s ease forwards}@media (min-width:640px){.hero__title{font-size:3rem}}@media (min-width:1024px){.hero__title{font-size:3.75rem}}.hero__subtitle{font-size:1rem;color:var(--colour-surface);font-family:var(--font-sans);max-width:36rem;line-height:1.625;margin-bottom:2.5rem;opacity:0;animation:fade-in-up .8s ease .4s forwards}@media (min-width:640px){.hero__subtitle{font-size:1.125rem}}@media (min-width:1024px){.hero__subtitle{font-size:1.25rem}}.hero__subtitle p{font-weight:600}.hero__subtitle span{font-weight:800}.hero__ctas{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem;opacity:0;animation:fade-in-up .8s ease .6s forwards}.hero__btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:600;font-size:.875rem;text-decoration:none;transition:transform .2s ease}.hero__btn:hover{transform:translateY(-2px)}.hero__btn--primary{background:var(--colour-accent);color:var(--sand-200);box-shadow:var(--shadow-lg);border:1px solid var(--colour-accent)}.hero__btn--secondary{border:1px solid var(--colour-bg);color:var(--colour-bg);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.hero__bottom-strip{position:absolute;bottom:1.25rem;left:1.25rem;right:1.25rem;z-index:20;display:flex;flex-direction:column;align-items:flex-start;gap:.5rem}@media (min-width:768px){.hero__bottom-strip{flex-direction:row;align-items:center;gap:1.5rem}}.hero__location{font-size:.875rem;font-weight:500;color:var(--colour-bg);white-space:nowrap}.hero__banner-wrap{flex:1;min-width:0}.about{padding:5rem 0;background:var(--colour-bg);font-family:Space Grotesk,sans-serif}.about__container{max-width:1200px;margin:0 auto;padding:0 1.5rem;display:flex;flex-direction:column;gap:3rem;align-items:center}@media (min-width:768px){.about__container{flex-direction:row}}.about__text-block{flex:1;display:flex;flex-direction:column;gap:1rem}.about__heading{font-size:1.875rem;font-weight:700;color:var(--colour-accent);letter-spacing:-.025em}@media (min-width:640px){.about__heading{font-size:2.25rem}}.about__paragraph{font-size:1rem;line-height:1.625;color:var(--colour-fg)}.about__paragraph--muted{color:var(--colour-fg-muted)}.about__image-block{flex:1;display:flex;align-items:center;justify-content:center}.about__portrait{width:18rem;height:18rem;object-fit:cover;border-radius:9999px;border:1px solid var(--colour-border);box-shadow:var(--shadow-lg);background:var(--colour-surface)}@media (min-width:640px){.about__portrait{width:20rem;height:20rem}}@media (min-width:1024px){.about__portrait{width:24rem;height:24rem}}.c-skill-item{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:500;background:var(--colour-secondary);border:1px solid var(--colour-secondary);color:var(--colour-bg);white-space:nowrap;transition:background .15s ease,border-color .15s ease}.c-skill-item:hover{background:var(--colour-accent);border-color:var(--colour-primary)}.c-skill-item-iconwrap{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.c-skill-item-icon{width:18px;height:18px;object-fit:contain;display:block}.c-skill-item-label{line-height:1}.c-skill-group{background:var(--colour-bg);border:1px solid var(--colour-border);border-radius:var(--radius-md,.5rem);padding:1.25rem;transition:transform .2s ease,box-shadow .2s ease}.c-skill-group:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.c-skill-group--title{font-size:.875rem;font-weight:600;color:var(--colour-accent);margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.05em}.c-skill-group--list{display:flex;flex-wrap:wrap;gap:.5rem;list-style:none;padding:0;margin:0}@keyframes marquee{0%{transform:translateX(0)}to{transform:translateX(-50%)}}@keyframes marquee-reverse{0%{transform:translateX(-50%)}to{transform:translateX(0)}}.c-skillscarousel{display:flex;flex-direction:column;gap:.75rem}.c-row,.c-skillscarousel{width:100%;overflow:hidden}.c-row:nth-child(2n) .c-track{animation-name:marquee-reverse}.c-track{display:flex;gap:.75rem;width:max-content;animation:marquee 30s linear infinite}.c-skillscarousel:hover .c-track{animation-play-state:paused}.c-item{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .875rem;border-radius:9999px;font-size:.8125rem;font-weight:500;background:var(--colour-bg);border:1px solid var(--colour-border);color:var(--colour-fg);white-space:nowrap;flex-shrink:0;transition:background .15s ease,border-color .15s ease}.c-item:hover{background:var(--colour-muted);border-color:var(--colour-primary)}.c-item-icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.c-item-iconimg{width:20px;height:20px;object-fit:contain;display:block}.c-item-label{line-height:1}.c-skill{padding:4rem 1.5rem;background:var(--colour-surface);color:var(--colour-fg);margin:0 auto}.c-skill-title{text-align:center;color:var(--colour-accent);font-size:3.25rem;font-weight:600;letter-spacing:-.025em;margin-bottom:1.5rem}@media (min-width:768px){.c-skill-title{font-size:2.25rem;font-weight:500}}.c-skill-toggle{display:flex;justify-content:center;gap:1.5rem;border:none;padding:0;margin:0 0 2rem}.c-skill-toggle-option{display:inline-flex;align-items:center;gap:.375rem;cursor:pointer;padding:.375rem 1rem;border-radius:9999px;font-size:.875rem;font-weight:500;border:1px solid var(--colour-border);background:var(--colour-bg);color:var(--colour-fg);transition:background .2s ease,color .2s ease,border-color .2s ease}.c-skill-toggle-option:has(input:checked){background:var(--colour-accent);color:var(--colour-bg);border-color:var(--colour-accent)}.c-skill-toggle-option:hover{color:var(--colour-fg)}.c-skill-toggle-option:has(input:checked):hover{color:var(--colour-fg)}.c-skill-toggle-option input[type=radio]{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}.c-skill-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media (min-width:640px){.c-skill-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.c-skill-grid{grid-template-columns:repeat(3,1fr)}}.c-skill-carousel-wrap{width:100%;overflow:hidden}.c-project{background:var(--colour-surface);color:var(--colour-fg);border:1px solid var(--colour-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.c-project-media{width:100%;height:11rem;object-fit:cover;display:block}.c-project-body{padding:1rem}.c-project-title{font-size:16px;line-height:26px;font-weight:600;color:var(--colour-fg)}.c-project-tags{margin-top:.25rem;color:var(--colour-fg-muted);font-size:14px;line-height:24px}.c-project-link{margin-top:.5rem;display:inline-flex;align-items:center;gap:.25rem;color:var(--colour-link);text-decoration:none}.c-project-link:hover{text-decoration:underline}@media (max-width:768px){.c-project-title{font-size:14px;line-height:24px;font-weight:600;color:var(--colour-fg)}.c-project-tags{font-size:12px;line-height:22px}}.c-projects{width:100%;display:flex;flex-direction:column;align-items:center;padding:4rem 0;background:var(--colour-bg);color:var(--colour-fg)}.c-projects-title{text-align:center;color:var(--colour-accent);font-size:36px;line-height:44px;letter-spacing:-.02em;font-weight:500}.c-projects-grid{margin-top:2rem;display:flex;flex-direction:row;gap:1rem}@media (max-width:768px){.c-projects-grid{display:flex;flex-direction:column}.c-projects-title{color:var(--colour-primary);font-size:30px;line-height:38px;letter-spacing:0;font-weight:600;margin-bottom:1rem}}.contact{width:100%;padding:4rem 0;background:var(--colour-surface)}.contact__container{width:100%;max-width:1200px;margin:0 auto;padding:2rem}.contact__header{text-align:center;margin-bottom:3rem}.contact__title{font-size:1.875rem;font-weight:700;color:var(--colour-fg);letter-spacing:-.025em;margin-bottom:.75rem}@media (min-width:640px){.contact__title{font-size:2.25rem}}.contact__subtitle{color:var(--colour-fg-muted);font-size:1rem;max-width:28rem;margin:0 auto}.contact__grid{display:grid;gap:2.5rem;max-width:56rem;margin:0 auto}@media (min-width:768px){.contact__grid{grid-template-columns:1fr 1fr}}.contact__info-block{display:flex;flex-direction:column;gap:1.5rem}.contact__info-title{font-size:1.25rem;font-weight:700;color:var(--colour-fg)}.contact__info-card{display:flex;align-items:flex-start;gap:1rem;padding:1rem;border-radius:.75rem;background:var(--colour-bg);border:1px solid var(--colour-border);box-shadow:var(--shadow-sm);transition:transform .2s ease}.contact__info-card:hover{transform:translateY(-2px)}.contact__info-icon{width:3rem;height:3rem;border-radius:.75rem;background:var(--colour-accent);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--colour-bg)}.contact__info-label{font-weight:600}.contact__info-label,.contact__info-link,.contact__info-value{font-size:.875rem;color:var(--colour-fg-muted)}.contact__info-link{text-decoration:none;transition:color .2s ease}.contact__info-link:hover{color:var(--colour-primary)}.contact__response-note{margin-top:1.5rem;padding:1rem;border-radius:.75rem;background:var(--colour-accent);border:1px solid var(--colour-border);box-shadow:var(--drop-shadow-md)}.contact__response-note p{font-size:.875rem;color:var(--colour-fg-muted)}.contact__response-note strong{color:var(--colour-fg)}.contact__form{display:flex;flex-direction:column;gap:1.25rem;padding:1.5rem;border-radius:.75rem;background:var(--colour-bg);border:1px solid var(--colour-border);box-shadow:var(--shadow-md)}.contact__form-title{font-size:1.125rem;font-weight:600;color:var(--colour-fg)}.contact__field-group{display:flex;flex-direction:column;gap:.375rem}.contact__label{font-size:.875rem;font-weight:600;color:var(--colour-fg-muted)}.contact__input,.contact__textarea{width:100%;padding:.75rem 1rem;border-radius:.5rem;background:rgba(1,1,1,.05);border:1px solid var(--colour-border);color:var(--colour-fg-muted);font-size:.875rem;outline:none;transition:box-shadow .2s ease;box-sizing:border-box}.contact__input::placeholder,.contact__textarea::placeholder{color:var(--colour-fg-muted)}.contact__input:focus,.contact__textarea:focus{box-shadow:0 0 0 2px var(--colour-ring)}.contact__textarea{resize:vertical}.contact__submit-btn{width:100%;padding:.75rem;border-radius:.5rem;background:var(--colour-accent);color:var(--colour-bg);font-weight:600;font-size:.875rem;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:transform .2s ease}.contact__submit-btn:hover{transform:translateY(-2px)}.contact__submit-btn:disabled{opacity:.6;cursor:not-allowed}.contact__disclaimer{font-size:.75rem;color:var(--colour-fg-muted);text-align:center}.*{box-sizing:border-box;font-family:Space Grotesk,sans-serif}.navbar{position:fixed;width:100%;top:0;left:0;right:0;z-index:50;background-color:var(--colour-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--colour-border)}.navbar__container{max-width:1200px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;height:4rem}.navbar__logo{font-size:1.25rem;font-weight:700;color:var(--colour-accent);letter-spacing:-.025em;text-decoration:none;font-family:Space Grotesk,sans-serif}.navbar__desktop-list{display:none;align-items:center;gap:2rem;list-style:none;margin:0;padding:0}@media (min-width:768px){.navbar__desktop-list{display:flex}}.navbar__desktop-link{font-size:.875rem;font-weight:500;color:var(--colour-fg-muted);text-decoration:none;transition:color .2s ease}.navbar__desktop-link:hover{color:var(--colour-accent)}.navbar__toggle{display:flex;align-items:center;justify-content:center;padding:.5rem;color:var(--colour-fg);background:none;border:none;cursor:pointer}@media (min-width:768px){.navbar__toggle{display:none}}.navbar__mobile-menu{background:var(--colour-bg);border-bottom:1px solid var(--colour-border)}@media (min-width:768px){.navbar__mobile-menu{display:none}}.navbar__mobile-list{max-width:1200px;margin:0 auto;padding:1rem 1.5rem;display:flex;flex-direction:column;gap:1rem;list-style:none}.navbar__mobile-link{font-size:1rem;font-weight:500;color:var(--colour-fg-muted);text-decoration:none;transition:color .2s ease}.navbar__mobile-link:hover{color:var(--colour-accent)}.footer{padding:2rem 0;border-top:1px solid var(--colour-border);background:var(--colour-bg)}.footer__container{max-width:1200px;margin:0 auto;padding:0 1.5rem;display:flex;flex-direction:column;align-items:center;justify-content:space-between;gap:1rem;font-size:.875rem;color:var(--colour-fg-muted)}@media (min-width:640px){.footer__container{flex-direction:row}}.footer__nav{display:flex;gap:1.5rem}.footer__nav-link{color:var(--colour-fg-muted);text-decoration:none;transition:color .2s ease}.footer__nav-link:hover{color:var(--colour-accent)}