:root{--bg:#f8f7fc;--bg-card:#ffffff;--bg-card-alt:#f3f0ff;--text:#1a1a2e;--text-light:#5a5a7a;--text-dim:#9a9ab0;--border:#e8e6f0;--red:#ef4444;--red-bg:#fef2f2;--red-glow:rgba(239, 68, 68, 0.25);--blue:#3b82f6;--blue-bg:#eff6ff;--blue-glow:rgba(59, 130, 246, 0.25);--green:#22c55e;--green-bg:#f0fdf4;--green-glow:rgba(34, 197, 94, 0.25);--orange:#f97316;--orange-bg:#fff7ed;--orange-glow:rgba(249, 115, 22, 0.25);--purple:#a855f7;--purple-bg:#faf5ff;--purple-glow:rgba(168, 85, 247, 0.25);--indigo:#6366f1;--indigo-bg:#eef2ff;--indigo-glow:rgba(99, 102, 241, 0.25);--teal:#14b8a6;--teal-bg:#f0fdfa;--teal-glow:rgba(20, 184, 166, 0.25);--rose:#f43f5e;--rose-bg:rgba(244,63,94,0.08);--rose-glow:rgba(244,63,94,0.12);--amber:#f59e0b;--amber-bg:#fffbeb;--amber-glow:rgba(245, 158, 11, 0.25);--sky:#0ea5e9;--sky-bg:#f0f9ff;--sky-glow:rgba(14, 165, 233, 0.25);--radius:14px;--radius-lg:24px;--radius-xl:32px;--shadow:0 4px 24px rgba(26, 26, 46, 0.06);--shadow-hover:0 12px 40px rgba(26, 26, 46, 0.1);--transition:0.3s cubic-bezier(0.34, 1.56, 0.64, 1);--spring:0.6s cubic-bezier(0.34, 1.56, 0.64, 1);--bounce:0.5s cubic-bezier(0.68, -0.55, 0.265, 1.55);--navbar-height:64px}@view-transition{navigation:auto}::view-transition-old(root){animation:.45s cubic-bezier(.65,0,.35,1) both vt-fade-out}::view-transition-new(root){animation:.45s cubic-bezier(.65,0,.35,1) both vt-fade-in;animation-delay:.2s}@keyframes vt-fade-out{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.97)}}@keyframes vt-fade-in{from{opacity:0;transform:scale(1.03)}to{opacity:1;transform:scale(1)}}body{opacity:0}body.page-ready{opacity:1;transition:opacity .15s ease}body.page-exit{opacity:0;transition:opacity .12s ease}*,::after,::before{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;font-size:16px}body{font-family:'Plus Jakarta Sans',sans-serif;color:var(--text);background:var(--bg);line-height:1.7;overflow-x:hidden;position:relative;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body::before{content:'';position:fixed;inset:0;background-image:radial-gradient(circle,var(--text-dim) 1px,transparent 1px);background-size:28px 28px;opacity:.07;pointer-events:none;z-index:0}.main-content{position:relative;z-index:1}.footer{position:relative;z-index:1}h1,h2,h3,h4,h5{font-family:'Bricolage Grotesque',Inter,sans-serif;font-weight:800;line-height:1.1;color:var(--text);letter-spacing:-.02em}.display-font{font-family:'Bricolage Grotesque',sans-serif}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto;display:block}#cursor-glow{position:fixed;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(59,130,246,.08) 0,transparent 70%);pointer-events:none;z-index:9999;transform:translate(-50%,-50%);opacity:0;mix-blend-mode:multiply;transition:opacity .3s}#cursor-glow.active{opacity:1}.top-navbar{position:fixed;top:0;left:0;right:0;height:var(--navbar-height);background:#0f0f1a;z-index:1000;display:flex;align-items:center;padding:0 2rem}.navbar-inner{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:1400px;margin:0 auto}.navbar-logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0}.logo-img{height:36px;width:auto}.navbar-menu{display:flex;align-items:center;gap:1rem}.navbar-links{display:flex;align-items:center;gap:.15rem}.navbar-links a{display:flex;align-items:center;gap:.5rem;padding:.45rem .85rem;border-radius:8px;color:rgba(255,255,255,.45);font-size:.88rem;font-weight:600;transition:all var(--transition);text-decoration:none}.navbar-links a:hover{color:rgba(255,255,255,.85);background:rgba(255,255,255,.05)}.navbar-links a.active{color:#fff}.home .navbar-links a.active{background:rgba(239,68,68,.15);box-shadow:inset 0 0 0 1px rgba(239,68,68,.2)}.about .navbar-links a.active{background:rgba(59,130,246,.15);box-shadow:inset 0 0 0 1px rgba(59,130,246,.2)}.laurier .navbar-links a.active,.projects .navbar-links a.active{background:rgba(34,197,94,.15);box-shadow:inset 0 0 0 1px rgba(34,197,94,.2)}.contact .navbar-links a.active,.stjosephs .navbar-links a.active{background:rgba(249,115,22,.15);box-shadow:inset 0 0 0 1px rgba(249,115,22,.2)}.topictide .navbar-links a.active{background:rgba(168,85,247,.15);box-shadow:inset 0 0 0 1px rgba(168,85,247,.2)}.blackberry .navbar-links a.active{background:rgba(99,102,241,.15);box-shadow:inset 0 0 0 1px rgba(99,102,241,.2)}.monaco .navbar-links a.active{background:rgba(215,25,47,.15);box-shadow:inset 0 0 0 1px rgba(215,25,47,.2)}.navbar-links a i{width:16px;display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}.navbar-social{display:flex;align-items:center;gap:.2rem;padding-left:.75rem;border-left:1px solid rgba(255,255,255,.08)}.navbar-social a{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.3);font-size:.85rem;transition:all var(--bounce);background:rgba(255,255,255,.03);text-decoration:none}.navbar-social a:hover{color:#fff;transform:translateY(-2px) scale(1.1)}.home .navbar-social a:hover{background:var(--red)}.about .navbar-social a:hover{background:var(--blue)}.laurier .navbar-social a:hover,.projects .navbar-social a:hover{background:var(--green)}.contact .navbar-social a:hover,.stjosephs .navbar-social a:hover{background:var(--orange)}.topictide .navbar-social a:hover{background:var(--purple)}.blackberry .navbar-social a:hover{background:var(--indigo)}.monaco .navbar-social a:hover{background:var(--red)}.navbar-hamburger{display:none;position:relative;z-index:1001;width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);cursor:pointer;align-items:center;justify-content:center;font-size:1.15rem;color:rgba(255,255,255,.6);transition:all var(--transition)}.navbar-hamburger:hover{background:rgba(255,255,255,.1);color:#fff}.navbar-overlay{display:none;position:fixed;inset:0;top:var(--navbar-height);background:rgba(15,15,26,.6);z-index:999;opacity:0;transition:opacity .35s;pointer-events:none;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.navbar-overlay.show{opacity:1;pointer-events:auto}.main-content{padding-top:var(--navbar-height);min-height:100vh}.page{padding:3rem 3.5rem 4rem;max-width:1200px;margin:0 auto;animation:pageIn .5s ease-out}@keyframes pageIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.page-accent{position:fixed;top:var(--navbar-height);left:0;right:0;height:3px;z-index:998;animation:accentSlide .6s ease-out}.home .page-accent{background:linear-gradient(90deg,var(--red),#f87171)}.about .page-accent{background:linear-gradient(90deg,var(--blue),#60a5fa)}.laurier .page-accent,.projects .page-accent{background:linear-gradient(90deg,var(--green),#4ade80)}.contact .page-accent,.stjosephs .page-accent{background:linear-gradient(90deg,var(--orange),#fb923c)}.topictide .page-accent{background:linear-gradient(90deg,var(--purple),#c084fc)}.blackberry .page-accent{background:linear-gradient(90deg,var(--indigo),#818cf8)}.monaco .page-accent{background:linear-gradient(90deg,var(--red),#f87171)}@keyframes accentSlide{from{transform:scaleX(0);transform-origin:left}to{transform:scaleX(1)}}.section{margin-bottom:4.5rem}.section:last-child{margin-bottom:0}.section-label{display:inline-flex;align-items:center;gap:.4rem;font-size:.7rem;text-transform:uppercase;letter-spacing:2px;font-weight:700;font-family:Inter,sans-serif;padding:.3rem .9rem;border-radius:50px;margin-bottom:.75rem}.home .section-label{color:var(--red);background:var(--red-bg)}.about .section-label{color:var(--blue);background:var(--blue-bg)}.projects .section-label{color:var(--green);background:var(--green-bg)}.contact .section-label{color:var(--orange);background:var(--orange-bg)}.monaco .section-label{color:var(--red);background:var(--red-bg)}.section-title{font-size:5rem;margin-bottom:.75rem;letter-spacing:-2.5px;font-family:'Bricolage Grotesque',sans-serif;font-weight:800}.gradient-text{background:linear-gradient(135deg,var(--red),var(--blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.section-desc{font-size:1.3rem;color:var(--text-light);max-width:640px;line-height:1.7}.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s cubic-bezier(.34, 1.56, .64, 1),transform .7s cubic-bezier(.34, 1.56, .64, 1)}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:80ms}.reveal-delay-2{transition-delay:0.16s}.reveal-delay-3{transition-delay:0.24s}.reveal-delay-4{transition-delay:0.32s}.reveal-delay-5{transition-delay:0.4s}.hero{min-height:calc(100vh - 6rem);display:flex;flex-direction:column;justify-content:center;position:relative;padding:1rem 0}.hero-greeting{font-family:Inter,sans-serif;font-size:1rem;text-transform:uppercase;letter-spacing:3px;font-weight:600;color:var(--red);margin-bottom:1rem}.hero-name{font-size:9rem;font-weight:900;letter-spacing:-4px;color:var(--text);line-height:.9}.hero-name-gradient{background:linear-gradient(135deg,var(--red),var(--blue),var(--green));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-typewrap{margin-top:.5rem;min-height:3.5rem;display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.hero-typewrap .static-text{font-size:2rem;font-weight:400;color:var(--text-light)}.hero-typewrap .typewriter{font-size:2rem;font-weight:700;color:var(--blue);border-right:3px solid var(--blue);padding-right:4px;animation:blink .7s step-end infinite}@keyframes blink{50%{border-color:transparent}}.hero-bio{margin-top:1.5rem;font-size:1.4rem;color:var(--text-light);max-width:600px;line-height:1.7}.hero-actions{display:flex;gap:.75rem;margin-top:2.5rem;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2.4rem;border-radius:50px;font-family:Inter,sans-serif;font-weight:700;font-size:1.1rem;border:none;cursor:pointer;transition:all var(--spring);text-decoration:none;position:relative;overflow:hidden}.btn-primary{color:#fff}.home .btn-primary{background:var(--red);box-shadow:0 4px 16px var(--red-glow)}.about .btn-primary{background:var(--blue);box-shadow:0 4px 16px var(--blue-glow)}.projects .btn-primary{background:var(--green);box-shadow:0 4px 16px var(--green-glow)}.contact .btn-primary,.stjosephs .btn-primary{background:var(--orange);box-shadow:0 4px 16px var(--orange-glow)}.topictide .btn-primary{background:var(--purple);box-shadow:0 4px 16px var(--purple-glow)}.blackberry .btn-primary{background:var(--indigo);box-shadow:0 4px 16px var(--indigo-glow)}.laurier .btn-primary{background:var(--green);box-shadow:0 4px 16px var(--green-glow)}.monaco .btn-primary{background:var(--red);box-shadow:0 4px 16px var(--red-glow)}.btn-primary:hover{transform:translateY(-3px) scale(1.03)}.home .btn-primary:hover{box-shadow:0 8px 28px var(--red-glow)}.about .btn-primary:hover{box-shadow:0 8px 28px var(--blue-glow)}.projects .btn-primary:hover{box-shadow:0 8px 28px var(--green-glow)}.topictide .btn-primary:hover{box-shadow:0 8px 28px var(--purple-glow)}.blackberry .btn-primary:hover{box-shadow:0 8px 28px var(--indigo-glow)}.contact .btn-primary:hover{box-shadow:0 8px 28px var(--orange-glow)}.monaco .btn-primary:hover{box-shadow:0 8px 28px var(--red-glow)}.btn-outline{background:0 0;color:var(--text);border:1.5px solid var(--border)}.btn-outline:hover{border-color:var(--text-dim);transform:translateY(-3px);box-shadow:var(--shadow)}.btn .ripple{position:absolute;border-radius:50%;background:rgba(255,255,255,.35);transform:scale(0);animation:rippleAnim .6s ease-out;pointer-events:none}@keyframes rippleAnim{to{transform:scale(4);opacity:0}}.scroll-indicator{position:absolute;bottom:1rem;left:0;display:flex;flex-direction:column;align-items:center;gap:.4rem;color:var(--text-dim);font-size:.65rem;text-transform:uppercase;letter-spacing:2px;animation:bob 2s ease-in-out infinite}.scroll-indicator .line{width:1px;height:32px;background:linear-gradient(to bottom,var(--text-dim),transparent)}@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.75rem 1.25rem;text-align:center;transition:all var(--transition);position:relative;overflow:hidden}.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}.stat-card:first-child::before{background:var(--red)}.stat-card:nth-child(2)::before{background:var(--blue)}.stat-card:nth-child(3)::before{background:var(--green)}.stat-card:nth-child(4)::before{background:var(--orange)}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}.stat-number{font-family:Inter,sans-serif;font-size:4.2rem;font-weight:900;line-height:1;margin-bottom:.25rem}.stat-card:first-child .stat-number{color:var(--red)}.stat-card:nth-child(2) .stat-number{color:var(--blue)}.stat-card:nth-child(3) .stat-number{color:var(--green)}.stat-card:nth-child(4) .stat-number{color:var(--orange)}.stat-label{font-size:.95rem;color:var(--text-light);font-weight:600}#rough-canvas{position:fixed;inset:0;width:100vw;height:100vh;pointer-events:none;z-index:-1;opacity:.5}.polaroid-carousel{margin:0 -3.5rem;position:relative}.scroll-cards-sticky{position:-webkit-sticky;position:sticky;top:var(--navbar-height);height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}.scroll-card{position:absolute;cursor:pointer;will-change:transform,opacity;opacity:0;transform:translateY(100px) scale(.92) rotate(-2deg);pointer-events:none}.scroll-card[data-index="0"]{opacity:1;transform:translateY(0) scale(1) rotate(2deg);z-index:2;pointer-events:auto}.scroll-indicators{position:fixed;right:1.5rem;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:.75rem;z-index:10;transition:opacity .4s ease}.scroll-indicators.hidden{opacity:0;pointer-events:none}.scroll-dot{width:12px;height:12px;border-radius:50%;border:2px solid var(--text-dim);background:0 0;cursor:pointer;transition:background .35s ease,transform .35s ease,border-color .35s ease,opacity .35s ease;opacity:.5}.scroll-dot.active{background:var(--indigo);border-color:var(--indigo);transform:scale(1.35);opacity:1;cursor:default}.lowfi-carousel{margin-top:2.5rem;position:relative}.lowfi-track{display:flex;gap:1rem;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:1rem 0 1.5rem;scrollbar-width:thin;scrollbar-color:var(--green) rgba(255,255,255,0.1);cursor:grab}.lowfi-track::-webkit-scrollbar{height:6px}.lowfi-track::-webkit-scrollbar-track{background:rgba(255,255,255,.1);border-radius:3px}.lowfi-track::-webkit-scrollbar-thumb{background:var(--green);border-radius:3px}.lowfi-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:44px;height:44px;border-radius:50%;border:none;background:var(--green);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease,transform .2s ease;box-shadow:0 2px 8px rgba(0,0,0,.15)}.lowfi-arrow i{width:22px;height:22px}.lowfi-arrow:hover{background:#16a34a;transform:translateY(-50%) scale(1.12);box-shadow:0 4px 16px rgba(34,197,94,.35)}.lowfi-arrow-left{left:0}.lowfi-arrow-right{right:0}.lowfi-card{flex:0 0 auto;width:260px;border-radius:8px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.06),0 1px 3px rgba(0,0,0,.03);border:1px solid rgba(255,255,255,.08);transition:transform .25s ease,box-shadow .25s ease;background:#fff}.lowfi-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.1),0 2px 6px rgba(0,0,0,.04)}.lowfi-card img{display:block;width:100%;height:auto}.stjosephs .lowfi-card{width:440px}.chart-container{margin:2.5rem 0;padding:1.5rem;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--radius-lg);position:relative}.chart-container canvas{width:100%!important;height:auto!important;max-height:400px}.chart-title{font-size:1rem;font-weight:600;margin-bottom:1rem;color:var(--text-dim);text-align:center}.scroll-card .polaroid{background:#fff;padding:1.2rem 1.2rem 2.8rem;border-radius:2px;box-shadow:0 4px 20px rgba(0,0,0,.08),0 1px 3px rgba(0,0,0,.04);width:580px;position:relative}.scroll-card .polaroid:hover .polaroid-image img{transform:scale(1.03)}.polaroid-pin{position:absolute;top:-6px;left:50%;transform:translateX(-50%);width:14px;height:14px;border-radius:50%;background:radial-gradient(circle at 40% 35%,#e8e8e8,#aaa);box-shadow:0 1px 3px rgba(0,0,0,.15);z-index:2}.polaroid-image{width:100%;aspect-ratio:4/3;overflow:hidden;position:relative;background:linear-gradient(135deg,var(--bg-card-alt),#f0ede8);display:flex;align-items:center;justify-content:center}.polaroid-image img{max-width:90%;max-height:90%;width:auto;height:auto;object-fit:contain;transition:transform .6s cubic-bezier(.34, 1.56, .64, 1);border-radius:4px;box-shadow:0 2px 8px rgba(0,0,0,.08)}.polaroid-caption{text-align:center;padding-top:1rem;font-family:Caveat,cursive;font-size:2.2rem;color:var(--text);line-height:1.3}.polaroid-cta-btn{display:inline-block;margin-top:.8rem;padding:.65rem 1.6rem;border-radius:50px;background:var(--green);color:#fff;font-family:Inter,sans-serif;font-size:.85rem;font-weight:700;text-decoration:none;transition:all var(--spring);letter-spacing:.3px}.polaroid-cta-btn:hover{transform:translateY(-3px);box-shadow:0 6px 20px var(--green-glow)}.polaroid-caption .roid-tag{font-family:Inter,sans-serif;font-size:.75rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);display:block;margin-top:.2rem;font-weight:600}.hover-cards{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.hover-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;display:block;text-decoration:none;aspect-ratio:4/3;background:var(--bg-card-alt);box-shadow:var(--shadow);transition:box-shadow var(--transition)}.hover-card:hover{box-shadow:var(--shadow-hover)}.hover-card-bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .5s cubic-bezier(.34, 1.56, .64, 1)}.hover-card:hover .hover-card-bg{transform:scale(1.06)}.hover-card-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:1.75rem;background:linear-gradient(to top,rgba(15,15,26,.75) 0,rgba(15,15,26,.1) 50%,transparent 100%);opacity:0;transform:translateY(12px);transition:opacity .35s ease,transform .35s cubic-bezier(.34, 1.56, .64, 1)}.hover-card:hover .hover-card-overlay{opacity:1;transform:translateY(0)}.hover-card-num{font-family:Inter,sans-serif;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:rgba(255,255,255,.6);margin-bottom:.25rem}.hover-card-title{font-family:'Bricolage Grotesque',sans-serif;font-size:1.4rem;font-weight:800;color:#fff;margin-bottom:.2rem}.hover-card-desc{font-size:.82rem;color:rgba(255,255,255,.75);line-height:1.5;margin-bottom:.6rem;max-width:280px}.hover-card-cta{font-family:Inter,sans-serif;font-size:.72rem;font-weight:700;color:var(--green);transition:gap var(--transition);display:inline-flex;align-items:center;gap:.3rem}.hover-card:hover .hover-card-cta{gap:.6rem}.polaroid-gallery{display:grid;grid-template-columns:1fr 1fr 1fr;gap:2rem;margin-top:2rem;max-width:1000px}.polaroid-card{display:block;background:#fcf9f2;padding:.9rem .9rem 2.4rem;border-radius:2px;box-shadow:0 6px 24px rgba(0,0,0,.1),0 1px 4px rgba(0,0,0,.06);transition:all .4s cubic-bezier(.34, 1.56, .64, 1);position:relative;text-decoration:none;transform:rotate(var(--rot,-2deg))}.polaroid-card:first-child{--rot:-2.5deg}.polaroid-card:nth-child(2){--rot:2deg}.polaroid-card:nth-child(3){--rot:-1.5deg}.polaroid-card:nth-child(4){--rot:1.8deg}.polaroid-card:nth-child(5){--rot:-2deg}.polaroid-card:nth-child(6){--rot:2.5deg}.polaroid-card:nth-child(7){--rot:-1.8deg}.polaroid-card:nth-child(8){--rot:1.8deg}.polaroid-card:hover{transform:rotate(0) scale(1.04);box-shadow:0 12px 40px rgba(0,0,0,.15);z-index:2}.polaroid-card>*{pointer-events:none}.polaroid-card-pin{position:absolute;top:-8px;left:50%;margin-left:-7px;width:14px;height:14px;border-radius:50%;background:radial-gradient(circle at 40% 35%,#d4d4d4,#999);box-shadow:0 1px 3px rgba(0,0,0,.2);z-index:3}.polaroid-card-img{width:100%;aspect-ratio:4/3;overflow:hidden;background:linear-gradient(135deg,var(--bg-card-alt),#f0ede8);display:flex;align-items:center;justify-content:center}.polaroid-card-img img{max-width:90%;max-height:90%;width:auto;height:auto;object-fit:contain;border-radius:4px;transition:transform .5s cubic-bezier(.34, 1.56, .64, 1);box-shadow:0 2px 8px rgba(0,0,0,.08)}.polaroid-card:hover .polaroid-card-img img{transform:scale(1.05)}.polaroid-card-cap{text-align:center;padding-top:.9rem;font-family:Caveat,cursive;font-size:1.6rem;color:var(--text);line-height:1.3}.polaroid-card-cap small{display:block;font-family:Inter,sans-serif;font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);margin-top:.15rem;font-weight:600}.camera-full-section{position:relative;min-height:100vh;padding:4rem 0;margin-top:20rem;margin-left:calc(-50vw + 50%);margin-right:calc(-50vw + 50%);padding-left:calc(50vw - 50%);padding-right:calc(50vw - 50%);display:flex;align-items:center;overflow:hidden}.camera-full-section .section-content{width:100%;max-width:1200px;margin:0 auto;padding:0 2rem;position:relative;z-index:2}.camera-bg-overlay{position:fixed;inset:0;z-index:-1;background:#0f172a;opacity:0;transition:opacity .8s ease;pointer-events:none}.camera-bg-overlay.active{opacity:1}.camera-full-section .section-label,.camera-full-section .section-title{color:#f1f5f9}.camera-full-section .section-label{display:inline-block;padding:.25rem .9rem;background:rgba(0,0,0,.25);border-radius:20px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);font-size:.7rem;letter-spacing:2.5px;text-transform:uppercase;font-weight:600;transition:background .2s}.camera-full-section .gradient-text{background:linear-gradient(135deg,#ef4444,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.camera-full-section.light-bg .section-label,.camera-full-section.light-bg .section-title{color:#f1f5f9}.camera-full-section.light-bg .gradient-text{background:linear-gradient(135deg,#1e40af,#6d28d9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.camera-full-section.light-bg .camera-column .camera-trigger-text{color:#f1f5f9}.camera-full-section.light-bg .camera-column .camera-device:hover~.camera-trigger-text{color:#fff;background:rgba(0,0,0,.5)}.camera-full-section.light-bg .film-counter{color:#e2e8f0;border-color:rgba(255,255,255,.08)}.camera-full-section.light-bg .film-counter.out{color:#fca5a5;border-color:rgba(252,165,165,.15)}.camera-carousel-layout{display:flex;gap:2rem;align-items:flex-start;margin-top:1.5rem;position:relative}.camera-column{flex:0 0 260px;text-align:center;position:relative}.camera-column .camera-device{display:inline-block;cursor:pointer;transition:transform .2s ease}.camera-column .camera-device:hover{transform:scale(1.03)}.camera-column .camera-device:active{transform:scale(.97)}.camera-column .camera-trigger-text{display:inline-block;margin-top:.9rem;padding:.35rem 1rem;font-size:.72rem;font-family:Inter,sans-serif;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:#e2e8f0;background:rgba(0,0,0,.3);border-radius:20px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);transition:color .2s,background .2s}.camera-column .camera-trigger-text::before{display:none}.camera-column .camera-device:hover~.camera-trigger-text{color:#fff;background:rgba(0,0,0,.45)}.camera-column .camera-svg{width:260px;height:auto;display:block;margin:0 auto}.film-counter{margin-top:.7rem;font-size:.75rem;font-family:Inter,sans-serif;font-weight:600;letter-spacing:.8px;color:#e2e8f0;display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .9rem;border-radius:20px;background:rgba(0,0,0,.3);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.06);transition:all .2s}.film-counter.out{color:#fca5a5;border-color:rgba(252,165,165,.15);background:rgba(0,0,0,.35)}.carousel-column{flex:1;min-width:0;position:relative;overflow:visible;height:75vh;min-height:500px;max-height:850px;display:flex;flex-direction:column}.fluid-carousel-wrapper{overflow-y:auto;overflow-x:hidden;scroll-snap-type:y mandatory;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;padding:.5rem 0;position:relative;flex:1;-ms-overflow-style:none;scrollbar-width:none}.fluid-carousel-wrapper::-webkit-scrollbar{display:none}.fluid-carousel-track{display:flex;flex-direction:column;gap:3rem;padding:15vh 1rem;align-items:center;width:100%;min-height:100%}.fluid-carousel-track .accumulated-card{display:block;text-decoration:none;background:#fff;padding:1.2rem 1.2rem 2rem;border-radius:4px;box-shadow:0 8px 32px rgba(0,0,0,.3);flex:0 0 auto;width:min(70vw,650px);scroll-snap-align:center;position:relative;transition:transform .4s cubic-bezier(.34, 1.56, .64, 1),opacity .4s ease,box-shadow .4s ease;opacity:.5;transform:scale(.88);will-change:transform,opacity}.fluid-carousel-track .accumulated-card.active-card{opacity:1;transform:scale(1);box-shadow:0 12px 48px rgba(0,0,0,.4)}.fluid-carousel-track .accumulated-card .polaroid-card-pin{position:absolute;top:-5px;left:50%;transform:translateX(-50%);width:12px;height:12px;border-radius:50%;background:radial-gradient(circle at 40% 35%,#e8e8e8,#aaa);box-shadow:0 1px 3px rgba(0,0,0,.15);z-index:2}.fluid-carousel-track .accumulated-card .accumulated-img{width:100%;aspect-ratio:4/3;overflow:hidden;position:relative;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);display:flex;align-items:center;justify-content:center}.fluid-carousel-track .accumulated-card .accumulated-img img{max-width:95%;max-height:95%;width:auto;height:auto;transition:transform .6s cubic-bezier(.34, 1.56, .64, 1);border-radius:4px;box-shadow:0 2px 8px rgba(0,0,0,.08)}.fluid-carousel-track .accumulated-card:hover .accumulated-img img{transform:scale(1.03)}.fluid-carousel-track .accumulated-card .accumulated-cap{text-align:center;padding-top:1rem;font-family:Caveat,cursive;font-size:1.8rem;color:#1e293b;line-height:1.25}.fluid-carousel-track .accumulated-card .accumulated-cap small{display:block;font-family:Inter,sans-serif;font-size:.75rem;text-transform:uppercase;letter-spacing:1.5px;color:#64748b;margin-top:.25rem;font-weight:600}.fluid-carousel-track .accumulated-card .accumulated-cta{display:inline-block;margin-top:.6rem;padding:.45rem 1.1rem;border-radius:50px;background:var(--green);color:#fff;font-family:Inter,sans-serif;font-size:.7rem;font-weight:700;text-decoration:none;letter-spacing:0;text-transform:none;transition:transform .2s ease,box-shadow .2s ease}.fluid-carousel-track .accumulated-card .accumulated-cta:hover{transform:translateY(-2px);box-shadow:0 4px 14px var(--green-glow)}.carousel-hint{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:#64748b;font-weight:500;pointer-events:none;transition:opacity .4s ease}.carousel-hint.hidden{opacity:0}.fluid-arrow{position:absolute;left:50%;transform:translateX(-50%);width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.1);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.15);color:#fff;font-size:1.6rem;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease,background .2s ease,transform .2s ease;pointer-events:none;line-height:1}.carousel-column:hover .fluid-arrow{opacity:1;pointer-events:auto}.fluid-arrow:hover{background:rgba(255,255,255,.2);transform:translateX(-50%) scale(1.1)}.fluid-arrow-left{top:.5rem}.fluid-arrow-right{bottom:.5rem}.stack-indicators{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:10px;z-index:5;pointer-events:none}.stack-dot{position:relative;width:12px;height:12px;border-radius:50%;background:#475569;border:1.5px solid rgba(255,255,255,.25);transition:all .3s ease;opacity:.6;cursor:pointer;pointer-events:auto;box-shadow:none}.stack-dot::before{content:'';position:absolute;inset:-4px;border-radius:50%;border:1.5px solid transparent;transition:all .35s ease;pointer-events:none}.stack-dot::after{content:attr(data-title);position:absolute;left:calc(100% + 18px);top:50%;transform:translateY(-50%);white-space:nowrap;background:linear-gradient(135deg,#0f172a 0,#1e293b 100%);color:#e2e8f0;padding:7px 18px 7px 14px;border-radius:0 8px 8px 0;font-size:.78rem;font-family:Inter,sans-serif;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;clip-path:inset(0 100% 0 0);transition:clip-path .4s cubic-bezier(.34, 1.56, .64, 1);pointer-events:none;box-shadow:0 0 24px rgba(96,165,250,.08),0 0 24px color-mix(in srgb,var(--dot-color,#60a5fa) 8%,transparent),0 4px 16px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.07);border-left:2.5px solid var(--dot-color,#60a5fa);line-height:1.4}.stack-dot:hover{opacity:1;background:var(--dot-color,#60a5fa);box-shadow:0 0 16px rgba(96,165,250,.5),0 0 16px color-mix(in srgb,var(--dot-color,#60a5fa) 50%,transparent)}.stack-dot:hover::before{border-color:rgba(96,165,250,.3);border-color:color-mix(in srgb,var(--dot-color,#60a5fa) 30%,transparent)}.stack-dot:hover::after{clip-path:inset(0 0 0 0)}.stack-dot.active{background:var(--dot-color,#f1f5f9);box-shadow:0 0 20px rgba(241,245,249,.4),0 0 20px color-mix(in srgb,var(--dot-color,#f1f5f9) 40%,transparent);opacity:1;transform:scale(1.25)}.stack-dot.active::before{border-color:rgba(241,245,249,.25);border-color:color-mix(in srgb,var(--dot-color,#f1f5f9) 25%,transparent)}@keyframes cardSlideIn{0%{opacity:0;transform:scale(.8) translateY(60px)}100%{opacity:1;transform:scale(1) translateY(0)}}@keyframes cardPopBack{0%{opacity:0;transform:scale(1.08)}60%{opacity:1;transform:scale(.97)}100%{opacity:1;transform:scale(1)}}.camera-section{text-align:center;padding:1.5rem 0 2.5rem;position:relative}.camera-device{display:inline-flex;flex-direction:column;align-items:center;cursor:pointer;position:relative;user-select:none}.camera-svg{transition:transform var(--spring);filter:drop-shadow(0 8px 24px rgba(0,0,0,.1))}.camera-device:hover .camera-svg{transform:scale(1.03) translateY(-2px)}.camera-device:active .camera-svg{transform:scale(.98) translateY(0)}.camera-flash-screen{position:fixed;inset:0;background:#fff;opacity:0;pointer-events:none;z-index:9998}.camera-flash-screen.active{animation:camFlash .35s ease-out forwards}@keyframes camFlash{0%{opacity:.85}100%{opacity:0}}.camera-result-area{margin-top:3rem;display:flex;justify-content:center;min-height:440px;position:relative}.camera-print{background:#fff;padding:1rem 1rem 2.4rem;border-radius:2px;box-shadow:0 8px 40px rgba(0,0,0,.1);max-width:500px;width:100%;opacity:0;transform:translateY(20px) scale(.92);transition:none;position:absolute}.camera-print.active{animation:printOut .7s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes printOut{0%{opacity:0;transform:translateY(-10px) scale(.9)}50%{opacity:1;transform:translateY(8px) scale(1.01)}75%{transform:translateY(-2px) scale(.99)}100%{opacity:1;transform:translateY(0) scale(1)}}.camera-print-img{width:100%;aspect-ratio:4/3;overflow:hidden;background:linear-gradient(135deg,var(--bg-card-alt),#f0ede8);display:flex;align-items:center;justify-content:center}.camera-print-img img{max-width:90%;max-height:90%;width:auto;height:auto;object-fit:contain;border-radius:4px}.camera-print-cap{text-align:center;padding-top:.9rem;font-family:Caveat,cursive;font-size:1.8rem;color:var(--text)}.camera-print-cap small{display:block;font-family:Inter,sans-serif;font-size:.75rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);margin-top:.2rem;font-weight:600}.camera-print-link{display:block;margin-top:.9rem;font-family:Inter,sans-serif;font-size:.95rem;font-weight:700;color:var(--green);text-decoration:none;transition:color var(--transition);text-align:center}.camera-print-link:hover{color:var(--blue)}.about-grid{display:grid;grid-template-columns:260px 1fr;gap:3rem;align-items:start}.photo-placeholder{width:100%;aspect-ratio:1;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--blue-bg),var(--red-bg));display:flex;align-items:center;justify-content:center;color:var(--text-dim);font-size:3.5rem;border:2px dashed var(--border);position:relative;transition:border-color var(--transition)}.photo-placeholder:hover{border-color:var(--blue)}.photo-placeholder .placeholder-text{font-family:Inter,sans-serif;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;position:absolute;bottom:1.2rem;color:var(--text-dim)}.about-text p{color:var(--text-light);margin-bottom:1.2rem;font-size:1.02rem;line-height:1.8}.philosophy-block{margin-top:2rem;padding:2rem 2.5rem;background:linear-gradient(135deg,var(--blue-bg),var(--red-bg));border-radius:var(--radius-lg);position:relative}.philosophy-block::before{content:'"';position:absolute;top:-.2rem;left:1.2rem;font-size:4rem;font-family:Georgia,serif;color:var(--blue);opacity:.15;line-height:1}.philosophy-block p{font-style:italic;font-size:1.1rem;color:var(--text);margin-bottom:0!important}.about-text p{font-size:1.2rem;line-height:2}.timeline{position:relative;padding-left:3rem;max-width:800px}.timeline::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(to bottom,var(--blue),var(--blue),transparent)}.timeline-item{position:relative;padding-bottom:3.5rem}.timeline-item:last-child{padding-bottom:0}.timeline-item::before{content:'';position:absolute;left:-3rem;top:.5rem;width:24px;height:24px;border-radius:50%;background:var(--blue);border:4px solid var(--blue-bg);transform:translateX(-50%);z-index:1;transition:all var(--spring);box-shadow:0 0 0 4px var(--blue-glow)}.timeline-item:hover::before{background:var(--blue);box-shadow:0 0 0 8px var(--blue-glow);transform:translateX(-50%) scale(1.1)}.timeline-date{font-size:1.1rem;font-family:Inter,sans-serif;font-weight:800;color:var(--blue);text-transform:uppercase;letter-spacing:2px;margin-bottom:.25rem;display:inline-block;padding:.2rem .8rem;background:var(--blue-bg);border-radius:50px}.timeline-role{font-size:1.6rem;font-weight:800;color:var(--text);margin-bottom:.1rem}.timeline-company{font-size:1.15rem;color:var(--text-dim);margin-bottom:.6rem;font-weight:600}.timeline-details{max-height:0;overflow:hidden;transition:max-height .5s ease,opacity .4s ease;opacity:0}.timeline-item:hover .timeline-details{max-height:400px;opacity:1}.timeline-details ul{list-style:none;padding-top:.5rem}.timeline-details li{position:relative;padding-left:1.6rem;font-size:1.1rem;color:var(--text-light);margin-bottom:.6rem;line-height:1.8;font-weight:500}.timeline-details li::before{content:'→';position:absolute;left:0;color:var(--blue);font-weight:700;font-size:1.2rem}.skills-cloud{display:flex;flex-wrap:wrap;gap:.65rem;margin-top:1rem}.skill-tag{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem 1.1rem;border-radius:50px;background:var(--bg-card);border:1.5px solid var(--border);font-size:.82rem;font-weight:600;color:var(--text-light);transition:all var(--spring);cursor:default}.skill-tag:hover{transform:translateY(-4px) scale(1.05);box-shadow:var(--shadow)}.skill-tag:first-child:hover,.skill-tag:nth-child(7):hover{border-color:var(--red);color:var(--red);box-shadow:0 4px 16px var(--red-glow)}.skill-tag:nth-child(2):hover,.skill-tag:nth-child(8):hover{border-color:var(--blue);color:var(--blue);box-shadow:0 4px 16px var(--blue-glow)}.skill-tag:nth-child(3):hover,.skill-tag:nth-child(9):hover{border-color:var(--green);color:var(--green);box-shadow:0 4px 16px var(--green-glow)}.skill-tag:nth-child(10):hover,.skill-tag:nth-child(4):hover{border-color:var(--orange);color:var(--orange);box-shadow:0 4px 16px var(--orange-glow)}.skill-tag:nth-child(11):hover,.skill-tag:nth-child(5):hover{border-color:var(--blue);color:var(--blue)}.skill-tag:nth-child(12):hover,.skill-tag:nth-child(6):hover{border-color:var(--red);color:var(--red)}.skill-tag i{font-size:.9rem}.art-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:2rem}.art-polaroid{background:#fcf9f2;padding:.9rem .9rem 2.6rem;border-radius:1px;box-shadow:0 6px 24px rgba(0,0,0,.1),0 1px 4px rgba(0,0,0,.06);transition:all .4s cubic-bezier(.34, 1.56, .64, 1);position:relative;transform:rotate(var(--rot,0deg));cursor:pointer}.art-polaroid:first-child{--rot:-3.5deg}.art-polaroid:nth-child(2){--rot:2.5deg}.art-polaroid:nth-child(3){--rot:-2deg}.art-polaroid:hover{transform:rotate(0) scale(1.05);box-shadow:0 12px 40px rgba(0,0,0,.15);z-index:5}.art-polaroid-pin{position:absolute;top:-8px;left:50%;margin-left:-7px;width:14px;height:14px;border-radius:50%;background:radial-gradient(circle at 40% 35%,#d4d4d4,#999);box-shadow:0 1px 3px rgba(0,0,0,.2);z-index:3}.art-polaroid-pin::after{content:'';position:absolute;top:14px;left:50%;margin-left:-.5px;width:1px;height:12px;background:linear-gradient(to bottom,rgba(0,0,0,.08),transparent)}.art-polaroid-img{width:100%;aspect-ratio:3/4;overflow:hidden;background:#e8e4db;position:relative;border:1px solid rgba(0,0,0,.04)}.art-polaroid-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.34, 1.56, .64, 1);display:block}.art-polaroid:hover .art-polaroid-img img{transform:scale(1.1)}.art-polaroid-cap{text-align:center;padding-top:.9rem;font-family:Caveat,cursive;font-size:1.2rem;color:#3a3a3a;line-height:1.2;letter-spacing:.3px}.lightbox-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:9999;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s ease;padding:2rem}.lightbox-overlay.active{opacity:1;pointer-events:auto}.lightbox-img{max-width:90%;max-height:90%;object-fit:contain;border-radius:4px;box-shadow:0 8px 40px rgba(0,0,0,.4)}.lightbox-close{position:fixed;top:1.2rem;right:1.5rem;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.1);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition)}.lightbox-close:hover{background:rgba(255,255,255,.2)}.section-number{font-family:Inter,sans-serif;font-size:1rem;font-weight:800;text-transform:uppercase;letter-spacing:3px;color:var(--text-dim);margin-bottom:.2rem}.laurier .section-number{color:var(--green)}.stjosephs .section-number{color:var(--orange)}.topictide .section-number{color:var(--purple)}.blackberry .section-number{color:var(--indigo)}.monaco .section-number{color:var(--red)}.project-hero{padding:1rem 0 2.5rem}.project-hero-layout{display:flex;gap:3rem;align-items:flex-start}.project-hero-text{flex:1;min-width:0}.project-hero-label{font-size:1rem;text-transform:uppercase;letter-spacing:3px;font-weight:700;font-family:Inter,sans-serif;margin-bottom:.6rem}.laurier .gradient-text{background:linear-gradient(135deg,#22c55e,#14b8a6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.laurier .project-hero-label{color:var(--green)}.stjosephs .gradient-text{background:linear-gradient(135deg,#f97316,#dc2626);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stjosephs .project-hero-label{color:var(--orange)}.topictide .gradient-text{background:linear-gradient(135deg,#a855f7,#6366f1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.topictide .project-hero-label{color:var(--purple)}.blackberry .gradient-text{background:linear-gradient(135deg,#6366f1,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.blackberry .project-hero-label{color:var(--indigo)}.monaco .gradient-text{background:linear-gradient(135deg,#d7192f,#ef4444);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.monaco .project-hero-label{color:var(--red)}.project-hero h1{font-size:4.5rem;letter-spacing:-2px;margin-bottom:.7rem}.project-hero-text p{color:var(--text-light);font-size:1.4rem;max-width:720px;line-height:1.7}.project-hero-meta{display:flex;gap:2.5rem;flex-wrap:wrap;margin-top:1.5rem}.project-hero-meta-item{display:flex;flex-direction:column}.project-hero-meta-item .label{font-size:.85rem;text-transform:uppercase;letter-spacing:1.8px;color:var(--text-dim);font-weight:600;font-family:Inter,sans-serif}.laurier .project-hero-meta-item .value{color:var(--green)}.stjosephs .project-hero-meta-item .value{color:var(--orange)}.topictide .project-hero-meta-item .value{color:var(--purple)}.blackberry .project-hero-meta-item .value{color:var(--indigo)}.monaco .project-hero-meta-item .value{color:var(--red)}.project-hero-meta-item .value{font-size:1.1rem;font-weight:700}.hero-image-showcase{flex-shrink:0;width:340px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow)}.hero-image-showcase.standalone{width:min(800px,100%);margin:2rem auto 0}.hero-image-showcase img{width:100%;height:auto;display:block}.laurier .hero-image-showcase{border-color:var(--green)}.stjosephs .hero-image-showcase{border-color:var(--orange)}.topictide .hero-image-showcase{border-color:var(--purple)}.blackberry .hero-image-showcase{border-color:var(--indigo)}.monaco .hero-image-showcase{border-color:var(--red)}.project-section{margin-bottom:3.5rem}.project-section h2{font-size:5rem;margin-bottom:.75rem;letter-spacing:-2.5px;font-family:'Bricolage Grotesque',sans-serif;font-weight:800;line-height:1.1}.project-section p{color:var(--text-light);line-height:1.8;font-size:1.3rem;margin-bottom:1rem}.project-showcase-img{width:70%;border-radius:var(--radius);overflow:hidden;margin:2rem auto;border:1px solid var(--border);box-shadow:var(--shadow);transition:box-shadow var(--transition);background:var(--bg-card)}.project-showcase-img:hover{box-shadow:var(--shadow-hover)}.project-showcase-img img{width:100%;height:auto;display:block;transition:transform .6s cubic-bezier(.34, 1.56, .64, 1)}.project-showcase-img:hover img{transform:scale(1.02)}.project-showcase-img .showcase-cap{padding:.75rem 1.25rem;font-size:.9rem;color:var(--text-dim);font-style:italic;border-top:1px solid var(--border);text-align:center}.project-details-list{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1rem}.detail-item{display:flex;align-items:flex-start;gap:.85rem;padding:1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:all var(--spring)}.laurier .detail-item:hover{border-color:var(--green);box-shadow:0 6px 24px var(--green-glow);transform:translateY(-4px)}.stjosephs .detail-item:hover{border-color:var(--orange);box-shadow:0 6px 24px var(--orange-glow);transform:translateY(-4px)}.topictide .detail-item:hover{border-color:var(--purple);box-shadow:0 6px 24px var(--purple-glow);transform:translateY(-4px)}.blackberry .detail-item:hover{border-color:var(--indigo);box-shadow:0 6px 24px var(--indigo-glow);transform:translateY(-4px)}.laurier .detail-item i{color:var(--green)}.stjosephs .detail-item i{color:var(--orange)}.topictide .detail-item i{color:var(--purple)}.blackberry .detail-item i{color:var(--indigo)}.monaco .detail-item:hover{border-color:var(--red);box-shadow:0 6px 24px var(--red-glow);transform:translateY(-4px)}.monaco .detail-item i{color:var(--red)}.monaco .back-link:hover{color:var(--red)}.monaco .stat-card:first-child::before{background:var(--red)}.monaco .stat-card:nth-child(2)::before{background:var(--blue)}.monaco .stat-card:nth-child(3)::before{background:var(--green)}.monaco .stat-card:first-child .stat-number{color:var(--red)}.monaco .stat-card:nth-child(2) .stat-number{color:var(--blue)}.monaco .stat-card:nth-child(3) .stat-number{color:var(--green)}.detail-item i{font-size:1.5rem;margin-top:.2rem;flex-shrink:0}.detail-item h4{font-size:1.15rem;margin-bottom:.2rem}.detail-item p{font-size:1rem;color:var(--text-dim);margin-bottom:0;line-height:1.6}.define-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:1rem}.define-grid .detail-item{flex-direction:column;gap:.5rem}.page-header{margin-bottom:2rem}.back-link{display:inline-flex;align-items:center;gap:.4rem;font-size:1rem;font-weight:600;color:var(--text-dim);transition:color var(--transition)}.laurier .back-link:hover{color:var(--green)}.stjosephs .back-link:hover{color:var(--orange)}.topictide .back-link:hover{color:var(--purple)}.blackberry .back-link:hover{color:var(--indigo)}.ndgo .navbar-links a.active{background:rgba(20,184,166,.15);box-shadow:inset 0 0 0 1px rgba(20,184,166,.2)}.ndgo .navbar-social a:hover{background:var(--teal)}.ndgo .page-accent{background:linear-gradient(90deg,var(--teal),#2dd4bf)}.ndgo .btn-primary{background:var(--teal);box-shadow:0 4px 16px var(--teal-glow)}.ndgo .btn-primary:hover{box-shadow:0 8px 28px var(--teal-glow)}.ndgo .section-number{color:var(--teal)}.ndgo .gradient-text{background:linear-gradient(135deg,#14b8a6,#0d9488);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ndgo .project-hero-label{color:var(--teal)}.ndgo .project-hero-meta-item .value{color:var(--teal)}.ndgo .hero-image-showcase{border-color:var(--teal)}.ndgo .detail-item:hover{border-color:var(--teal);box-shadow:0 6px 24px var(--teal-glow);transform:translateY(-4px)}.ndgo .detail-item i{color:var(--teal)}.ndgo .back-link:hover{color:var(--teal)}.songbird .navbar-links a.active{background:rgba(244,63,94,.15);box-shadow:inset 0 0 0 1px rgba(244,63,94,.2)}.songbird .navbar-links a:hover{color:var(--rose)}.songbird .navbar-social a:hover{background:var(--rose)}.songbird .page-accent{background:linear-gradient(90deg,var(--rose),#fb7185)}.songbird .btn-primary{background:var(--rose);box-shadow:0 4px 16px var(--rose-glow)}.songbird .btn-primary:hover{background:#e11d48;box-shadow:0 8px 28px var(--rose-glow)}.songbird .section-number{color:var(--rose)}.songbird .gradient-text{background:linear-gradient(135deg,#f43f5e,#d946ef);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.songbird .project-hero-label{color:var(--rose)}.songbird .project-hero-meta-item .value{color:var(--rose)}.songbird .hero-image-showcase{border-color:var(--rose)}.songbird .detail-item:hover{border-color:var(--rose);box-shadow:0 6px 24px var(--rose-glow);transform:translateY(-4px)}.songbird .detail-item i{color:var(--rose)}.songbird .back-link:hover{color:var(--rose)}.songbird .stat-number{color:var(--rose)}.songbird .lowfi-arrow{background:var(--rose)}.songbird .lowfi-arrow:hover{background:#e11d48;transform:translateY(-50%) scale(1.12);box-shadow:0 4px 16px var(--rose-glow)}.songbird .lowfi-track::-webkit-scrollbar-thumb{background:var(--rose)}.songbird .scroll-dot.active{background:var(--rose);border-color:var(--rose)}.qnx .navbar-links a.active{background:rgba(245,158,11,.15);box-shadow:inset 0 0 0 1px rgba(245,158,11,.2)}.qnx .navbar-social a:hover{background:var(--amber)}.qnx .page-accent{background:linear-gradient(90deg,var(--amber),#fbbf24)}.qnx .btn-primary{background:var(--amber);box-shadow:0 4px 16px var(--amber-glow)}.qnx .btn-primary:hover{box-shadow:0 8px 28px var(--amber-glow)}.qnx .section-number{color:var(--amber)}.qnx .gradient-text{background:linear-gradient(135deg,#f59e0b,#d97706);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.qnx .project-hero-label{color:var(--amber)}.qnx .project-hero-meta-item .value{color:var(--amber)}.qnx .hero-image-showcase{border-color:var(--amber)}.qnx .detail-item:hover{border-color:var(--amber);box-shadow:0 6px 24px var(--amber-glow);transform:translateY(-4px)}.qnx .detail-item i{color:var(--amber)}.qnx .back-link:hover{color:var(--amber)}.qnx-sdp .navbar-links a.active{background:rgba(14,165,233,.15);box-shadow:inset 0 0 0 1px rgba(14,165,233,.2)}.qnx-sdp .navbar-social a:hover{background:var(--sky)}.qnx-sdp .page-accent{background:linear-gradient(90deg,var(--sky),#38bdf8)}.qnx-sdp .btn-primary{background:var(--sky);box-shadow:0 4px 16px var(--sky-glow)}.qnx-sdp .btn-primary:hover{box-shadow:0 8px 28px var(--sky-glow)}.qnx-sdp .section-number{color:var(--sky)}.qnx-sdp .gradient-text{background:linear-gradient(135deg,#0ea5e9,#6366f1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.qnx-sdp .project-hero-label{color:var(--sky)}.qnx-sdp .project-hero-meta-item .value{color:var(--sky)}.qnx-sdp .hero-image-showcase{border-color:var(--sky)}.qnx-sdp .detail-item:hover{border-color:var(--sky);box-shadow:0 6px 24px var(--sky-glow);transform:translateY(-4px)}.qnx-sdp .detail-item i{color:var(--sky)}.qnx-sdp .back-link:hover{color:var(--sky)}.persona-carousel{position:relative;margin:2rem auto;max-width:720px;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow)}.persona-track{display:flex;transition:transform .4s cubic-bezier(.34, 1.56, .64, 1)}.persona-slide{min-width:100%;display:flex;align-items:center;justify-content:center;padding:1.5rem;box-sizing:border-box}.persona-slide img{width:100%;height:auto;border-radius:var(--radius);box-shadow:0 2px 12px rgba(0,0,0,.06)}.persona-btn{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border);box-shadow:0 2px 8px rgba(0,0,0,.08);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text);transition:all var(--spring);z-index:2}.persona-btn:hover{background:var(--green);color:#fff;border-color:var(--green);box-shadow:0 4px 16px var(--green-glow)}.persona-btn--prev{left:.75rem}.persona-btn--next{right:.75rem}.persona-btn i{width:20px;height:20px}.persona-dots{display:flex;justify-content:center;gap:.5rem;padding:.75rem 1rem 1rem}.persona-dot{width:10px;height:10px;border-radius:50%;background:var(--border);border:none;cursor:pointer;transition:all var(--spring);padding:0}.persona-dot.active{background:var(--green);transform:scale(1.35)}.persona-dot:hover{transform:scale(1.2)}.persona-slide img{cursor:zoom-in}.lightbox-overlay{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.85);display:flex;align-items:center;justify-content:center;padding:2rem;opacity:0;pointer-events:none;transition:opacity .25s ease}.lightbox-overlay.visible{opacity:1;pointer-events:auto}.lightbox-overlay img{max-width:95vw;max-height:95vh;width:auto;height:auto;border-radius:8px;box-shadow:0 8px 40px rgba(0,0,0,.5);cursor:zoom-out}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}.contact-info>p{color:var(--text-light);margin-bottom:2rem}.contact-details{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.contact-detail{display:flex;align-items:center;gap:.9rem}.contact-detail i{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.05rem;flex-shrink:0;color:var(--orange);background:var(--orange-bg)}.contact-detail .detail-label{font-size:.68rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);font-weight:600;font-family:Inter,sans-serif}.contact-detail .detail-value{font-size:.92rem;font-weight:600;color:var(--text)}.resume-download{display:flex;align-items:center;gap:.75rem;padding:1.1rem 1.4rem;border-radius:var(--radius);border:2px dashed var(--border);color:var(--text-dim);font-size:.85rem;transition:all var(--transition);cursor:pointer;text-decoration:none}.resume-download:hover{border-color:var(--orange);color:var(--orange);border-style:solid}.resume-download i{font-size:1.2rem;color:var(--orange)}.contact-form{background:var(--bg-card);padding:2.5rem;border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.78rem;font-weight:600;color:var(--text);margin-bottom:.3rem;font-family:Inter,sans-serif}.form-group input,.form-group textarea{width:100%;padding:.75rem 1rem;border:1.5px solid var(--border);border-radius:10px;font-family:'Plus Jakarta Sans',sans-serif;font-size:.88rem;color:var(--text);background:var(--bg);transition:all var(--transition);outline:0}.form-group input:focus,.form-group textarea:focus{border-color:var(--orange);box-shadow:0 0 0 4px var(--orange-glow);background:var(--bg-card)}.form-group textarea{resize:vertical;min-height:110px}.form-success{display:none;text-align:center;padding:2rem}.form-success i{font-size:3rem;color:var(--orange);margin-bottom:.75rem}.form-success h3{margin-bottom:.4rem}.form-success p{color:var(--text-light)}.footer{position:relative;z-index:1;padding:2.5rem 3.5rem;background:var(--bg-card);overflow:hidden}.footer::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent,#60a5fa),transparent);opacity:.25}.footer-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.25rem;max-width:1200px;margin:0 auto;position:relative;z-index:1}.footer-logo{font-family:'Bricolage Grotesque',sans-serif;font-size:1.4rem;font-weight:800;background:linear-gradient(135deg,#60a5fa,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-decoration:none;letter-spacing:2px}.footer-copy{font-size:.78rem;color:var(--text-dim);font-weight:400;letter-spacing:.3px}.footer-links{display:flex;gap:.5rem}.footer-links a{color:var(--text-dim);font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.4rem 1.1rem;border-radius:20px;border:1px solid var(--border);transition:all .25s ease;text-decoration:none}.footer-links a:hover{color:var(--text);border-color:var(--text-dim);background:rgba(255,255,255,.03)}.figma-embed iframe{width:100%;border:none;display:block}@media (max-width:768px){.figma-embed iframe{height:420px!important}}@media (max-width:480px){.figma-embed iframe{height:350px!important}}@media (max-width:1024px){.page{padding:2.5rem 2rem 3rem}.footer{padding:2rem}.polaroid-carousel{margin:0 -2rem}.scroll-card .polaroid{width:480px;padding:1rem 1rem 2.2rem}.hover-cards{gap:1rem}.hover-card-overlay{padding:1.25rem}.hover-card-title{font-size:1.15rem}.hover-card-desc{font-size:.75rem}.camera-svg{width:220px;height:auto}.camera-print{max-width:400px;padding:.8rem .8rem 1.8rem}.camera-trigger-text{font-size:.7rem}.hero-name{font-size:6rem}.section-title{font-size:3.5rem}.polaroid-gallery{gap:2rem}.project-section h2{font-size:3.5rem}}@media (max-width:768px){.top-navbar{padding:0 1rem}.navbar-hamburger{display:flex}.navbar-menu{display:none;position:absolute;top:var(--navbar-height);left:0;right:0;background:#0f0f1a;flex-direction:column;padding:.75rem 1rem 1rem;border-top:1px solid rgba(255,255,255,.06);box-shadow:0 12px 32px rgba(0,0,0,.4)}.top-navbar.open .navbar-menu{display:flex}.navbar-links{flex-direction:column;width:100%}.navbar-links a{padding:.7rem .85rem;width:100%;border-radius:8px}.navbar-social{padding-left:0;border-left:none;padding-top:.6rem;margin-top:.4rem;border-top:1px solid rgba(255,255,255,.06);width:100%}.navbar-overlay{display:block}.page{padding:4rem 1.5rem 3rem}.polaroid-carousel{margin:0 -1.5rem}.scroll-card .polaroid{width:380px;padding:.9rem .9rem 2rem}.polaroid-caption{font-size:1.8rem}.camera-svg{width:180px;height:auto}.camera-print{max-width:320px;padding:.7rem .7rem 1.5rem}.camera-trigger-text{font-size:.6rem}.hero-name{font-size:4.5rem}.hero-typewrap .static-text,.hero-typewrap .typewriter{font-size:1.4rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:.85rem}.contact-grid{grid-template-columns:1fr}.form-row{grid-template-columns:1fr}.project-details-list{grid-template-columns:1fr}.define-grid{grid-template-columns:1fr}.project-hero h1{font-size:2rem}.project-hero-image{height:220px}.project-hero-layout{flex-direction:column}.hero-image-showcase{width:100%;max-width:400px}.about-grid{grid-template-columns:1fr;gap:2rem}.about-grid .about-photo{max-width:240px;margin:0 auto}.section-title{font-size:2.8rem}.art-grid{grid-template-columns:1fr 1fr}.footer-inner{flex-direction:column;text-align:center;justify-content:center}.polaroid-gallery{grid-template-columns:1fr;gap:2rem}.project-section h2{font-size:2.8rem}.camera-carousel-layout{flex-direction:column;gap:2rem}.camera-column{flex:none;width:100%}.camera-column .camera-svg{width:200px}.carousel-column{width:100%;height:60vh;max-height:600px}.fluid-carousel-track .accumulated-card{width:min(85vw,520px);padding:1rem 1rem 1.6rem}.fluid-carousel-track .accumulated-card .accumulated-cap{font-size:1.6rem}.fluid-carousel-track{padding:10vh .5rem;gap:2.5rem}.camera-full-section{min-height:auto;padding:3rem 0}}@media (max-width:480px){.scroll-card .polaroid{width:280px;padding:.7rem .7rem 1.4rem}.polaroid-caption{font-size:1.4rem}.lowfi-card{width:260px}.stjosephs .lowfi-card{width:320px}.camera-svg{width:140px;height:auto}.camera-print{max-width:240px;padding:.6rem .6rem 1.2rem}.camera-trigger-text{font-size:.5rem}.hero-name{font-size:3rem}.hero-typewrap .static-text,.hero-typewrap .typewriter{font-size:1.1rem}.stats-grid{gap:.6rem}.stat-number{font-size:3rem}.hero-actions{flex-direction:column}.hero-actions .btn{width:100%;justify-content:center}.art-grid{grid-template-columns:1fr}.section-title{font-size:2.2rem}.polaroid-card-cap{font-size:1.3rem}.polaroid-gallery{gap:1.5rem}.project-hero-layout{flex-direction:column}.hero-image-showcase{width:100%;max-width:300px}.project-section h2{font-size:2.2rem}.camera-column .camera-svg{width:140px}.carousel-column{height:50vh;max-height:450px}.fluid-carousel-track .accumulated-card{width:88vw;padding:.8rem .8rem 1.2rem}.fluid-carousel-track{padding:8vh .5rem;gap:2rem}.fluid-carousel-track .accumulated-card .accumulated-cap{font-size:1.4rem}.stack-dot::after,.stack-dot::before{display:none}.camera-full-section{min-height:auto;padding:2rem 0}}