*,*:before,*:after{box-sizing:border-box}:root{--ff-primary: "Source Sans Pro", sans-serif;--ff-secondary: "Source Code Pro", monospace;--fw-reg: 300;--fw-bold: 900;--clr-light: #fff;--clr-background: #f0edee;--clr-dark: #111;--clr-accent: #01c7bd;--clr-grey: #5a5560;--clr-fl: #ff00cc;--clr-skill: #54457f;--clr-icon: #f6ae2d;--clr-sktext: #b84a62;--fs-h1: 3rem;--fs-h2: 2.25rem;--fs-h3: 1.15rem;--fs-body: 1rem;--bs: .25em .25em .75em rgba(0, 0, 0, .25), .125em .125em .25em rgba(0, 0, 0, .15)}@media(min-width:800px){:root{--fs-h1: 4.5rem;--fs-h2: 3.75rem;--fs-h3: 1.5rem;--fs-body: 1.125rem}}html{scroll-behavior:smooth;height:100%;margin:0}body{background:var(--clr-light);color:var(--clr-dark);margin:0;font-family:var(--ff-primary);font-size:var(--fs-body);line-height:1.6}section{padding:20px}img{display:block;max-width:100%}strong{font-weight:var(--fw-bold)}:focus{outline:3px solid var(--clr-accent);outline-offset:3px}.btn{display:inline-block;padding:.5em 2.5em;background:var(--clr-accent);color:var(--clr-dark);text-decoration:none;cursor:pointer;font-size:.8rem;text-transform:uppercase;letter-spacing:2px;font-weight:var(--fw-bold);transition:transform .2s ease-in-out}.btn:hover{transform:scale(1.5)}h1,h2,h3{line-height:1;margin:0}h1{font-size:var(--fs-h1)}h2{font-size:var(--fs-h2)}h3{font-size:var(--fs-h3)}.section__title{margin-bottom:.25em}.section__title--intro{font-weight:var(--fw-reg)}.section__title--intro strong{display:block}.section__subtitle{margin:0;font-size:var(--fs-h3)}.section__subtitle--intro,.section__subtitle--about{background:var(--clr-accent);padding:.25em 1em;font-family:var(--ff-secondary);margin-bottom:1em}.section__subtitle--work{color:var(--clr-accent);font-weight:var(--fw-bold);margin-bottom:.5em}.section__subtitle--work-info{color:var(--clr-accent);font-weight:var(--fw-reg);margin-bottom:1em}header{display:flex;justify-content:space-between;padding:1em}.logo{max-width:100px}.logo:hover{filter:opacity(50%)}.nav{position:fixed;background:var(--clr-dark);color:var(--clr-light);inset:0;z-index:100;transform:translate(100%);transition:transform .25s cubic-bezier(.5,0,.5,1)}.nav__list{list-style:none;display:flex;height:100%;flex-direction:column;justify-content:space-evenly;align-items:center;margin:0;padding:0}.nav__link{color:inherit;font-weight:var(--fw-bold);font-size:var(--fs-h2);text-decoration:none}.nav__link:hover{color:var(--clr-accent)}.nav-toggle{padding:.5em;background:transparent;border:0;cursor:pointer;position:absolute;right:1em;top:1em;z-index:1000}.nav-open .nav{transform:translate(0)}.nav-open .nav-toggle{position:fixed}.nav-open .hamburger{transform:rotate(.625turn)}.nav-open .hamburger:before{transform:rotate(90deg) translate(-6px)}.nav-open .hamburger:after{opacity:0}.hamburger{display:block;position:relative}.hamburger,.hamburger:before,.hamburger:after{background:var(--clr-accent);width:2em;height:3px;border-radius:1em;transition:transform .25s ease-in-out}.hamburger:before,.hamburger:after{content:"";position:absolute;left:0;right:0}.hamburger:before{top:6px}.hamburger:after{bottom:6px}.intro{position:relative}.intro__img{box-shadow:var(--bs);border-radius:1rem;overflow:hidden;transition:transform 20ms ease-in-out}.intro__img:hover{transform:scale(1.1);filter:brightness(110%)}.section__subtitle--intro{display:inline-block}.section__subtitle--intro:hover{color:var(--clr-fl);filter:blur(1px)}@media(min-width:600px){.intro{display:grid;width:min-content;margin:0 auto;grid-column-gap:1em;grid-template-areas:"img title" "img subtitle";grid-template-columns:min-content max-content}.intro__img{grid-area:img;min-width:350px;position:relative;z-index:2}.section__subtitle--intro{align-self:start;grid-column:-1 / 1;grid-row:2;text-align:right;position:relative;left:-1.5em;width:calc(100% + 1.5em)}}.footer{background:#111;color:var(--clr-accent);text-align:center;padding:2.5em 0;font-size:var(--fs-h3);margin-top:auto;width:100%}.footer a{color:inherit;text-decoration:none}.footer__link{font-weight:var(--fw-bold)}.footer__link:hover,.social-list__link:hover{opacity:.7}.footer__link:hover{text-decoration:underline}.social-list{list-style:none;display:flex;justify-content:center;margin:1em 0 0;padding:0}.social-list__item{margin:0 .5em}.social-list__link{padding:.5em}nav a{position:relative;color:#000;text-decoration:none}nav a:after{content:"";position:absolute;width:0;height:2px;bottom:-5px;left:0;background-color:#000;transition:width .3s}nav a:hover:after{width:100%}.footer__copyright{font-size:.9rem}.skills-dashboard{text-align:center;max-width:1000px;margin:auto;padding:2em}.skills-dashboard h2{font-size:40px;font-weight:700;margin-bottom:20px;color:#333}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.skill-card{background-color:#fff;border-radius:10px;padding:20px;box-shadow:0 4px 12px #0000001a;transition:transform .3s ease;display:flex;align-items:center;justify-content:center;flex-direction:column}.skill-card:hover{transform:translateY(-10px)}.skill-icon{font-size:50px;color:var(--clr-accent);margin-bottom:15px}.skill-info{text-align:center}.skill-name{font-size:20px;font-weight:600;color:var(--clr-sktext);margin-bottom:10px}.skill-level{font-size:13px;font-weight:400;color:var(--clr-skill)}.carousel-container{display:flex;justify-content:center;align-items:center;position:relative;width:100%;max-width:800px;margin:0 auto;padding:20px 0}.carousel-content{display:flex;justify-content:center;align-items:center;width:calc(100% - 40px);margin:0 20px}.carousel-card{text-align:center;background-color:#fff;border:2px solid #ccc;border-radius:15px;padding:20px;box-shadow:0 4px 8px #0000001a;margin:10px;flex:none;width:100%;height:250px;overflow-y:auto}.carousel-card:hover{transform:scale(1.03)}button{position:absolute;top:50%;transform:translateY(-50%);background:none;border:none;font-size:2rem;cursor:pointer;padding:2px;z-index:2;color:var(--clr-accent)}button:hover{color:darken(var(--clr-accent),10%)}button:focus{outline:none}.carousel-container button:first-of-type{left:-20px}.carousel-container button:last-of-type{right:-20px}section>h2{text-align:center;margin-bottom:1rem}.carousel-card h3{margin:0;padding:.5rem 0;font-size:1.5rem}.carousel-card p{margin:0;padding:.5rem 0}@media(max-width:768px){.carousel-container{padding:10px 0}.carousel-content{margin:0 5px}.carousel-container button{font-size:1.5rem}.carousel-container button:first-of-type{left:-20px}.carousel-container button:last-of-type{right:-20px}}.about-me{max-width:1100px;margin:0 auto;padding:60px 24px;display:grid;gap:3rem}.about-me__header{text-align:center}.section__title--about{letter-spacing:-.02em}.section__subtitle--about{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:999px;padding:.5rem 1.5rem;box-shadow:0 18px 40px #01c7bd33}.about-me__content{display:grid;gap:2.5rem;background:linear-gradient(135deg,#01c7bd1f,#54457f14);padding:2.5rem;border-radius:24px;position:relative;overflow:hidden}.about-me__content:before{content:"";position:absolute;inset:1px;border-radius:22px;background:#ffffffd1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:0}.about-me__story,.about-me__stats{position:relative;z-index:1}.about-me__story{display:grid;gap:1.5rem;color:var(--clr-grey)}.about-me__story p{margin:0}.about-me__lede{font-size:1.3rem;font-weight:600;color:var(--clr-dark)}.about-me__tags{list-style:none;display:flex;flex-wrap:wrap;gap:.75rem;margin:0;padding:0}.about-me__tags li{padding:.45rem 1.1rem;border-radius:999px;background:#01c7bd26;color:var(--clr-dark);font-size:.9rem;font-weight:600;letter-spacing:.01em;border:1px solid rgba(1,199,189,.35);transition:transform .25s ease}.about-me__tags li:hover{transform:translateY(-4px)}.about-me__stats{display:grid;gap:1rem}.about-me__stat{background:var(--clr-light);border-radius:18px;padding:1.75rem 1.5rem;box-shadow:0 18px 40px #11111114;border:1px solid rgba(17,17,17,.06);display:grid;gap:.35rem;transition:transform .3s ease,box-shadow .3s ease}.about-me__stat:hover{transform:translateY(-6px);box-shadow:0 22px 44px #54457f2e}.about-me__stat-value{font-size:2rem;font-weight:700;color:var(--clr-accent);letter-spacing:-.02em}.about-me__stat-label{font-size:.95rem;color:var(--clr-grey)}.about-me__cards{display:grid;gap:1.5rem}.about-me__card{padding:2rem;border-radius:20px;background:linear-gradient(135deg,#54457f24,#ffffffeb);border:1px solid rgba(84,69,127,.22);box-shadow:0 18px 40px #11111114;transition:transform .3s ease,box-shadow .3s ease}.about-me__card h3{margin-bottom:.75rem;color:var(--clr-dark);text-transform:uppercase;letter-spacing:.08em;font-size:.95rem}.about-me__card p{margin:0;color:var(--clr-grey);line-height:1.7}.about-me__card:hover{transform:translateY(-8px);box-shadow:0 26px 56px #1111111f}@media(min-width:720px){.about-me__content{grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);align-items:start}.about-me__stats{align-content:start}.about-me__cards{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:719px){.about-me{padding:48px 18px}.about-me__content{padding:2rem}}@media(prefers-reduced-motion:reduce){.about-me__tags li,.about-me__stat,.about-me__card{transition:none}}.highlights{position:relative;padding:80px 24px 60px;max-width:1100px;margin:0 auto}.highlights:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at top right,rgba(1,199,189,.18),transparent 55%);z-index:-1;opacity:.7}.highlights__header{text-align:center;margin-bottom:48px}.section__subtitle--highlights{display:inline-flex;align-items:center;gap:10px;border-radius:999px;background:#01c7bd1f;padding:10px 26px;color:var(--clr-grey)}.highlights__grid{display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:48px}.highlight-card{position:relative;border:none;text-align:left;cursor:pointer;padding:28px 24px;border-radius:24px;background:#ffffffeb;box-shadow:0 20px 45px #11111114;transition:box-shadow .3s ease,transform .3s ease;color:inherit}.highlight-card:focus-visible{outline:3px solid rgba(1,199,189,.6);outline-offset:4px}.highlight-card--active{box-shadow:0 25px 55px #01c7bd47;transform:translateY(-8px)}.highlight-card__icon{font-size:2rem;color:var(--clr-accent)}.highlight-card__metric{display:block;font-size:2.6rem;font-weight:700;color:var(--clr-dark);margin:16px 0 8px}.highlight-card__title{display:block;font-size:1.1rem;font-weight:600;color:var(--clr-grey);min-height:48px}.highlight-card__description{margin-top:16px;color:var(--clr-dark);font-size:.95rem;line-height:1.5}.fun-fact{display:flex;flex-direction:column;align-items:center;gap:18px;padding:24px 32px;border-radius:28px;background:linear-gradient(135deg,#01c7bd26,#ffffffd9);box-shadow:0 18px 40px #11111114;text-align:center}.fun-fact svg{font-size:2.2rem;color:var(--clr-accent)}.fun-fact p{margin:0;color:var(--clr-dark);line-height:1.6;max-width:520px}.fun-fact__button{border:none;background:var(--clr-accent);color:var(--clr-dark);font-weight:700;padding:10px 24px;border-radius:999px;cursor:pointer;letter-spacing:.08em}.fun-fact__button:focus-visible{outline:3px solid rgba(1,199,189,.55);outline-offset:3px}@media(max-width:768px){.highlights{padding:60px 18px 40px}.highlight-card{padding:24px 20px}}.journey{position:relative;padding:80px 20px;max-width:1100px;margin:0 auto}.journey__header{text-align:center;margin-bottom:60px}.section__subtitle--journey{display:inline-block;background:linear-gradient(135deg,#01c7bd33,#01c7bd0d);border-radius:999px;padding:12px 28px;color:var(--clr-grey);letter-spacing:.04em}.journey__timeline{position:relative;display:grid;gap:40px}.journey__line{position:absolute;top:0;bottom:0;left:50%;width:4px;transform:translate(-50%);background:linear-gradient(to bottom,#01c7bd00,#01c7bde6,#01c7bd00);pointer-events:none}.journey__item{position:relative;display:grid;gap:16px;align-items:start;padding:24px 28px;border-radius:20px;background:#ffffffd9;box-shadow:0 16px 45px #11111114;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.journey__item:after{content:"";position:absolute;top:32px;width:16px;height:16px;border-radius:50%;border:3px solid var(--clr-accent);background:var(--clr-light);box-shadow:0 0 0 6px #01c7bd33}.journey__item--left{margin-right:10%}.journey__item--left:after{right:-48px}.journey__item--right{margin-left:10%}.journey__item--right:after{left:-48px}.journey__year{font-family:var(--ff-secondary);font-size:1.2rem;text-transform:uppercase;color:var(--clr-accent);letter-spacing:.2em}.journey__content h3{margin-bottom:12px;font-size:1.6rem;color:var(--clr-dark)}.journey__content p{color:var(--clr-grey);margin-bottom:16px}.journey__tags{display:flex;flex-wrap:wrap;gap:10px;padding:0;margin:0;list-style:none}.journey__tags li{font-size:.75rem;letter-spacing:.08em;padding:6px 12px;border-radius:999px;background:#01c7bd2e;color:var(--clr-dark)}@media(max-width:900px){.journey__line{left:16px;transform:none}.journey__item{margin:0 0 0 44px}.journey__item:after{left:-44px;right:auto}}@media(max-width:600px){.journey{padding:60px 16px}.journey__item{padding:20px 22px}.journey__content h3{font-size:1.35rem}}.dashboard-hw1{padding:40px;background-color:var(--clr-light, #fff);color:var(--clr-dark, #333);border-radius:8px;box-shadow:var(--bs, 0 4px 8px rgba(0, 0, 0, .1));font-family:var( --ff-primary, "Source Sans Pro", sans-serif )}.dashboard-hw1 h2{color:#6b8e23}.dashboard-intro{margin-bottom:30px;background-color:var(--clr-light, #f0f0f0);padding:20px;border-radius:8px;box-shadow:var(--bs, 0 4px 8px rgba(0, 0, 0, .1))}.dashboard-title{color:var(--clr-accent, #17a2b8);margin-bottom:15px}.dashboard-purpose,.dashboard-data-source{color:var(--clr-dark, #333);margin-bottom:10px}.dashboard-data-source a{color:#6b8e23;text-decoration:none}.dashboard-data-source a:hover{text-decoration:underline}.dashboard-hw1-title{color:var(--clr-accent, #17a2b8);margin-bottom:20px;text-align:center;font-size:var(--fs-h2, 2.25rem)}.dashboard-hw1-content{display:grid;grid-template-columns:1fr;gap:20px}.dashboard-hw1-item{background-color:var(--clr-light, #f8f9fa);padding:15px;border-radius:4px;text-align:center;box-shadow:var(--bs, 0 2px 4px rgba(0, 0, 0, .05));color:var(--clr-dark, #333)}.dashboard-hw1-item .dashboard-map{width:100%;height:800px;border:none;margin:auto}.dashboard-hw1-item img{max-width:100%;height:auto;display:block;margin:auto}.visualization-item{margin-bottom:30px;padding:20px;background-color:var(--clr-light, #fff);border-radius:8px;box-shadow:var(--bs, 0 4px 8px rgba(0, 0, 0, .1))}.visualization-title{margin-top:0;margin-bottom:10px;color:var(--clr-accent, #17a2b8);font-family:var(--ff-secondary, "Source Code Pro", monospace)}.visualization-description{margin-bottom:20px;color:var(--clr-dark, #333);font-size:var(--fs-body, 1rem)}.visualization-content{text-align:center}.visualization-content img{max-width:100%;height:auto;border:2px solid var(--clr-accent, #17a2b8);border-radius:4px;display:block;margin:auto}.visualization-content iframe{max-width:100%;border:2px solid var(--clr-accent, #17a2b8);border-radius:4px;display:block;margin:auto;height:500px}.dashboard-conclusion{margin-top:30px;background-color:var( --clr-light, #f0f0f0 );padding:20px;border-radius:8px;box-shadow:var(--bs, 0 4px 8px rgba(0, 0, 0, .1))}@media(max-width:768px){.dashboard-hw1-content{grid-template-columns:1fr}.dashboard-hw1-item .dashboard-map{height:300px}}.trig-app{--surface: var(--clr-light, #fff);--surface-alt: var(--clr-background, #f0edee);--surface-soft: #e6ecef;--border: rgba(17, 17, 17, .08);--text-main: var(--clr-dark, #111);--text-muted: var(--clr-grey, #5a5560);--accent: var(--clr-accent, #01c7bd);--accent-strong: #019a93;--accent-soft: rgba(1, 199, 189, .12);--red: #e36468;--red-strong: #b84a62;--blue: #3282b8;--green: #54457f;font-family:var(--ff-primary, "Source Sans Pro", sans-serif);background:var(--clr-background, #f0edee);color:var(--text-main);min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:2.25rem 1.25rem 3rem;box-sizing:border-box}.trig-app .trig-header{text-align:center;margin-bottom:1.5rem;display:block}.trig-title{font-size:2.15rem;font-weight:800;margin:0;color:var(--accent);letter-spacing:.01em;display:block}.trig-subtitle{color:var(--text-muted);margin-top:.35rem;display:block}.main-panel{background:var(--surface);width:100%;max-width:68rem;border-radius:18px;box-shadow:var(--bs, 0 16px 40px rgba(17, 17, 17, .08));overflow:hidden;border:1px solid var(--border)}.controls-bar{background-color:var(--surface-alt);padding:1rem 1.25rem;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem}.controls-left,.controls-right,.toggles{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.controls-left .btn,.controls-left .btn-icon{flex-shrink:0;position:relative}.controls-left{display:grid;grid-auto-flow:column;grid-auto-columns:max-content;column-gap:.9rem}.trig-app .btn{display:flex;align-items:center;gap:.5rem;padding:.55rem 1.1rem;border-radius:.75rem;font-weight:700;cursor:pointer;border:1px solid transparent;transition:transform .15s ease,box-shadow .2s ease,background-color .2s;font-size:.92rem}.btn-primary{background-color:var(--accent);color:var(--clr-light, #fff);box-shadow:0 10px 24px #01c7bd38}.btn-primary:hover{background-color:var(--accent-strong);transform:translateY(-1px)}.btn-active{background-color:var(--accent-soft);color:var(--accent-strong);border-color:#019a9373;box-shadow:none}.btn-icon{background:var(--surface);color:var(--text-muted);padding:.55rem;border:1px solid var(--border);border-radius:.75rem}.btn-icon:hover{background-color:var(--surface-soft)}.toggle-label{display:flex;align-items:center;gap:.5rem;padding:.35rem .85rem;border-radius:999px;border:1px solid var(--border);cursor:pointer;font-size:.85rem;color:var(--text-muted);-webkit-user-select:none;user-select:none;transition:all .2s ease;background:var(--surface)}.toggle-dot{width:.6rem;height:.6rem;border-radius:50%;background-color:var(--surface-soft)}.toggle-label.sin-active{background:#e364681f;border-color:#e3646866;color:var(--red-strong)}.toggle-label.sin-active .toggle-dot{background:var(--red)}.toggle-label.cos-active{background:#3282b81f;border-color:#3282b866;color:#2d5f89}.toggle-label.cos-active .toggle-dot{background:var(--blue)}.toggle-label.tan-active{background:#54457f1f;border-color:#54457f73;color:#423761}.toggle-label.tan-active .toggle-dot{background:var(--green)}.viz-grid{display:grid;grid-template-columns:1fr}@media(min-width:1024px){.viz-grid{grid-template-columns:1fr 1fr}.circle-section{border-right:1px solid var(--border);border-bottom:none}}.circle-section{padding:2rem 1.5rem 2.5rem;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:var(--surface-alt);position:relative;border-bottom:1px solid var(--border)}.section-label{position:absolute;top:1rem;left:1rem;font-size:.75rem;font-weight:700;text-transform:uppercase;color:var(--text-muted);letter-spacing:.08em}.svg-container{position:relative;margin-bottom:2.25rem}.slider-container{position:absolute;bottom:-1.6rem;left:0;right:0;display:flex;justify-content:center}.angle-slider{width:100%;max-width:260px;cursor:pointer;accent-color:var(--accent)}.readout-panel{margin-top:1rem;display:grid;grid-template-columns:1fr 1fr;gap:.85rem;width:100%;max-width:320px}.readout-card{background:var(--surface);padding:.8rem .95rem;border-radius:.75rem;border:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;font-size:.9rem;box-shadow:0 8px 18px #1111110f}.graph-section{padding:2rem 1.5rem;background:var(--surface);position:relative;display:flex;flex-direction:column;justify-content:center}.graph-container{position:relative;height:16rem;width:100%;border:1px solid var(--border);border-radius:.85rem;background-color:var(--surface-alt);overflow:hidden;box-shadow:0 12px 24px #1111110d inset}.stats-grid{margin-top:1.35rem;display:grid;grid-template-columns:repeat(3,1fr);gap:.85rem}.stat-card{padding:1rem;border-radius:.85rem;border:1px solid var(--border);background:var(--surface-alt);opacity:.4;transition:opacity .3s ease,box-shadow .25s ease;border-left:4px solid transparent}.stat-card.visible{opacity:1;box-shadow:0 10px 20px #11111114}.stat-card.sin{border-color:var(--red);background:#e3646814}.stat-card.cos{border-color:var(--blue);background:#3282b814}.stat-card.tan{border-color:var(--green);background:#54457f14}.stat-title{font-size:.78rem;font-weight:700;text-transform:uppercase;margin-bottom:.35rem;letter-spacing:.06em}.stat-value{font-family:var(--ff-secondary, "Source Code Pro", monospace);font-size:1.2rem;font-weight:700}.stat-desc{font-size:.78rem;margin-top:.3rem;color:var(--text-muted)}.sin .stat-title{color:var(--red-strong)}.sin .stat-value{color:var(--red)}.cos .stat-title{color:#2d5f89}.cos .stat-value{color:var(--blue)}.tan .stat-title{color:#423761}.tan .stat-value{color:var(--green)}.footer-info{background:var(--surface-alt);padding:1rem 1.25rem;border-top:1px solid var(--border);font-size:.8rem;color:var(--text-muted);display:flex;align-items:center;gap:.65rem}.trig-dashboard-root{--surface: var(--clr-light, #fff);--surface-alt: var(--clr-background, #f0edee);--surface-soft: #e6ecef;--border: rgba(17, 17, 17, .08);--text-main: var(--clr-dark, #111);--text-muted: var(--clr-grey, #5a5560);--accent: var(--clr-accent, #01c7bd);--accent-strong: #019a93;--accent-soft: rgba(1, 199, 189, .14);--card-shadow: var(--bs, 0 16px 40px rgba(17, 17, 17, .08));font-family:var(--ff-primary, "Source Sans Pro", sans-serif);color:var(--text-main);background:var(--surface-alt);display:flex;justify-content:center;padding:2.25rem 1rem 3rem}.trig-dashboard-shell{width:100%;max-width:1200px;background:var(--surface);border-radius:18px;border:1px solid var(--border);padding:1.5rem 1.75rem 2rem;box-shadow:var(--card-shadow);position:relative}.trig-header{display:flex;justify-content:space-between;gap:1rem;align-items:center;margin-bottom:1.25rem}.trig-header-text{display:flex;flex-direction:column;gap:.25rem}.trig-header h1{margin:0;font-size:1.75rem;letter-spacing:.01em;color:var(--text-main)}.trig-header p{margin:.35rem 0 0;color:var(--text-muted);font-size:.96rem;max-width:38rem}.trig-header-actions{display:flex;align-items:center;justify-content:flex-end;position:absolute;top:1.25rem;right:1.25rem}.trig-actions{display:flex;gap:.6rem}.trig-btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:.5rem .95rem;border-radius:10px;font-weight:700;font-size:.92rem;border:1px solid transparent;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,background-color .2s ease,color .2s ease}.trig-btn-primary{background:var(--accent);color:var(--clr-light, #fff);box-shadow:0 10px 24px #01c7bd33}.trig-btn-primary:hover{background:var(--accent-strong);transform:translateY(-1px)}.trig-btn-secondary{background:var(--accent-soft);color:var(--accent-strong);border-color:#01c7bd66}.trig-btn-ghost{background:var(--surface);color:var(--text-muted);border:1px solid var(--border)}.trig-btn-ghost:hover{background:var(--surface-soft)}.trig-main-grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1.6fr);gap:1.5rem}.trig-left-panel{display:flex;flex-direction:column;gap:1rem}.trig-right-panel{overflow:hidden}.control-card,.trig-card{background:var(--surface);border-radius:16px;border:1px solid var(--border);padding:1rem 1.05rem 1.1rem;box-shadow:var(--card-shadow)}.control-card h2{margin:0 0 .2rem;font-size:1.08rem;color:var(--text-main)}.control-subtitle{margin:0 0 .75rem;font-size:.86rem;color:var(--text-muted)}.slider-control{margin-bottom:.75rem}.slider-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.slider-label{font-size:.9rem}.slider-value{font-size:.82rem;color:var(--accent-strong);background:var(--accent-soft);border-radius:999px;padding:.15rem .55rem;border:1px solid rgba(1,199,189,.35)}.slider-input-row{display:grid;grid-template-columns:1fr 84px;gap:.6rem;align-items:center}.slider-control input[type=range]{width:100%;appearance:none;height:4px;border-radius:999px;background:var(--surface-soft);outline:none;accent-color:var(--accent)}.slider-control input[type=range]::-webkit-slider-thumb{appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);border:2px solid var(--surface);box-shadow:0 0 0 4px #01c7bd2e;cursor:pointer}.slider-control input[type=range]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent);border:2px solid var(--surface);box-shadow:0 0 0 4px #01c7bd2e;cursor:pointer}.slider-number-input{width:100%;padding:.45rem .55rem;border:1px solid var(--border);border-radius:10px;background:var(--surface-alt);font-size:.9rem;color:var(--text-main)}.slider-number-input:focus{outline:2px solid var(--accent-soft);border-color:var(--accent)}.slider-minmax{display:flex;justify-content:space-between;font-size:.78rem;color:var(--text-muted);margin-top:.15rem}.trig-card-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.trig-card-header{display:flex;flex-direction:column;gap:.2rem;margin-bottom:.5rem}.trig-card-title{font-size:.98rem;font-weight:700;color:var(--text-main)}.trig-card-formula{font-size:.82rem;color:var(--text-muted)}.trig-plot-svg{width:100%;border-radius:12px;overflow:hidden;border:1px solid var(--border);background:var(--surface-alt)}.axis-label,.axis-tick-label{fill:var(--text-muted);font-family:var(--ff-secondary, "Source Code Pro", monospace);font-size:10px}@media(max-width:960px){.trig-main-grid{grid-template-columns:minmax(0,1fr)}.trig-header{flex-direction:column;align-items:flex-start}.trig-header-actions{position:static;align-self:flex-start;margin-top:.35rem}}@media(max-width:720px){.trig-card-grid{grid-template-columns:minmax(0,1fr)}.trig-dashboard-shell{padding-inline:1.1rem}}.vector-explorer{--surface: var(--clr-light, #fff);--surface-alt: var(--clr-background, #f0edee);--surface-soft: #e7eef2;--border: rgba(17, 17, 17, .08);--text-main: var(--clr-dark, #111);--text-muted: var(--clr-grey, #5a5560);--accent: var(--clr-accent, #01c7bd);--accent-strong: #019a93;--u-color: #ef4444;--v-color: #0ea5e9;--proj-color: #14b8a6;--sum-color: #8b5cf6;--root-color: #f59e0b;--mid-color: #0f766e;--card-shadow: var(--bs, 0 16px 40px rgba(17, 17, 17, .08));background:var(--surface-alt);color:var(--text-main);font-family:var(--ff-primary, "Source Sans Pro", sans-serif);display:flex;justify-content:center;box-sizing:border-box;padding:2.2rem 1rem 3rem}.vector-shell{width:100%;max-width:1240px;background:var(--surface);border:1px solid var(--border);border-radius:18px;box-shadow:var(--card-shadow);padding:1.25rem 1.3rem 1.7rem;position:relative}.vector-reset-btn{position:absolute;top:1rem;right:1rem;border:1px solid transparent;border-radius:10px;background:var(--accent);color:var(--clr-light, #fff);font-weight:700;font-size:.9rem;padding:.52rem .95rem;cursor:pointer;transition:transform .15s ease,background-color .2s ease;z-index:5}.vector-reset-btn:hover{background:var(--accent-strong);transform:translateY(-1px)}.vector-header{margin-bottom:1.05rem;padding-right:7.5rem}.vector-header h1{margin:0;font-size:1.72rem}.vector-header p{margin:.4rem 0 0;color:var(--text-muted);font-size:.95rem;max-width:52rem}.vector-header code,.vector-card-subtitle code,.vector-caption code,.vector-formula-card code{font-family:var(--ff-secondary, "Source Code Pro", monospace)}.vector-layout{display:grid;gap:1rem;grid-template-columns:minmax(320px,390px) minmax(0,1fr)}.vector-left-column{display:flex;flex-direction:column;gap:1rem}.vector-card{background:var(--surface);border:1px solid var(--border);border-radius:15px;box-shadow:var(--card-shadow);padding:.95rem 1rem}.vector-card h2{margin:0;font-size:1.03rem}.vector-card-subtitle{margin:.35rem 0 .7rem;color:var(--text-muted);font-size:.85rem}.vector-control+.vector-control{margin-top:.72rem}.vector-control-header{display:flex;justify-content:space-between;align-items:center;gap:.55rem;margin-bottom:.3rem;font-size:.87rem}.vector-control-header span{color:var(--accent-strong);background:#01c7bd1f;border:1px solid rgba(1,199,189,.35);border-radius:999px;padding:.14rem .52rem;font-size:.79rem}.vector-input-row{display:grid;grid-template-columns:1fr 80px;gap:.5rem}.vector-input-row input[type=range]{width:100%;accent-color:var(--accent)}.vector-input-row input[type=number]{width:100%;border:1px solid var(--border);border-radius:10px;background:var(--surface-alt);color:var(--text-main);font-size:.86rem;padding:.4rem .5rem}.vector-input-row input[type=number]:focus{outline:2px solid rgba(1,199,189,.2);border-color:var(--accent)}.vector-toggle-group{margin-top:.8rem;display:grid;gap:.45rem}.vector-checkbox{display:flex;align-items:center;gap:.5rem;font-size:.84rem;color:var(--text-main)}.vector-checkbox input{accent-color:var(--accent)}.vector-section-label{margin:.7rem 0 .45rem;font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted);font-weight:700}.vector-readout-grid{display:grid;gap:.5rem;grid-template-columns:1fr}.vector-readout-item{border:1px solid var(--border);border-radius:10px;background:var(--surface-alt);display:flex;justify-content:space-between;align-items:center;gap:.85rem;padding:.5rem .62rem;font-size:.83rem}.vector-readout-item span{color:var(--text-muted)}.vector-readout-item strong{color:var(--text-main);font-family:var(--ff-secondary, "Source Code Pro", monospace);font-size:.82rem;text-align:right}.vector-right-column{border:1px solid var(--border);border-radius:16px;background:var(--surface);box-shadow:var(--card-shadow);padding:.92rem;display:flex;flex-direction:column;gap:.72rem}.vector-plane-wrap{width:min(100%,680px);margin:0 auto;border:1px solid var(--border);border-radius:14px;overflow:hidden;background:var(--surface-alt)}.vector-plane{width:100%;display:block;aspect-ratio:1 / 1}.vector-plane-bg{fill:#f9fbfc}.vector-grid-line{stroke:#d7e1e8;stroke-width:1}.vector-axis-line{stroke:#6b7280;stroke-width:1.35}.vector-u-line{stroke:var(--u-color);stroke-width:3.1}.vector-v-line{stroke:var(--v-color);stroke-width:3.1}.vector-proj-line{stroke:var(--proj-color);stroke-width:2.8}.vector-sum-line{stroke:var(--sum-color);stroke-width:2.8}.vector-rejection-line{stroke:var(--root-color);stroke-width:1.9;stroke-dasharray:5 4}.vector-root-point{fill:var(--root-color);stroke:#fff;stroke-width:1.1}.vector-point-u,.vector-point-v,.vector-point-midpoint{stroke:#fff;stroke-width:1.4}.vector-point-u{fill:var(--u-color)}.vector-point-v{fill:var(--v-color)}.vector-point-midpoint{fill:var(--mid-color)}.vector-axis-label,.vector-point-label{fill:var(--text-muted);font-family:var(--ff-secondary, "Source Code Pro", monospace);font-size:12px;font-weight:600}.vector-point-label.u{fill:var(--u-color)}.vector-point-label.v{fill:var(--v-color)}.vector-point-label.proj{fill:var(--proj-color)}.vector-point-label.sum{fill:var(--sum-color)}.vector-point-label.mid{fill:var(--mid-color)}.vector-caption{border:1px solid var(--border);border-radius:10px;background:var(--surface-alt);padding:.65rem .74rem}.vector-caption p{margin:0;font-size:.83rem;color:var(--text-main)}.vector-caption p+p{margin-top:.34rem}.vector-right-readout-card{margin-top:0}.vector-formula-row{margin-top:1rem;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem}.vector-formula-card{border:1px solid var(--border);border-radius:12px;background:var(--surface-alt);padding:.75rem .85rem}.vector-chip{display:inline-block;margin:0;font-size:.72rem;font-weight:700;letter-spacing:.05em;color:var(--accent-strong);background:#01c7bd24;border:1px solid rgba(1,199,189,.34);border-radius:999px;padding:.08rem .45rem;text-transform:uppercase}.vector-formula-card h3{margin:.35rem 0 0;font-size:.93rem}.vector-formula-card p{margin:.36rem 0 0;font-size:.82rem;color:var(--text-muted)}@media(max-width:1080px){.vector-layout{grid-template-columns:1fr}}@media(max-width:780px){.vector-shell{padding-inline:.9rem}.vector-header{padding-right:6.2rem}.vector-formula-row{grid-template-columns:1fr}.vector-readout-item{flex-direction:column;align-items:flex-start}.vector-readout-item strong{text-align:left}}@media(max-width:560px){.vector-reset-btn{top:.85rem;right:.85rem;padding:.44rem .8rem}.vector-header{padding-right:5.6rem}.vector-input-row{grid-template-columns:1fr 72px}}.projection-lab{--surface: var(--clr-light, #fff);--surface-alt: var(--clr-background, #f0edee);--surface-soft: #e8eef2;--border: rgba(17, 17, 17, .08);--text-main: var(--clr-dark, #111);--text-muted: var(--clr-grey, #5a5560);--accent: var(--clr-accent, #01c7bd);--accent-strong: #019a93;--shadow-color: #334155;--ray-color: #facc15;--u-color: #ef4444;--axis-color: #2563eb;--orth-color: #0ea5e9;--card-shadow: var(--bs, 0 16px 40px rgba(17, 17, 17, .08));background:var(--surface-alt);color:var(--text-main);font-family:var(--ff-primary, "Source Sans Pro", sans-serif);display:flex;justify-content:center;box-sizing:border-box;padding:2.2rem 1rem 3rem}.projection-shell{width:100%;max-width:1240px;border:1px solid var(--border);border-radius:18px;background:var(--surface);box-shadow:var(--card-shadow);padding:1.3rem 1.3rem 1.7rem;position:relative}.projection-header{position:relative;padding-right:15.5rem;min-height:2.7rem;margin-bottom:1rem}.projection-header-text{min-width:0}.projection-header-text h1{margin:0;font-size:1.74rem}.projection-header-text p{margin:.38rem 0 0;color:var(--text-muted);font-size:.95rem;max-width:52rem}.projection-header-text code,.projection-subtitle code,.projection-caption-card code{font-family:var(--ff-secondary, "Source Code Pro", monospace)}.projection-header-actions{position:absolute;top:.1rem;right:0;display:grid;grid-auto-flow:column;grid-auto-columns:max-content;column-gap:.55rem;align-items:center;z-index:2}.projection-btn{border:1px solid transparent;border-radius:10px;padding:.5rem .92rem;font-size:.88rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:transform .15s ease,background-color .2s ease,color .2s ease,border-color .2s ease}.projection-header-actions .projection-btn{position:static!important;display:inline-flex;align-items:center;justify-content:center}.projection-btn-primary{background:var(--accent);color:var(--clr-light, #fff)}.projection-btn-primary:hover{background:var(--accent-strong);transform:translateY(-1px)}.projection-btn-active{background:#facc152e;border-color:#ca8a0473;color:#854d0e}.projection-btn-ghost{background:var(--surface);border-color:var(--border);color:var(--text-muted)}.projection-btn-ghost:hover{background:var(--surface-soft)}.projection-main-grid{display:grid;gap:1rem;grid-template-columns:minmax(320px,400px) minmax(0,1fr)}.projection-left,.projection-right{display:flex;flex-direction:column;gap:1rem}.projection-card,.projection-scene-card,.projection-caption-card{border:1px solid var(--border);border-radius:15px;box-shadow:var(--card-shadow);background:var(--surface);padding:.95rem 1rem}.projection-card h2{margin:0;font-size:1.04rem}.projection-subtitle{margin:.34rem 0 .7rem;font-size:.85rem;color:var(--text-muted)}.projection-control+.projection-control{margin-top:.72rem}.projection-control-head{display:flex;align-items:center;justify-content:space-between;gap:.55rem;margin-bottom:.3rem;font-size:.87rem}.projection-control-head span{color:var(--accent-strong);background:#01c7bd1f;border:1px solid rgba(1,199,189,.35);border-radius:999px;padding:.14rem .5rem;font-size:.79rem}.projection-input-row{display:grid;grid-template-columns:1fr 80px;gap:.5rem}.projection-input-row input[type=range]{width:100%;accent-color:var(--accent)}.projection-input-row input[type=number]{width:100%;border:1px solid var(--border);border-radius:10px;background:var(--surface-alt);color:var(--text-main);font-size:.86rem;padding:.4rem .5rem}.projection-input-row input[type=number]:focus{outline:2px solid rgba(1,199,189,.2);border-color:var(--accent)}.projection-checkbox{margin-top:.78rem;display:flex;align-items:center;gap:.5rem;font-size:.84rem;color:var(--text-main)}.projection-checkbox input{accent-color:var(--accent)}.projection-readout-grid{display:grid;gap:.5rem;margin-top:.72rem}.projection-readout-row{border:1px solid var(--border);border-radius:10px;background:var(--surface-alt);display:flex;align-items:center;justify-content:space-between;gap:.8rem;padding:.48rem .62rem;font-size:.83rem}.projection-readout-row span{color:var(--text-muted)}.projection-readout-row strong{color:var(--text-main);font-family:var(--ff-secondary, "Source Code Pro", monospace);font-size:.82rem;text-align:right}.projection-warning{margin:.62rem 0 0;font-size:.8rem;color:#b45309;background:#facc1529;border:1px solid rgba(202,138,4,.35);border-radius:8px;padding:.42rem .5rem}.projection-scene-card{padding:.9rem}.projection-scene{width:100%;display:block;aspect-ratio:1 / 1;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--surface-alt)}.projection-bg{fill:#f9fbfc}.projection-grid-line{stroke:#d8e1e8;stroke-width:1}.projection-axis{stroke:#6b7280;stroke-width:1.25}.projection-span-line{stroke:var(--axis-color);stroke-width:2.2}.projection-light-cone{fill:#facc1538}.projection-u-line{stroke:var(--u-color);stroke-width:3}.projection-shadow-line{stroke:var(--shadow-color);stroke-width:4}.projection-orth-line{stroke:var(--orth-color);stroke-width:2.2;stroke-dasharray:6 4}.projection-drop-line{stroke:#0f172a99;stroke-width:1.7;stroke-dasharray:5 4}.projection-ray{stroke:var(--ray-color);stroke-linecap:round;stroke-dasharray:8 5;animation:ray-shift 1.2s linear infinite}@keyframes ray-shift{0%{stroke-dashoffset:0}to{stroke-dashoffset:-26}}.flash-body{fill:#1f2937}.flash-head{fill:#374151}.flash-lens{fill:#fde68a;stroke:#f59e0b;stroke-width:1}.projection-point-u{fill:var(--u-color);stroke:#fff;stroke-width:1.5}.projection-point-shadow{fill:var(--shadow-color);stroke:#fff;stroke-width:1.4}.projection-point-orth{fill:var(--orth-color);stroke:#fff;stroke-width:1.1}.projection-label,.projection-point-label{fill:var(--text-muted);font-family:var(--ff-secondary, "Source Code Pro", monospace);font-size:12px;font-weight:600}.projection-point-label.u{fill:var(--u-color)}.projection-point-label.axis{fill:var(--axis-color)}.projection-point-label.flash{fill:#b45309}.projection-point-label.shadow{fill:var(--shadow-color)}.projection-caption-card p{margin:0;font-size:.84rem}.projection-caption-card p+p{margin-top:.35rem}@media(max-width:1080px){.projection-main-grid{grid-template-columns:1fr}}@media(max-width:780px){.projection-header{padding-right:0;min-height:0}.projection-header-actions{position:static;margin-top:.7rem;display:flex;gap:.55rem}}@media(max-width:600px){.projection-shell{padding-inline:.9rem}.projection-input-row{grid-template-columns:1fr 72px}.projection-btn{font-size:.82rem;padding:.44rem .74rem}.projection-readout-row{flex-direction:column;align-items:flex-start}.projection-readout-row strong{text-align:left}}.projects-list{padding:20px;max-width:1000px;margin:10px auto;background-color:#fff;box-shadow:0 2px 4px #0006;position:relative}.projects-header{display:flex;align-items:center;justify-content:center;gap:200px}.projects-title{flex-grow:1;text-align:center}.projects-list h2{text-align:center;margin-bottom:20px;color:var(--clr-accent);font-size:var(--fs-h2);font-weight:700}.card-title{height:80px;overflow:hidden;display:flex;align-items:center;justify-content:center;text-align:center}.card-description{height:110px;overflow:clip;text-overflow:clip;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical}.card-technology{height:80px;color:var(--clr-sktext);overflow:clip;text-overflow:clip}.card{min-width:300px;display:flex;flex-direction:column;justify-content:space-between;border:1px solid var(--clr-accent);border-radius:8px;box-shadow:0 3px 4px #0000001a;overflow:hidden;transition:box-shadow .3s ease,transform .3s ease}.card:hover{box-shadow:0 4px 8px #0003;transform:translateY(-5px)}.progress-bar-container{position:relative;width:100%;height:6px;margin-top:20px;border:1px solid var(--clr-accent);border-radius:4px;overflow:hidden}.progress-bar{width:100%;height:100%;background:var(--clr-accent);transform-origin:0%;transform:scaleX(0);transition:transform .3s ease}.project-list-container{display:flex;flex-direction:row;overflow-x:auto;scroll-behavior:smooth;padding:20px 0;margin-bottom:20px}.project-list-container::-webkit-scrollbar{display:none}.scroll-indicator{position:absolute;top:50%;transform:translateY(-50%);font-size:24px;color:var(--clr-accent);opacity:.7;z-index:20;pointer-events:none}.scroll-indicator.left{left:-30px}.scroll-indicator.right{right:-30px}@media(max-width:768px){.projects-header{gap:10px}.projects-title{font-size:var(--fs-h3)}.arrow-button{font-size:20px}}.dashboard-container{max-width:1200px;margin:0 auto;padding:20px;text-align:center}.chart-container{margin:20px 0;padding:20px;border:1px solid #ddd;border-radius:8px;background-color:#f9f9f9}.chart-description{margin-bottom:10px;color:#333;font-size:16px;text-align:center}h1{margin-bottom:40px}
