@import"https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,600;9..144,700&family=IBM+Plex+Mono:wght@400;500&family=Manrope:wght@400;500;600;700;800&display=swap";:root{--bg-primary: #f4f7fb;--bg-secondary: #eef3fc;--bg-tertiary: #f8f9fa;--text-primary: #2f2f2f;--text-secondary: #6c757d;--accent-primary: #4a6fa5;--accent-secondary: #1e90ff;--accent-hover: #104e8b;--border-color: #dee2e6;--shadow-color: rgba(0, 0, 0, .1);--card-bg: white;--success-color: #4caf50;--warning-color: #ffc107;--info-color: #1e90ff;--error-color: #f44336;--transition-speed: .3s;--navbar-bg: #1a2b48;--footer-bg: #1a2b48;--success-color-light: rgba(76, 175, 80, .1);--warning-color-light: rgba(255, 193, 7, .1);--error-color-light: rgba(244, 67, 54, .1);--info-color-light: rgba(30, 144, 255, .1);--bg-hover: #e0e7ff;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-6: 1.5rem;--space-8: 2rem;--space-12: 3rem;--space-16: 4rem;--color-primary: #2563eb;--color-primary-dark: #1d4ed8;--color-text: #1f2937;--color-text-light: #4b5563;--color-background: #ffffff;--color-background-alt: #f3f4f6}[data-theme=dark]{--bg-primary: #121212;--bg-secondary: #1e1e1e;--bg-tertiary: #2d2d2d;--text-primary: #f0f0f0;--text-secondary: #b0b0b0;--accent-primary: #4a6fa5;--accent-secondary: #4a9eff;--accent-hover: #6ab0ff;--border-color: #444;--shadow-color: rgba(0, 0, 0, .3);--card-bg: #2d2d2d;--success-color: #66bb6a;--warning-color: #ffca28;--info-color: #42a5f5;--error-color: #ef5350;--navbar-bg: #1a2b48;--footer-bg: #1a2b48;--success-color-light: rgba(102, 187, 106, .2);--warning-color-light: rgba(255, 202, 40, .2);--error-color-light: rgba(239, 83, 80, .2);--info-color-light: rgba(66, 165, 245, .2);--bg-hover: #2a3a5a;--color-text: #f3f4f6;--color-text-light: #d1d5db;--color-background: #111827;--color-background-alt: #1f2937}.layout-wrapper{display:flex;flex-direction:column;min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary);transition:background-color var(--transition-speed),color var(--transition-speed)}.main-content{flex:1}*{box-sizing:border-box}html,body{min-height:100%;margin:0;padding:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);overflow-x:hidden;transition:background-color var(--transition-speed),color var(--transition-speed);font-size:var(--font-size-base);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1{color:var(--accent-primary);margin-bottom:1rem;font-size:clamp(1.8rem,4vw,2.5rem);transition:color var(--transition-speed)}h2{color:var(--accent-primary);margin-bottom:1rem;font-size:clamp(1.4rem,3vw,2rem);transition:color var(--transition-speed)}ul{list-style:none;padding-left:0}li{background:var(--card-bg);border-radius:6px;box-shadow:0 0 6px var(--shadow-color);padding:1rem;margin-bottom:1rem;transition:background-color var(--transition-speed),box-shadow var(--transition-speed)}a{color:var(--accent-primary);text-decoration:none;font-weight:500;transition:color var(--transition-speed)}a:hover{color:var(--accent-hover);text-decoration:underline}.container{max-width:900px;margin:0 auto;padding:2rem}.section-box{background-color:var(--bg-secondary);padding:1rem 1.5rem;border-radius:10px;box-shadow:0 1px 3px var(--shadow-color);margin-bottom:1.5rem;transition:background-color var(--transition-speed),box-shadow var(--transition-speed);cursor:pointer}.section-box:hover{background-color:var(--bg-tertiary)}.section-box h2{margin-bottom:.5rem}.bug-image{width:100%;max-width:1000px;max-height:70vh;-o-object-fit:contain;object-fit:contain;border-radius:8px;box-shadow:0 2px 10px var(--shadow-color);transition:transform .2s ease,box-shadow var(--transition-speed);cursor:zoom-in;margin-bottom:1rem}.bug-image:hover{transform:scale(1.01)}.tab-buttons{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}.tab-buttons button{padding:.5rem 1rem;font-size:1rem;border:none;border-radius:6px;background-color:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;transition:background-color var(--transition-speed),color var(--transition-speed);min-width:200px}.tab-buttons button:hover{background-color:var(--border-color)}.tab-buttons button.active{background-color:var(--accent-primary);color:#fff;font-weight:700}.tasks-content{background-color:var(--card-bg);padding:1.5rem;border-radius:10px;box-shadow:0 1px 4px var(--shadow-color);line-height:1.6;transition:background-color var(--transition-speed),box-shadow var(--transition-speed)}.tasks-content h3{margin-top:1.5rem;color:var(--accent-primary);transition:color var(--transition-speed)}.tasks-content p{margin-bottom:1rem}.carousel-controls{display:flex;justify-content:center;gap:1.5rem;margin-top:1rem}.carousel-controls button{background-color:var(--accent-primary);color:#fff;padding:.6rem 1.2rem;font-size:1rem;border-radius:6px;cursor:pointer;border:none;transition:background-color var(--transition-speed)}.carousel-controls button:hover{background-color:var(--accent-hover)}.footer{background-color:var(--footer-bg);color:#fff;text-align:center;padding:.8rem 1rem;font-size:.8rem;line-height:1.4;margin-top:auto;transition:background-color var(--transition-speed)}.footer-icons{margin-top:.4rem}.footer-icons a{margin:0 .4rem;transition:transform .2s ease;display:inline-block}.footer-icons a:hover{transform:scale(1.1)}.linkedin-icon,.github-icon{fill:#fff;height:18px;width:18px}.cert-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.cert-item{background-color:var(--card-bg);padding:1rem;border-radius:10px;box-shadow:0 1px 4px var(--shadow-color);text-align:center;cursor:pointer;transition:transform .2s ease,background-color var(--transition-speed),box-shadow var(--transition-speed)}.cert-item:hover{transform:scale(1.02)}.cert-item img{width:100%;max-height:200px;-o-object-fit:contain;object-fit:contain;border-radius:6px;margin-bottom:.5rem}@media (max-width: 480px){.container{max-width:100%;padding:1rem}.section-box{padding:.8rem 1rem;margin-bottom:1rem}li{padding:.8rem;margin-bottom:.8rem}}@media (min-width: 768px){.container{padding:2rem}.section-box{padding:1rem 1.5rem;margin-bottom:1.5rem}}.link-grid{display:flex;gap:1rem;flex-wrap:wrap;margin-top:.5rem}.intro-box{padding:2rem}.accordion-list{list-style:none;padding:0;margin:0}.accordion-item{margin-bottom:.5rem;border-radius:6px;overflow:hidden}.accordion-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background-color:var(--bg-tertiary);cursor:pointer;border-radius:6px;transition:background-color var(--transition-speed)}.accordion-header:hover{background-color:var(--border-color)}.accordion-icon{font-size:.8rem;color:var(--text-secondary);transition:color var(--transition-speed)}.accordion-content{padding:0 1rem 1rem;background-color:var(--card-bg);border-radius:0 0 6px 6px;transition:background-color var(--transition-speed)}.accordion-content ul{margin-top:.5rem}.accordion-content li{background:transparent;box-shadow:none;padding:.25rem 0}.progress-bar{height:10px;background-color:var(--bg-tertiary);border-radius:5px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background-color:var(--success-color);border-radius:5px;transition:width .3s ease,background-color var(--transition-speed)}.progress-stats{display:flex;justify-content:space-between;font-size:.9rem;color:var(--text-secondary);transition:color var(--transition-speed)}.status-summary{display:flex;justify-content:space-around;margin-bottom:1.5rem;padding:.5rem;background-color:var(--bg-tertiary);border-radius:6px;transition:background-color var(--transition-speed)}.status-item{display:flex;align-items:center;font-size:.9rem;color:var(--text-primary);transition:color var(--transition-speed)}.status-dot{width:10px;height:10px;border-radius:50%;margin-right:.5rem}.status-item.in-progress .status-dot{background-color:var(--warning-color)}.status-item.pending .status-dot{background-color:var(--text-secondary)}.checklist-filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.checklist-filters button{padding:.4rem .8rem;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;transition:all var(--transition-speed);color:var(--text-primary)}.checklist-filters button:hover{background-color:var(--border-color)}.checklist-item{display:flex;align-items:flex-start;padding:.75rem;margin-bottom:.5rem;background-color:var(--card-bg);border-radius:6px;box-shadow:0 1px 3px var(--shadow-color);transition:background-color var(--transition-speed),box-shadow var(--transition-speed)}.status-badge.completed{background-color:var(--success-color-light);color:var(--success-color)}.status-badge.in-progress{background-color:var(--warning-color-light);color:var(--warning-color)}.status-badge.pending{background-color:var(--text-secondary);color:var(--text-secondary)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;width:100%}.loading-spinner{width:50px;height:50px;border:5px solid rgba(26,43,72,.1);border-radius:50%;border-top-color:var(--accent-primary);animation:spin 1s ease-in-out infinite;margin-bottom:1rem;transition:border-color var(--transition-speed)}.loading-text{font-size:1.2rem;color:var(--accent-primary);font-weight:500;transition:color var(--transition-speed)}@keyframes spin{to{transform:rotate(360deg)}}.theme-toggle-container{display:flex;align-items:center;margin-left:1rem}.theme-toggle-container.mobile{margin:1rem 0;justify-content:center}.theme-toggle{background:transparent;border:none;cursor:pointer;padding:.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;transition:background-color var(--transition-speed)}.theme-toggle svg{width:20px;height:20px;stroke:#fff;fill:none;transition:stroke var(--transition-speed)}.navbar{background-color:var(--navbar-bg);transition:background-color var(--transition-speed)}.footer{background-color:var(--footer-bg);transition:background-color var(--transition-speed)}[data-theme=dark] .navbar a,[data-theme=dark] .footer{color:var(--text-primary)}[data-theme=dark] .navbar a:hover{color:var(--accent-secondary)}.theme-toggle-fixed{display:none}.theme-toggle{background:transparent;border:none;cursor:pointer;padding:.8rem;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;transition:background-color var(--transition-speed)}.theme-toggle:hover{background-color:#ffffff1a}.theme-toggle svg{width:24px;height:24px;stroke:#fff;fill:none;transition:stroke var(--transition-speed)}.dropdown-content{background-color:var(--navbar-bg)!important;border:1px solid var(--border-color)}.dropdown-content a{color:#fff!important;transition:background-color var(--transition-speed),color var(--transition-speed)}.dropdown-content a:hover{background-color:var(--accent-primary)!important;color:#fff!important}[data-theme=light] .theme-toggle svg,[data-theme=dark] .theme-toggle svg{stroke:#fff}@media (max-width: 768px){.theme-toggle.mobile-only{background:transparent!important;padding:.5rem}.theme-toggle.mobile-only:hover{background:transparent!important}}.portfolio-collection{background-color:var(--card-bg);border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px var(--shadow-color);transition:transform .2s ease,box-shadow .2s ease}.portfolio-collection:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-color)}.collection-description{color:var(--text-primary);font-size:var(--font-size-base);line-height:1.6;margin-bottom:1.5rem;transition:color var(--transition-speed)}.portfolio-grid{display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.portfolio-category{background-color:var(--bg-secondary);border-radius:8px;padding:1.5rem;transition:background-color var(--transition-speed)}.portfolio-category:hover{background-color:var(--bg-hover)}.portfolio-category h3{color:var(--accent-primary);margin-bottom:1rem;font-size:1.2rem;display:flex;align-items:center;gap:.5rem}.portfolio-links{display:flex;flex-direction:column;gap:.75rem}.portfolio-link{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background-color:var(--card-bg);border-radius:6px;color:var(--text-primary);text-decoration:none;transition:all var(--transition-speed);border:1px solid var(--border-color)}.portfolio-link:hover{background-color:var(--bg-hover);transform:translate(4px);border-color:var(--accent-primary);color:var(--accent-primary)}.link-icon{font-size:1.2rem;min-width:1.5rem;text-align:center}.link-text{flex:1;font-weight:500}.external-link{position:relative}.external-icon{font-size:1rem;opacity:.7;transition:opacity var(--transition-speed)}.external-link:hover .external-icon{opacity:1}@media (max-width: 768px){.portfolio-collection{padding:1.5rem}.portfolio-grid{grid-template-columns:1fr;gap:1.5rem}.portfolio-category{padding:1.25rem}.portfolio-link{padding:.6rem .8rem}}h1,h2,h3,h4,h5,h6{line-height:1.2;margin-bottom:var(--space-4);font-weight:600}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}a{color:var(--color-primary);text-decoration:none;transition:color .2s ease}a:hover{color:var(--color-primary-dark);text-decoration:underline}:focus{outline:2px solid var(--color-primary);outline-offset:2px}:focus:not(:focus-visible){outline:none}.skip-to-main{position:absolute;left:-9999px;z-index:999;padding:1em;background-color:var(--color-background);color:var(--color-text);text-decoration:none}.skip-to-main:focus{left:50%;transform:translate(-50%)}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--space-4)}section{margin:var(--space-16) 0;padding:var(--space-8) 0}.card{background-color:var(--color-background);border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:var(--space-6);transition:transform .2s ease,box-shadow .2s ease}.card:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000001a}.button{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-2) var(--space-4);border-radius:.375rem;font-weight:500;transition:all .2s ease;cursor:pointer}.button-primary{background-color:var(--color-primary);color:#fff}.button-primary:hover{background-color:var(--color-primary-dark)}@media (max-width: 640px){:root{--font-size-4xl: 2rem;--font-size-3xl: 1.75rem;--font-size-2xl: 1.375rem}section{margin:var(--space-8) 0;padding:var(--space-4) 0}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--color-background-alt) 25%,var(--color-background) 50%,var(--color-background-alt) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.automation-block{margin-top:1.5rem;padding:0;background:none;border-radius:0;box-shadow:none;border:none}.automation-title{margin:0 0 .5rem;font-weight:400;font-size:1em}.automation-btn{padding:.5em 1em;border-radius:5px;font-weight:500;text-decoration:none;display:inline-block;color:#fff;width:100%}.automation-btn.github{background:#24292f}.automation-btn.report{background:#1976d2}.automation-block>div:last-child{display:flex;gap:.75rem;flex-wrap:wrap}.automation-title-block,.automation-desc-block{pointer-events:none;margin-bottom:.5rem}.automation-desc-block{font-size:.97em;font-weight:400;color:var(--text-secondary)}.automation-btns-block{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:.5rem}.cypress-automation-link{flex-direction:column;align-items:flex-start;margin-top:.75rem;gap:.5rem}.cypress-automation-header{display:flex;align-items:center;gap:.75rem}.cypress-automation-title{font-weight:600}.cypress-automation-desc{font-weight:400;color:var(--text-secondary);margin:.5em 0 .5em 2.25em;display:block}.cypress-automation-btns{display:flex;gap:.75rem;flex-wrap:wrap;margin-left:2.25em;margin-top:.25em}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Manrope,system-ui,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:IBM Plex Mono,ui-monospace,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{color-scheme:light;--color-bg: #f5f3ee;--color-surface: rgba(252, 251, 248, .88);--color-surface-2: #ece6d9;--color-text: #171717;--color-muted: #5f5a52;--color-border: rgba(23, 23, 23, .1);--color-accent: #1f5eff;--color-accent-soft: rgba(31, 94, 255, .12);--color-shadow: rgba(15, 17, 19, .08);--gradient-hero: radial-gradient( circle at top left, rgba(31, 94, 255, .14), transparent 32% ), radial-gradient( circle at bottom right, rgba(16, 185, 129, .08), transparent 28% )}[data-theme=dark]{color-scheme:dark;--color-bg: #0f1113;--color-surface: rgba(21, 24, 27, .88);--color-surface-2: #1b2024;--color-text: #f3f1ec;--color-muted: #b8b2a8;--color-border: rgba(243, 241, 236, .12);--color-accent: #7aa2ff;--color-accent-soft: rgba(122, 162, 255, .16);--color-shadow: rgba(0, 0, 0, .28);--gradient-hero: radial-gradient( circle at top left, rgba(122, 162, 255, .12), transparent 32% ), radial-gradient( circle at bottom right, rgba(16, 185, 129, .08), transparent 28% )}html{scroll-behavior:smooth}body{background-color:var(--color-bg);font-family:Manrope,system-ui,sans-serif;color:var(--color-text);background-image:var(--gradient-hero);min-height:100vh}::-moz-selection{background:var(--color-accent-soft)}::selection{background:var(--color-accent-soft)}a{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px}.container{width:100%}@media (min-width: 640px){.container{max-width:640px}}@media (min-width: 768px){.container{max-width:768px}}@media (min-width: 1024px){.container{max-width:1024px}}@media (min-width: 1280px){.container{max-width:1280px}}@media (min-width: 1536px){.container{max-width:1536px}}.layout-shell{min-height:100vh;background-color:var(--color-bg);color:var(--color-text)}.shell-container{margin-left:auto;margin-right:auto;width:100%;max-width:80rem;padding-left:1rem;padding-right:1rem}@media (min-width: 640px){.shell-container{padding-left:1.5rem;padding-right:1.5rem}}@media (min-width: 1024px){.shell-container{padding-left:2.5rem;padding-right:2.5rem}}.shell-panel{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:0 24px 80px var(--color-shadow);border-radius:1.5rem;--tw-backdrop-blur: blur(12px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.section-frame{background:var(--color-surface);border:1px solid var(--color-border);border-radius:1.25rem}.eyebrow{font-family:IBM Plex Mono,ui-monospace,monospace;font-size:.75rem;line-height:1rem;text-transform:uppercase;letter-spacing:.22em;color:var(--color-muted)}.hero-title{font-family:Fraunces,Georgia,serif;font-size:clamp(3.25rem,7vw,6rem);line-height:.94;letter-spacing:-.04em}.section-title{font-family:Fraunces,Georgia,serif;font-size:clamp(2rem,4vw,3rem);line-height:1;letter-spacing:-.03em}.nav-link{display:inline-flex;align-items:center;border-radius:9999px;padding:.5rem 1rem;font-size:.875rem;line-height:1.25rem;font-weight:500;color:var(--color-muted);transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.nav-link-active{background:var(--color-accent-soft);color:var(--color-text)}.primary-button{box-shadow:0 10px 24px #1f5eff2e,inset 0 -2px #0000001f;display:inline-flex;align-items:center;justify-content:center;border-radius:9999px;background-color:var(--color-accent);padding:.75rem 1.25rem;font-size:.875rem;line-height:1.25rem;font-weight:600;--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1));transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.secondary-button{border:1px solid var(--color-border);box-shadow:0 8px 18px #0f11130f,inset 0 -2px #0f11130f;display:inline-flex;align-items:center;justify-content:center;border-radius:9999px;padding:.75rem 1.25rem;font-size:.875rem;line-height:1.25rem;font-weight:600;color:var(--color-text);transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.secondary-button:hover{border-color:var(--color-accent);color:var(--color-accent)}.metric-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:1.25rem;padding:1.25rem}.physical-button{transform:translateY(0);transition-property:transform,box-shadow,border-color,background-color,color,opacity;transition-duration:.18s;transition-timing-function:ease}.hero-profile-panel{background:linear-gradient(180deg,color-mix(in srgb,var(--color-surface) 96%,transparent),color-mix(in srgb,var(--color-surface) 92%,transparent)),radial-gradient(circle at top right,var(--color-accent-soft),transparent 34%);border:1px solid var(--color-border);box-shadow:0 20px 56px var(--color-shadow);display:grid;gap:1rem;border-radius:1.5rem;padding:1.25rem}@media (min-width: 640px){.hero-profile-panel{padding:1.5rem}}@media (min-width: 1024px){.hero-profile-panel{margin-top:2.5rem}}.hero-profile-top,.hero-profile-footer{background:color-mix(in srgb,var(--color-bg) 58%,transparent);border-radius:1.25rem;border-width:1px;border-color:var(--color-border);padding:1.25rem}.hero-profile-card{background:color-mix(in srgb,var(--color-surface) 94%,transparent);border:1px solid var(--color-border);border-radius:1.25rem;padding:1rem}.visible{visibility:visible}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{top:0;right:0;bottom:0;left:0}.inset-y-0{top:0;bottom:0}.bottom-3{bottom:.75rem}.bottom-5{bottom:1.25rem}.left-0{left:0}.right-0{right:0}.right-3{right:.75rem}.right-5{right:1.25rem}.top-4{top:1rem}.z-10{z-index:10}.z-40{z-index:40}.z-50{z-index:50}.z-\[120\]{z-index:120}.z-\[1\]{z-index:1}.m-0{margin:0}.mx-auto{margin-left:auto;margin-right:auto}.mb-4{margin-bottom:1rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.block{display:block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.h-11{height:2.75rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-full{height:100%}.max-h-\[74vh\]{max-height:74vh}.max-h-\[78vh\]{max-height:78vh}.min-h-\[148px\]{min-height:148px}.min-h-\[60vh\]{min-height:60vh}.min-h-full{min-height:100%}.w-1\/2{width:50%}.w-11{width:2.75rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-auto{width:auto}.w-full{width:100%}.min-w-0{min-width:0px}.min-w-full{min-width:100%}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-6xl{max-width:72rem}.max-w-\[96rem\]{max-width:96rem}.max-w-full{max-width:100%}.max-w-xl{max-width:36rem}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-default{cursor:default}.grid-cols-\[auto_minmax\(0\,1fr\)_auto\]{grid-template-columns:auto minmax(0,1fr) auto}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-10{gap:2.5rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.break-words{overflow-wrap:break-word}.break-all{word-break:break-all}.rounded-2xl{border-radius:1rem}.rounded-3xl{border-radius:1.5rem}.rounded-\[1\.25rem\]{border-radius:1.25rem}.rounded-\[1\.5rem\]{border-radius:1.5rem}.rounded-\[1rem\]{border-radius:1rem}.rounded-full{border-radius:9999px}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-line{border-color:var(--color-border)}.bg-black\/5{background-color:#0000000d}.bg-black\/65{background-color:#000000a6}.bg-surface{background-color:var(--color-surface)}.bg-surface-2{background-color:var(--color-surface-2)}.bg-transparent{background-color:transparent}.bg-\[radial-gradient\(circle_at_top\,_rgba\(31\,94\,255\,0\.10\)\,transparent_28\%\)\,linear-gradient\(to_bottom\,_rgba\(255\,255\,255\,0\.02\)\,rgba\(0\,0\,0\,0\.04\)\)\]{background-image:radial-gradient(circle at top,rgba(31,94,255,.1),transparent 28%),linear-gradient(to bottom,#ffffff05,#0000000a)}.fill-\[var\(--color-accent\)\]{fill:var(--color-accent)}.fill-none{fill:none}.stroke-\[var\(--color-accent\)\]{stroke:var(--color-accent)}.stroke-current{stroke:currentColor}.object-contain{-o-object-fit:contain;object-fit:contain}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pb-8{padding-bottom:2rem}.pt-2{padding-top:.5rem}.pt-4{padding-top:1rem}.pt-5{padding-top:1.25rem}.pt-6{padding-top:1.5rem}.text-center{text-align:center}.font-mono{font-family:IBM Plex Mono,ui-monospace,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-\[11px\]{font-size:11px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.leading-7{line-height:1.75rem}.leading-8{line-height:2rem}.tracking-\[0\.18em\]{letter-spacing:.18em}.tracking-\[0\.22em\]{letter-spacing:.22em}.tracking-\[0\.2em\]{letter-spacing:.2em}.text-accent{color:var(--color-accent)}.text-ink{color:var(--color-text)}.text-muted{color:var(--color-muted)}.text-red-500{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity, 1))}.opacity-0{opacity:0}.opacity-75{opacity:.75}.shadow-\[0_18px_60px_rgba\(0\,0\,0\,0\.18\)\]{--tw-shadow: 0 18px 60px rgba(0,0,0,.18);--tw-shadow-colored: 0 18px 60px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_30px_80px_rgba\(0\,0\,0\,0\.35\)\]{--tw-shadow: 0 30px 80px rgba(0,0,0,.35);--tw-shadow-colored: 0 30px 80px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-none{--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-md{--tw-backdrop-blur: blur(12px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.text-balance{text-wrap:balance}.nav-link:hover{background:var(--color-accent-soft);color:var(--color-text)}.primary-button:hover,.secondary-button:hover,.physical-button:hover{transform:translateY(-2px)}.primary-button:active,.secondary-button:active,.physical-button:active{transform:translateY(1px) scale(.99)}.primary-button:active{box-shadow:0 6px 14px #1f5eff29,inset 0 1px #ffffff1f}.secondary-button:active,.physical-button:active{box-shadow:0 4px 10px #0f111314,inset 0 1px #ffffff14}body .container{margin-left:auto;margin-right:auto;width:100%;max-width:72rem;padding:2rem 1rem}@media (min-width: 640px){body .container{padding-left:1.5rem;padding-right:1.5rem}}@media (min-width: 1024px){body .container{padding-left:2.5rem;padding-right:2.5rem}}body .section-box,body .project-testing-section-box,body .certificates-section-box,body .cs50-block,body .task-card,body .tasks-content,body .project-card{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:0 14px 36px var(--color-shadow);border-radius:1.25rem}body .section-box:hover,body .project-card:hover{background:var(--color-surface)}body .tab-buttons button,body button.log-toggle,body .checklist-filters button{border:1px solid var(--color-border);background:var(--color-surface-2);border-radius:9999px;font-weight:500;color:var(--color-text)}body .tab-buttons button.active,body .checklist-filters button.active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}body .footer{display:none}.hover\:-translate-y-0\.5:hover{--tw-translate-y: -.125rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:-translate-y-1:hover{--tw-translate-y: -.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:border-accent:hover{border-color:var(--color-accent)}@media (min-width: 640px){.sm\:bottom-6{bottom:1.5rem}.sm\:right-6{right:1.5rem}.sm\:max-h-\[78vh\]{max-height:78vh}.sm\:max-h-\[82vh\]{max-height:82vh}.sm\:min-h-\[68vh\]{min-height:68vh}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:items-end{align-items:flex-end}.sm\:items-center{align-items:center}.sm\:justify-between{justify-content:space-between}.sm\:gap-4{gap:1rem}.sm\:space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(2rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2rem * var(--tw-space-y-reverse))}.sm\:rounded-\[1\.25rem\]{border-radius:1.25rem}.sm\:rounded-\[1\.5rem\]{border-radius:1.5rem}.sm\:rounded-\[2rem\]{border-radius:2rem}.sm\:p-4{padding:1rem}.sm\:p-6{padding:1.5rem}.sm\:px-10{padding-left:2.5rem;padding-right:2.5rem}.sm\:px-5{padding-left:1.25rem;padding-right:1.25rem}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}.sm\:px-8{padding-left:2rem;padding-right:2rem}.sm\:py-10{padding-top:2.5rem;padding-bottom:2.5rem}.sm\:py-12{padding-top:3rem;padding-bottom:3rem}.sm\:py-5{padding-top:1.25rem;padding-bottom:1.25rem}.sm\:py-6{padding-top:1.5rem;padding-bottom:1.5rem}.sm\:py-8{padding-top:2rem;padding-bottom:2rem}.sm\:pb-10{padding-bottom:2.5rem}.sm\:pt-6{padding-top:1.5rem}.sm\:text-base{font-size:1rem;line-height:1.5rem}.sm\:text-xl{font-size:1.25rem;line-height:1.75rem}}@media (min-width: 768px){.md\:block{display:block}.md\:inline-flex{display:inline-flex}.md\:hidden{display:none}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width: 1024px){.lg\:flex{display:flex}.lg\:hidden{display:none}.lg\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:grid-cols-\[minmax\(0\,1\.05fr\)_minmax\(320px\,0\.95fr\)\]{grid-template-columns:minmax(0,1.05fr) minmax(320px,.95fr)}.lg\:grid-cols-\[minmax\(0\,1\.08fr\)_minmax\(320px\,0\.92fr\)\]{grid-template-columns:minmax(0,1.08fr) minmax(320px,.92fr)}.lg\:grid-cols-\[minmax\(0\,1\.15fr\)_minmax\(280px\,0\.85fr\)\]{grid-template-columns:minmax(0,1.15fr) minmax(280px,.85fr)}.lg\:grid-cols-\[minmax\(0\,1\.1fr\)_minmax\(0\,0\.9fr\)\]{grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr)}.lg\:items-start{align-items:flex-start}.lg\:items-end{align-items:flex-end}.lg\:px-14{padding-left:3.5rem;padding-right:3.5rem}.lg\:py-16{padding-top:4rem;padding-bottom:4rem}}@media (min-width: 1280px){.xl\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.xl\:grid-cols-\[minmax\(0\,1\.1fr\)_minmax\(320px\,0\.9fr\)\]{grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr)}}.test-html-wrapper{width:100%;overflow-x:auto;padding:1rem 0;-webkit-overflow-scrolling:touch}.test-html-wrapper table{width:100%!important;max-width:100%;border-collapse:collapse;background-color:#f4f7fb!important;border-radius:8px;box-shadow:none;font-size:.9rem;table-layout:auto}.test-html-wrapper th,.test-html-wrapper td{padding:.6rem .8rem;border:1px solid #e0e0e0;text-align:left;font-size:.95rem;white-space:pre-wrap;word-break:break-word;font-variant-numeric:tabular-nums;background-color:#f4f7fb!important}.test-html-wrapper th{font-weight:700;color:#1a2b48;background-color:#e9eff7!important;white-space:nowrap}.test-html-wrapper td{vertical-align:top}@media (max-width: 768px){.test-html-wrapper{padding:.5rem}.test-html-wrapper table{font-size:.85rem;min-width:auto}.test-html-wrapper th,.test-html-wrapper td{font-size:.85rem;padding:.4rem .6rem}}@media (max-width: 480px){.test-html-wrapper table{font-size:.75rem}.test-html-wrapper th,.test-html-wrapper td{font-size:.75rem;padding:.3rem .5rem}}.container{max-width:1200px;margin:0 auto;padding:2rem}.section-box{background-color:var(--card-bg);border-radius:8px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 2px 4px var(--shadow-color)}.tab-buttons{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin-bottom:1.5rem}.tab-buttons button{flex:1 1 200px;min-width:200px;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-secondary);color:var(--text-primary);font-weight:500;cursor:pointer;transition:all .2s ease}.tab-buttons button:hover{background-color:var(--bg-tertiary)}.tab-buttons button.active{background-color:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.task-card{background-color:var(--bg-secondary);border-radius:6px;padding:1rem;margin-bottom:1rem;border:1px solid var(--border-color)}.task-card h3{color:var(--text-primary);margin-bottom:.5rem}.test-case-info{background-color:var(--bg-secondary);border-radius:6px;padding:1rem;margin:1rem 0}.preconditions-section{margin:1rem 0}.preconditions-section ul{list-style-type:disc;margin-left:1rem;margin-top:.5rem}.steps-section{margin-top:1.5rem}.step-group{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;padding:1rem;margin-bottom:.75rem}.checklist-progress{margin-bottom:1.5rem}.progress-bar{height:8px;background-color:var(--bg-tertiary);border-radius:4px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background-color:var(--success-color);border-radius:4px}.progress-stats{display:flex;justify-content:space-between;font-size:.9rem;color:var(--text-secondary)}.status-summary{display:flex;justify-content:space-around;margin-bottom:1.5rem;padding:.75rem;background-color:var(--bg-tertiary);border-radius:6px}.status-item{display:flex;align-items:center;gap:.5rem}.status-item.completed .status-dot{background-color:var(--success-color)}.status-item.pending .status-dot{background-color:var(--error-color)}.checklist-items{list-style:none;padding:0}.checklist-item{display:flex;align-items:flex-start;padding:.75rem;margin-bottom:.5rem;background-color:var(--bg-secondary);border-radius:6px;border:1px solid var(--border-color)}.status-badge{padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500;margin-right:.75rem;white-space:nowrap}.status-badge.completed{background-color:#4caf5033;color:var(--success-color)}.status-badge.pending{background-color:#f4433633;color:var(--error-color)}.checklist-item-content{flex:1}.check-category{color:var(--text-secondary);font-size:.9rem;margin-left:.25rem}.error-message{background-color:#f443361a;color:var(--error-color);padding:1rem;border-radius:6px;margin-bottom:1rem;text-align:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn .3s ease-in-out}.image-grid,.cert-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;padding:0}.image-tile,.cert-item{position:relative;background:var(--color-surface);border:1px solid var(--color-border);padding:1.2rem;border-radius:1.25rem;box-shadow:0 14px 32px var(--color-shadow);text-align:center;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.image-tile:hover,.cert-item:hover{transform:translateY(-4px);box-shadow:0 20px 40px var(--color-shadow);border-color:var(--color-accent)}.image-tile img,.cert-item img{width:100%;height:220px;-o-object-fit:contain;object-fit:contain;border-radius:8px;margin-bottom:.8rem;transition:transform .3s ease}.image-caption,.cert-item p{font-size:.95rem;color:var(--color-text);margin:0;padding:.5rem;font-weight:600}.bug-intro{display:grid;justify-items:center;gap:1rem;padding:2rem 1rem;text-align:center}.bug-description{max-width:42rem;font-size:1rem;line-height:1.8;color:var(--color-muted)}.bug-hunt-container{position:relative;width:100%;height:460px;border:1px solid var(--color-border);border-radius:1.5rem;background:radial-gradient(circle at top left,rgba(31,94,255,.12),transparent 28%),linear-gradient(135deg,#122033,#1c2431 48%,#11161d);overflow:hidden}.bug-canvas{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;width:100%;height:100%}.bug-window{position:absolute;width:150px;height:100px;background:#fff;border:2px solid #0f172a;box-shadow:0 10px 24px #00000040;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:transform .1s linear;z-index:1}.bug-window-header{background:#0f62fe;color:#fff;font-size:.85rem;padding:.35rem;text-align:center;border-bottom:1px solid #0f172a}.bug-window-body{padding:.5rem;font-size:.8rem;color:#111827}.bug-hunt-info{margin-top:1rem;display:flex;justify-content:space-between;gap:1rem;align-items:center;color:var(--color-text)}.win-message{margin-top:1rem;font-weight:600;color:var(--color-accent);text-align:center;font-size:1rem}@media (max-width: 768px){.bug-hunt-container{height:380px}.bug-hunt-info{flex-direction:column;align-items:stretch}}.log-toggle{background-color:var(--accent-primary);color:#fff;padding:.6rem 1.2rem;font-size:1rem;border:none;border-radius:6px;margin-top:1rem;cursor:pointer;transition:background-color .2s ease}.log-toggle:hover{background-color:var(--accent-hover)}.log-output{background-color:var(--card-bg);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;padding:1rem;margin-top:1rem;font-size:.9rem;max-height:400px;overflow-y:auto;white-space:pre-wrap;word-break:break-word}.bug-header-main{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;width:100%;padding:.5rem}.bug-badges{display:flex;gap:.5rem;flex-wrap:wrap;order:1}.bug-title{flex:1 1 auto;min-width:0;word-break:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;color:var(--text-primary);order:2}.bug-title strong{font-weight:600;color:var(--text-primary);margin-right:.5rem}.severity-badge,.priority-badge,.status-badge{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase}.severity-badge.critical{background-color:var(--error-color);color:#fff}.severity-badge.high{background-color:var(--warning-color);color:var(--text-primary)}.severity-badge.medium{background-color:var(--accent-secondary);color:var(--text-primary)}.severity-badge.low{background-color:var(--success-color);color:#fff}.priority-badge.high{background-color:var(--error-color);color:#fff}.priority-badge.medium{background-color:var(--warning-color);color:var(--text-primary)}.priority-badge.low{background-color:var(--success-color);color:#fff}.status-badge{background-color:var(--accent-primary);color:#fff}.status-badge.fixed{background-color:var(--success-color)}.status-badge.in_progress{background-color:var(--warning-color);color:var(--text-primary)}.status-badge.partially{background-color:var(--accent-secondary);color:var(--text-primary)}.status-badge.wontfix{background-color:var(--text-secondary);color:#fff}.status-badge.abandoned{background-color:var(--error-color);color:#fff}.status-badge.pending{background-color:#e0e0e0;color:#424242;border:1px solid #bdbdbd}.bug-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(0,1fr));gap:1.5rem;padding:1rem;width:100%;box-sizing:border-box}.bug-detail-section{background-color:var(--card-bg);border-radius:8px;padding:1rem;box-shadow:0 2px 4px var(--shadow-color)}.bug-detail-section h4{color:var(--text-primary);margin-bottom:.75rem;font-size:1rem;font-weight:600}.comparison-box{display:grid;gap:1rem}.expected,.actual{padding:.75rem;border-radius:4px;background-color:var(--bg-secondary)}.expected strong,.actual strong{display:block;margin-bottom:.5rem;color:var(--text-primary)}.env-details{list-style:none;padding:0;margin:0}.env-details li{margin-bottom:.5rem;color:var(--text-primary)}.env-details li strong{color:var(--text-secondary);margin-right:.5rem}.fix-notes{background-color:var(--bg-secondary);padding:.75rem;border-radius:4px;color:var(--text-primary);font-style:italic}.test-filters{display:flex;flex-wrap:wrap;gap:24px;margin-bottom:24px;background-color:#fff;padding:24px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.filter-group label{font-size:14px;color:#666;font-weight:500}.filter-group select{padding:8px 32px 8px 12px;border:1px solid #e0e0e0;border-radius:4px;background-color:#fff;font-size:14px;width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8.825L1.175 4 2.238 2.938 6 6.7l3.763-3.762L10.825 4z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.filter-group select:hover{border-color:#1976d2}.filter-group select:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 2px #1976d233}.test-header-main{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;width:100%;padding:.5rem}.test-badges{display:flex;gap:.5rem;flex-wrap:wrap;order:1}.test-title{flex:1 1 auto;min-width:0;word-break:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;color:var(--text-primary);order:2}.test-title strong{font-weight:600;color:var(--text-primary);margin-right:.5rem}.test-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(0,1fr));gap:1.5rem;padding:1rem;width:100%;box-sizing:border-box;overflow:hidden}.test-detail-section{background-color:var(--card-bg);border-radius:8px;padding:1rem;box-shadow:0 2px 4px var(--shadow-color);width:100%;box-sizing:border-box;overflow:hidden}.test-detail-section h4{color:var(--text-primary);margin-bottom:.75rem;font-size:1rem;font-weight:600;width:100%;box-sizing:border-box}.test-detail-section ol,.test-detail-section ul{margin:0;padding-left:1.5rem;width:100%;box-sizing:border-box}.test-detail-section li{margin-bottom:.75rem;color:var(--text-primary);line-height:1.4;position:relative;padding-left:.25rem}.test-detail-section ol{counter-reset:item;list-style:none}.test-detail-section ol li{counter-increment:item}.test-detail-section ol li:before{content:counter(item) ".";position:absolute;left:-1.5rem;color:var(--text-secondary);font-weight:500}.test-info{list-style:none;padding:0;margin:0;width:100%;box-sizing:border-box;overflow:hidden}.test-info li{margin-bottom:.5rem;color:var(--text-primary);display:flex;align-items:flex-start;flex-wrap:wrap}.test-info strong{color:var(--text-secondary);margin-right:.5rem;min-width:85px;font-size:.9rem}.project-testing-container{max-width:1200px;margin:0 auto;padding:24px;background-color:var(--bg-primary);color:var(--text-primary)}.project-testing-section-box{background:var(--bg-primary);border-radius:12px;padding:24px;margin-bottom:24px;box-shadow:0 2px 4px var(--shadow-color);border:1px solid var(--border-color)}.project-testing-section-box{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:0 14px 36px var(--color-shadow);border-radius:1.25rem;padding:1.5rem}.project-testing-section-box h2{color:var(--color-text);margin-bottom:1rem}.checklist-progress,.status-summary,.test-filters,.checklist-filters{border:1px solid var(--color-border);background:color-mix(in srgb,var(--color-surface-2) 68%,transparent);border-radius:1.25rem}.checklist-progress{padding:1rem 1.1rem}.status-summary{padding:.85rem 1rem;gap:.75rem}.status-item{background:transparent}.progress-bar{background:#7f7f7f26;border-radius:999px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,var(--color-accent),#6aa1ff);border-radius:999px}.test-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;padding:1rem;box-shadow:none}.filter-group label{font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:var(--color-muted)}.filter-group select{border:1px solid var(--color-border);background-color:var(--color-surface);border-radius:999px;color:var(--color-text);padding:.9rem 2.5rem .9rem 1rem}.filter-group select:hover,.filter-group select:focus{border-color:var(--color-accent)}.checklist-filters{padding:.75rem;display:flex;flex-wrap:wrap;gap:.75rem}.checklist-filters button,.tab-buttons button{min-height:44px}.checklist-items{display:grid;gap:.85rem;margin-top:1rem}.checklist-item{border:1px solid var(--color-border);background:var(--color-surface);box-shadow:0 10px 24px var(--color-shadow);border-radius:1rem;padding:1rem}.test-details-grid,.bug-details-grid{gap:1rem;padding:0}.test-detail-section,.bug-detail-section{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:0 10px 24px var(--color-shadow);border-radius:1rem}.expected,.actual,.fix-notes{background:color-mix(in srgb,var(--color-surface-2) 78%,transparent);border-radius:.9rem}.env-details li,.test-info li,.test-detail-section li{box-shadow:none;background:transparent;border-radius:0;margin-bottom:.6rem;padding:0}@media (max-width: 768px){.project-testing-section-box{padding:1rem}.test-header-main,.bug-header-main{gap:.75rem}}.checklist-progress{margin:24px 0}.progress-bar{height:8px;background-color:var(--bg-secondary);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background-color:var(--badge-low-text);transition:width .3s ease}.progress-stats{display:flex;justify-content:space-between;margin-top:8px;color:var(--text-secondary);font-size:14px}.status-summary{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px}.status-item{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-primary)}.status-dot{width:8px;height:8px;border-radius:50%}.status-item.passed .status-dot,.status-item.completed .status-dot,.status-item.fixed .status-dot{background-color:var(--badge-low-text)}.status-item.failed .status-dot,.status-item.open .status-dot{background-color:var(--badge-high-text)}.status-item.in-progress .status-dot{background-color:var(--badge-progress-text)}.status-item.pending .status-dot{background-color:#9e9e9e}.test-filters,.checklist-filters{display:flex;flex-wrap:wrap;gap:24px;margin-bottom:24px;background-color:var(--bg-primary);padding:24px;border-radius:8px;box-shadow:0 2px 4px var(--shadow-color);border:1px solid var(--border-color)}.filter-group{display:flex;flex-direction:column;gap:8px;min-width:200px}.filter-group label{font-size:14px;color:var(--text-secondary);font-weight:500}.filter-group select{padding:8px 32px 8px 12px;border:1px solid var(--border-color);border-radius:4px;background-color:var(--bg-primary);color:var(--text-primary);font-size:14px;width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8.825L1.175 4 2.238 2.938 6 6.7l3.763-3.762L10.825 4z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.filter-group select:hover{border-color:var(--badge-progress-text);background-color:var(--bg-hover)}.filter-group select:focus{outline:none;border-color:var(--badge-progress-text);box-shadow:0 0 0 2px var(--badge-progress-bg)}.tab-buttons{display:flex;gap:12px;margin-bottom:24px}.tab-buttons button{padding:12px 24px;border:none;border-radius:8px;background-color:var(--bg-secondary);color:var(--text-primary);font-size:16px;cursor:pointer;transition:all .2s}.tab-buttons button:hover{background-color:var(--bg-hover)}.tab-buttons button.active{background-color:var(--badge-progress-text);color:#fff}.test-details-grid,.bug-details-grid{display:grid;gap:24px;grid-template-columns:1fr;width:100%}@media (min-width: 768px){.test-details-grid,.bug-details-grid{grid-template-columns:repeat(2,1fr)}}.test-detail-section,.bug-detail-section{background-color:var(--bg-primary);border-radius:8px;padding:16px;border:1px solid var(--border-color)}.test-detail-section h4,.bug-detail-section h4{margin:0 0 12px;color:var(--text-primary);font-size:16px}.test-detail-section ol,.bug-detail-section ol{margin:0;padding-left:20px;color:var(--text-primary)}.test-detail-section li,.bug-detail-section li{margin-bottom:8px}.test-info,.env-details{list-style:none;padding:0;margin:0;color:var(--text-primary)}.test-info li,.env-details li{margin-bottom:8px}.test-info strong,.env-details strong{color:var(--text-secondary);margin-right:8px}.comparison-box{display:grid;gap:16px}.comparison-box .expected,.comparison-box .actual{background-color:var(--bg-secondary);padding:12px;border-radius:4px;border:1px solid var(--border-color)}.comparison-box strong{display:block;margin-bottom:8px;color:var(--text-secondary)}.comparison-box p{color:var(--text-primary);margin:0}.fix-notes{background-color:var(--bg-secondary);padding:12px;border-radius:4px;margin:0;color:var(--text-primary);border:1px solid var(--border-color)}.checklist-items{list-style:none;padding:0;margin:0}.checklist-item{display:flex;align-items:center;gap:1rem;padding:1rem;background-color:var(--card-bg);border-radius:8px;box-shadow:0 1px 3px var(--shadow-color);margin-bottom:.5rem;transition:background-color var(--transition-speed),box-shadow var(--transition-speed);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.checklist-item-content{flex:1;color:var(--text-primary);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}@media (max-width: 768px){.test-details-grid,.bug-details-grid{grid-template-columns:1fr;padding:.5rem;overflow:hidden}.test-detail-section,.bug-detail-section{padding:.75rem;overflow:hidden}.test-header-main,.bug-header-main{flex-direction:column;align-items:flex-start;overflow:hidden}.test-badges,.bug-badges{width:100%;margin-bottom:.5rem;overflow:hidden}.test-title,.bug-title{width:100%;overflow:hidden}.comparison-box{grid-template-columns:1fr;overflow:hidden}.expected,.actual{width:100%;overflow:hidden}.test-detail-section ol,.test-detail-section ul{padding-left:2rem}.test-detail-section ol li:before{left:-1.75rem}.test-detail-section li{padding-left:0}.test-info li{margin-bottom:.75rem}.test-info strong{min-width:75px;margin-right:.35rem;font-size:.85rem}}.checklist-filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;width:100%}.checklist-filters button{flex:1;min-width:120px;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-primary);color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all .2s ease;white-space:nowrap;text-align:center}.checklist-filters button:hover{background-color:var(--bg-hover)}.checklist-filters button.active{background-color:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}@media (max-width: 768px){.checklist-filters{flex-direction:column;gap:.5rem;padding:0 .5rem}.checklist-filters button{width:100%;min-width:100%;margin:0;padding:.75rem}}.accordion-list{list-style:none;padding:0;margin:0;width:100%;display:grid;gap:1rem}.accordion-item{border:1px solid var(--color-border);border-radius:1.25rem;background:var(--color-surface);width:100%;overflow:hidden;box-shadow:0 14px 36px var(--color-shadow)}.accordion-header{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.25rem;cursor:pointer;transition:background-color .2s,transform .2s;background:transparent;color:var(--color-text);width:100%;text-align:left}.accordion-header:hover{background:var(--color-accent-soft)}.accordion-icon{flex-shrink:0;margin-left:auto;transition:transform .3s ease;font-size:12px;color:var(--color-muted)}.accordion-icon.rotated{transform:rotate(180deg)}.accordion-content{max-height:0;overflow:hidden;transition:max-height .3s ease-out,padding .3s ease-out;padding:0;background:color-mix(in srgb,var(--color-surface-2) 72%,transparent);width:100%}.accordion-content.expanded{max-height:2000px;padding:1.25rem;border-top:1px solid var(--color-border)}.test-header-main,.bug-header-main{display:flex;align-items:flex-start;gap:1rem;flex-wrap:wrap;width:100%;color:var(--color-text);padding:0}.test-badges,.bug-badges{display:flex;gap:.5rem;flex-wrap:wrap}.priority-badge,.severity-badge,.status-badge,.result-badge{padding:.35rem .65rem;border-radius:999px;font-size:11px;font-weight:600;white-space:nowrap;letter-spacing:.02em;text-transform:uppercase}.priority-badge.high{background:#c2410c24;color:#c2410c}.priority-badge.medium{background:#ca8a0424;color:#a16207}.priority-badge.low,.result-badge.passed{background:#16a34a24;color:#15803d}.result-badge.failed{background:#dc262624;color:#b91c1c}.result-badge.in_progress{background:#2563eb24;color:#1d4ed8}.status-badge.fixed{background:#16a34a24;color:#15803d}.status-badge.in_progress{background:#2563eb24;color:#1d4ed8}.status-badge.open,.severity-badge.high{background:#dc262624;color:#b91c1c}.severity-badge.medium{background:#ca8a0424;color:#a16207}.severity-badge.low{background:#16a34a24;color:#15803d}
