*,:after,:before{--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:rgba(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:rgba(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: }

.hero a[href*="project"],
.hero-section a[href*="project"],
.hero-actions a:first-child,
.hero-cta a:first-child,
.btn-primary,
.button-primary,
.cta-primary,
a.btn-primary,
a.button-primary {
  color: #ffffff !important;
  text-shadow: 0 0 14px rgba(255, 255, 255, 0.28);
}

/* Make sure child spans/icons inside the button also become white */
.hero a[href*="project"] *,
.hero-section a[href*="project"] *,
.hero-actions a:first-child *,
.hero-cta a:first-child *,
.btn-primary *,
.button-primary *,
.cta-primary * {
  color: #ffffff !important;
}

/* =========================================================
   Availability badge: outline only + white text
   Target: "Available for work"
   ========================================================= */

.badge-available,
span.badge-available {
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;

  color: #ffffff !important;

  border: 1px solid rgba(34, 211, 238, 0.72) !important;
  border-radius: 9999px !important;

  box-shadow:
    0 0 18px rgba(34, 211, 238, 0.22),
    inset 0 0 16px rgba(34, 211, 238, 0.06) !important;

  text-shadow: 0 0 12px rgba(255, 255, 255, 0.22) !important;
}

/* Text inside the badge */
.badge-available span,
span.badge-available span {
  color: #ffffff !important;
}

/* Small dot inside the badge */
.badge-available span:first-child,
span.badge-available span:first-child {
  background: #ffffff !important;
  box-shadow: 0 0 12px rgba(255, 255, 255, 0.65) !important;
}

/* =========================================================
   Fix 01: Top brand text — "The Philip Notes"
   Bigger + white
   ========================================================= */

.nav-shell .nav-inner > a:first-child,
.nav-shell a:first-child,
header .nav-inner > a:first-child,
header a[href="/"]:first-child,
header a[href="./"]:first-child {
  color: #ffffff !important;
  font-size: 1.05rem !important;
  font-weight: 800 !important;
  letter-spacing: -0.02em !important;
  line-height: 1 !important;
}

/* Keep the logo image/badge size stable */
.nav-shell .logo-badge,
header .logo-badge {
  color: #ffffff !important;
  flex-shrink: 0 !important;
}

/* If the brand text is inside a span */
.nav-shell .nav-inner > a:first-child span:not(.logo-badge),
header .nav-inner > a:first-child span:not(.logo-badge) {
  color: #ffffff !important;
  font-size: 1.05rem !important;
  font-weight: 800 !important;
}


/* =========================================================
   Fix 02: Blog page title
   White text + prevent clipping / covered look
   ========================================================= */

main h1:first-of-type,
.layout-page h1:first-of-type,
.layout-page-tight h1:first-of-type {
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;

  background: none !important;
  background-image: none !important;
  background-clip: initial !important;
  -webkit-background-clip: initial !important;

  font-size: clamp(2.5rem, 5vw, 2.25rem) !important;
  font-weight: 800 !important;
  letter-spacing: -0.055em !important;
  line-height: 1.0 !important;

  display: block !important;
  position: relative !important;
  z-index: 5 !important;

  overflow: visible !important;
  padding-top: 0.2rem !important;
  padding-bottom: 0.35rem !important;
  margin-top: 1rem !important;
  margin-bottom: 0.25rem !important;
}

/* Disable decorative overlays that may visually cover the heading */
main h1:first-of-type::before,
main h1:first-of-type::after,
.layout-page h1:first-of-type::before,
.layout-page h1:first-of-type::after,
.layout-page-tight h1:first-of-type::before,
.layout-page-tight h1:first-of-type::after {
  display: none !important;
  content: none !important;
}


/* =========================================================
   Fix 03: Blog intro text spacing under title
   ========================================================= */

main h1:first-of-type + p,
.layout-page h1:first-of-type + p,
.layout-page-tight h1:first-of-type + p {
  color: #a1a1aa !important;
  font-size: 1rem !important;
  line-height: 1.3 !important;
  margin-top: 0.25rem !important;
}

/* =========================================================
   Blog post cards: solid left accent bar
   ========================================================= */

.card-home--post {
  position: relative !important;
  overflow: hidden !important;

  border-left-width: 0 !important;
  border-left-color: transparent !important;

  background-color: rgba(7, 9, 14, 0.96) !important;
  border-color: rgba(39, 39, 42, 0.72) !important;
}

/* Solid left bar */
.card-home--post::before {
  content: "" !important;
  position: absolute !important;

  left: 0 !important;
  top: 0 !important;
  bottom: 0 !important;

  width: 5px !important;
  height: 100% !important;

  opacity: 0.7 !important;
  transform: none !important;

  background: #22d3ee !important;

  box-shadow:
    0 0 18px rgba(34, 211, 238, 0.55),
    0 0 34px rgba(34, 211, 238, 0.22) !important;

  pointer-events: none !important;
  z-index: 2 !important;
}

/* Keep card content above the bar */
.card-home--post > * {
  position: relative !important;
  z-index: 3 !important;
}

/* Alternate every second post to purple */
.card-home--post:nth-of-type(even)::before {
  background: #a855f7 !important;

  box-shadow:
    0 0 18px rgba(168, 85, 247, 0.55),
    0 0 34px rgba(168, 85, 247, 0.22) !important;
}

/* Optional: slightly stronger card hover without changing the solid bar */
.card-home--post:hover {
  transform: translateY(-3px) !important;
  border-color: rgba(63, 63, 70, 0.9) !important;
  box-shadow:
    0 18px 42px rgba(0, 0, 0, 0.72),
    0 0 32px rgba(34, 211, 238, 0.08) !important;
}

.card-home--post:nth-of-type(even):hover {
  box-shadow:
    0 18px 42px rgba(0, 0, 0, 0.72),
    0 0 32px rgba(168, 85, 247, 0.1) !important;
}

/*! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;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,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,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,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{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}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.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}}.dock{position:fixed;right:1.5rem;bottom:1.6rem;z-index:50}.dock-inner{gap:.45rem;padding:.3rem .5rem;border-radius:9999px;backdrop-filter:blur(16px)}.dock-inner,.dock-panel{display:inline-flex;align-items:center}.dock-panel{padding:.25rem;gap:.35rem;max-width:0;opacity:0;transform:translateX(6px);overflow:hidden;transition:max-width .18s ease-out,opacity .18s ease-out,transform .18s ease-out}.dock--open .dock-panel{max-width:10rem;opacity:1;transform:translateX(0)}.dock-divider{width:1px;height:1.4rem;background:linear-gradient(to bottom,transparent,color-mix(in srgb,var(--color-border) 80%,transparent),transparent)}.dock-action{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:9999px;border:1px solid var(--color-border);background-color:color-mix(in srgb,var(--color-bg) 75%,transparent);color:var(--color-text-muted);cursor:pointer;transition:background-color .16s ease-out,border-color .16s ease-out,color .16s ease-out,transform .16s ease-out,box-shadow .16s ease-out}.dock-action:hover{border-color:var(--color-accent);color:var(--color-accent);transform:translateY(-1px)}.dock-toggle{display:flex;align-items:center;justify-content:center;width:2.1rem;height:2.1rem;border-radius:9999px;border:1px solid var(--color-border);background-color:color-mix(in srgb,var(--color-bg) 85%,transparent);color:var(--color-text-muted);cursor:pointer;transition:background-color .16s ease-out,border-color .16s ease-out,transform .16s ease-out,box-shadow .16s ease-out}.dock-toggle:hover{border-color:var(--color-accent);color:var(--color-accent);transform:translateY(-1px);box-shadow:0 10px 24px rgba(0,0,0,.5)}.dock-toggle-dots{position:relative;display:inline-block;width:.8rem;height:.16rem;border-radius:999px;background-color:var(--color-text-muted)}.dock-toggle-dots:after,.dock-toggle-dots:before{content:"";position:absolute;inset-y:0;width:.16rem;border-radius:999px;background-color:var(--color-text-muted)}.dock-toggle-dots:before{left:-.18rem}.dock-toggle-dots:after{right:-.18rem}.dock--open .dock-toggle-dots,.dock--open .dock-toggle-dots:after,.dock--open .dock-toggle-dots:before{background-color:var(--color-accent)}.btn-primary-sm{font-size:.75rem;padding:.35rem .9rem;border-radius:999px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.visible{visibility:visible}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.sticky{position:sticky}.order-first{order:-9999}.mx-auto{margin-left:auto;margin-right:auto}.mb-2{margin-bottom:.5rem}.mb-8{margin-bottom:2rem}.ml-1{margin-left:.25rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.block{display:block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.contents{display:contents}.hidden{display:none}.h-1\.5{height:.375rem}.h-24{height:6rem}.h-4{height:1rem}.h-8{height:2rem}.h-full{height:100%}.min-h-screen{min-height:100vh}.w-1\.5{width:.375rem}.w-24{width:6rem}.w-4{width:1rem}.w-8{width:2rem}.w-full{width:100%}.min-w-0{min-width:0}.max-w-7xl{max-width:80rem}.max-w-xl{max-width:36rem}.flex-1{flex:1 1 0%}.flex-shrink{flex-shrink:1}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.list-disc{list-style-type:disc}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-baseline{align-items:baseline}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-8{gap:2rem}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.25rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem*var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.5rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem*var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.75rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem*var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem*var(--tw-space-y-reverse))}.space-y-5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1.25rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.25rem*var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1.5rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem*var(--tw-space-y-reverse))}.overflow-hidden,.truncate{overflow:hidden}.truncate{text-overflow:ellipsis;white-space:nowrap}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-border{border-color:var(--color-border)}.bg-bg{background-color:var(--color-bg)}.bg-surface{background-color:var(--color-surface)}.bg-white\/95{background-color:hsla(0,0%,100%,.95)}.object-cover{-o-object-fit:cover;object-fit:cover}.p-2{padding:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.pb-6{padding-bottom:1.5rem}.pl-4{padding-left:1rem}.pt-10{padding-top:2.5rem}.pt-6{padding-top:1.5rem}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-\[0\.68rem\]{font-size:.68rem}.text-\[0\.72rem\]{font-size:.72rem}.text-\[0\.75rem\]{font-size:.75rem}.text-\[0\.7rem\]{font-size:.7rem}.text-\[0\.8rem\]{font-size:.8rem}.text-\[1rem\],.text-base{font-size:1rem}.text-base{line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.italic{font-style:italic}.tracking-tight{letter-spacing:-.025em}.tracking-wide{letter-spacing:.025em}.text-accent{color:var(--color-accent)}.text-muted{color:var(--color-text-muted)}.text-text{color:var(--color-text)}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.shadow-md{--tw-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.shadow-md,.shadow-sm{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 rgba(0,0,0,.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.blur{--tw-blur:blur(8px)}.blur,.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-filter{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}:root{--color-bg:#f9fafb;--color-surface:#fff;--color-text:#111827;--color-text-muted:#6b7280;--color-border:#e5e7eb;--color-accent:#a855f7}html[data-theme=dark]{--color-bg:#000;--color-surface:#0a0a0a;--color-text:#f9fafb;--color-text-muted:#9ca3af;--color-border:#27272a;--color-accent:#c084fc}body{background:var(--color-bg);color:var(--color-text)}.bg-bg{background-color:var(--color-bg)}.bg-surface{background-color:var(--color-surface)}.text-text{color:var(--color-text)}.text-muted{color:var(--color-text-muted)}.text-accent{color:var(--color-accent)}.border-border{border-color:var(--color-border)}.border-accent{border-color:var(--color-accent)}.bg-accent{background-color:var(--color-accent)}.underline-accent{text-decoration-color:var(--color-accent)}@keyframes fade-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.animate-fade-up{animation:fade-up .45s ease-out both}@keyframes search-panel-in{0%{opacity:0;transform:translate(-50%,-48%) scale(.97)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes search-backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes search-panel-out{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-48%) scale(.97)}}@keyframes search-backdrop-out{0%{opacity:1}to{opacity:0}}.card-home{display:flex;flex-direction:column;justify-content:space-between;gap:.5rem;background-color:color-mix(in srgb,var(--color-surface) 96%,transparent);box-shadow:0 18px 40px rgba(0,0,0,.55)}.card-home--project{position:relative;overflow:hidden;transition:transform .18s ease-out,box-shadow .18s ease-out,border-color .18s ease-out,background-color .18s ease-out}.card-home--project:after{content:"";position:absolute;inset:-40%;background:radial-gradient(circle at 120% 50%,color-mix(in srgb,var(--color-accent) 70%,transparent),transparent 60%);opacity:0;transform:translateX(-8px);transition:opacity .22s ease-out,transform .22s ease-out;pointer-events:none}.card-home--project:hover{transform:translateY(-4px) translateX(3px);border-color:color-mix(in srgb,var(--color-accent) 40%,var(--color-border));box-shadow:0 18px 40px rgba(0,0,0,.7),16px 0 38px rgba(124,58,237,.45);background-color:color-mix(in srgb,var(--color-surface) 99%,transparent)}.card-home--project:hover:after{opacity:.22;transform:translateX(0)}.card-home-body{display:flex;flex-direction:column;gap:.5rem;text-decoration:none;color:inherit}.card-home-header{display:flex;align-items:flex-start;gap:.6rem}.card-home-icon{display:inline-flex;align-items:center;justify-content:center;width:2.1rem;height:2.1rem;border-radius:999px;border:1px solid var(--color-border);background-color:color-mix(in srgb,var(--color-bg) 92%,transparent);box-shadow:0 1px 4px rgba(0,0,0,.4);font-size:.85rem}.card-badge{margin-left:.25rem;padding:.05rem .35rem;border-radius:999px;background-color:color-mix(in srgb,var(--color-accent) 22%,transparent);color:var(--color-accent);font-size:.6rem;font-weight:600}.card-home-footer{margin-top:.5rem;display:flex;align-items:center;gap:.5rem;justify-content:space-between}.card-home-footer--buttons{padding-top:.4rem;border-top:1px solid color-mix(in srgb,var(--color-border) 80%,transparent)}.card-tag-row{display:flex;flex-wrap:wrap;gap:.25rem}.card-tag-pill{padding:.1rem .45rem;border-radius:999px;border:1px solid color-mix(in srgb,var(--color-border) 80%,transparent);background-color:color-mix(in srgb,var(--color-bg) 92%,transparent);font-size:.65rem;color:var(--color-text-muted)}.card-cta{font-size:.7rem;border-radius:999px;border:1px solid transparent;transition:color .15s ease-out,border-color .15s ease-out,background-color .15s ease-out,transform .15s ease-out}.card-cta,.card-cta-btn{display:inline-flex;align-items:center;gap:.35rem;color:var(--color-text-muted);text-decoration:none;padding:.25rem .6rem}.card-cta-btn{border-radius:8px;font-size:.68rem;background-color:color-mix(in srgb,var(--color-bg) 92%,transparent);border:1px solid color-mix(in srgb,var(--color-border) 80%,transparent);transition:color .15s ease-out,background-color .15s ease-out,border-color .15s ease-out,transform .15s ease-out,box-shadow .15s ease-out}.card-cta-btn:hover{color:var(--color-accent);background-color:color-mix(in srgb,var(--color-surface) 96%,transparent);border-color:color-mix(in srgb,var(--color-accent) 50%,transparent);transform:translateY(-1px);box-shadow:0 10px 28px rgba(0,0,0,.45)}.card-cta-repo{display:inline-flex;align-items:center;gap:.4rem;padding:.25rem .7rem;border-radius:999px;border:1px solid color-mix(in srgb,var(--color-border) 85%,transparent);background-color:color-mix(in srgb,var(--color-bg) 94%,transparent);font-size:.7rem;color:var(--color-text-muted);text-decoration:none;transition:color .15s ease-out,border-color .15s ease-out,background-color .15s ease-out,transform .15s ease-out,box-shadow .15s ease-out}.card-cta-repo:hover{border-color:color-mix(in srgb,var(--color-accent) 55%,transparent);background-color:color-mix(in srgb,var(--color-surface) 96%,transparent);box-shadow:0 10px 28px rgba(0,0,0,.5)}.card-cta-repo:hover,.card-cta:hover{color:var(--color-accent);transform:translateY(-1px)}.card-cta:hover{border-color:color-mix(in srgb,var(--color-accent) 40%,transparent)}.card-cta:hover,.card-home--post{background-color:color-mix(in srgb,var(--color-surface) 94%,transparent)}.card-home--post{position:relative;overflow:hidden;border-left-width:2px;border-left-color:color-mix(in srgb,var(--color-border) 80%,transparent);transition:transform .18s ease-out,box-shadow .18s ease-out,border-color .18s ease-out,background-color .18s ease-out}.card-home--post:before{content:"";position:absolute;left:-4px;top:-20%;bottom:-20%;width:10px;background:linear-gradient(to bottom,transparent,color-mix(in srgb,var(--color-accent) 70%,transparent),transparent);opacity:0;transform:translateX(-6px);transition:opacity .22s ease-out,transform .22s ease-out;pointer-events:none}.card-home--post:hover{transform:translateY(-3px);background-color:color-mix(in srgb,var(--color-surface) 98%,transparent);border-left-color:color-mix(in srgb,var(--color-accent) 55%,var(--color-border));box-shadow:0 16px 34px rgba(0,0,0,.65)}.card-home--post:hover:before{opacity:.55;transform:translateX(0)}.card-home-icon--post{background-color:color-mix(in srgb,var(--color-bg) 94%,transparent)}.card-badge--soft{background-color:color-mix(in srgb,var(--color-accent) 16%,transparent);color:color-mix(in srgb,var(--color-accent) 85%,#fff)}.card{border-radius:.75rem;transition:all .2s ease-out}.card-pad{padding:1rem}.card:hover{box-shadow:0 6px 16px rgba(0,0,0,.2);border-color:color-mix(in srgb,var(--color-accent) 40%,transparent)}.layout-page{margin-left:auto;margin-right:auto;max-width:80rem;padding:1.5rem 1rem}@media (min-width:640px){.layout-page{padding-left:1.5rem;padding-right:1.5rem}}@media (min-width:1024px){.layout-page{padding-top:3rem;padding-bottom:3rem}}.layout-page-tight{margin-left:auto;margin-right:auto;max-width:72rem;padding:1rem}@media (min-width:640px){.layout-page-tight{padding-left:1.5rem;padding-right:1.5rem}}@media (min-width:1024px){.layout-page-tight{padding-top:2.5rem;padding-bottom:2.5rem}}.section-stack>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(2.5rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2.5rem*var(--tw-space-y-reverse))}.section-stack--home>*+*{margin-top:1.75rem}.section-stack>div+div.posts-section{border-top:1px solid color-mix(in srgb,var(--color-border) 60%,transparent);padding-top:1.5rem}.heading-page{font-size:1.875rem;line-height:2.25rem;font-weight:600;letter-spacing:-.025em}@media (min-width:640px){.heading-page{font-size:2.25rem;line-height:2.5rem}}.heading-section{font-size:.875rem;line-height:1.25rem;font-weight:600;letter-spacing:-.025em}.eyebrow{font-size:.65rem;text-transform:uppercase;letter-spacing:.22em}.card{border-radius:.75rem;border-width:1px;--tw-shadow:0 1px 2px 0 rgba(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);background-color:var(--color-surface);border-color:var(--color-border)}.card-pad{padding:1rem}@media (min-width:640px){.card-pad{padding:1.25rem}}.card-hover{transition-property:transform;transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;transition-timing-function:cubic-bezier(0,0,.2,1)}.card-hover:hover{--tw-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color);transform:translateY(-1px);border-color:var(--color-accent)}.btn-primary,.card-hover:hover{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.btn-primary{display:inline-flex;align-items:center;border-radius:9999px;padding:.5rem 1rem;font-size:.75rem;line-height:1rem;font-weight:500;--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1));--tw-shadow:0 1px 2px 0 rgba(0,0,0,.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color);transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;transition-timing-function:cubic-bezier(0,0,.2,1);background-color:var(--color-accent)}.btn-primary:hover{transform:translateY(-1px)}.btn-ghost{display:inline-flex;align-items:center;font-size:.75rem;line-height:1rem;font-weight:500;color:var(--color-text-muted)}.nav-shell{border-radius:9999px;border-width:1px;padding:.75rem;--tw-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);--tw-backdrop-blur:blur(8px);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);border-color:var(--color-border);background-color:color-mix(in srgb,var(--color-surface) 82%,transparent)}.nav-shell:before{content:"";position:absolute;inset-inline:0;top:0;bottom:0;height:1px;background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--color-accent) 80%,transparent),transparent);opacity:.8;pointer-events:none}.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem}@media (min-width:640px){.nav-inner{padding:.625rem 1.25rem}}.logo-badge{display:flex;height:2rem;width:2rem;align-items:center;justify-content:center;border-radius:9999px;font-size:.65rem;font-weight:600;--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1));background-color:var(--color-accent)}.nav-link{font-size:.78rem;font-weight:500;color:var(--color-text-muted)}.nav-link:hover{color:var(--color-accent)}.theme-toggle{display:inline-flex;height:2rem;width:2rem;align-items:center;justify-content:center;border-radius:9999px;border-width:1px;font-size:.7rem;--tw-shadow:0 1px 2px 0 rgba(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);background-color:var(--color-bg);color:var(--color-text-muted);border-color:var(--color-border);transition:background-color .15s ease-out,color .15s ease-out,transform .15s ease-out}.theme-toggle:hover{color:var(--color-accent);transform:translateY(-1px)}html[data-theme=dark] .theme-toggle{background-color:var(--color-surface)}.link-underline{position:relative;display:inline-block}.link-underline:after{content:"";position:absolute;left:0;bottom:-.15rem;width:0;height:1px;background-color:var(--color-accent);transition:width .16s ease-out}.link-underline:hover:after{width:100%}.footer-shell{border-radius:1rem;border-width:1px;--tw-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);--tw-backdrop-blur:blur(8px);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);border-color:var(--color-border);position:relative;overflow:hidden;background-color:color-mix(in srgb,var(--color-surface) 86%,transparent)}.footer-shell:before{content:"";position:absolute;inset-inline:0;top:0;height:1px;background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--color-accent) 80%,transparent),transparent);opacity:.8;pointer-events:none}.footer-inner{display:flex;flex-direction:column;gap:.75rem;padding:.75rem 1rem;font-size:.72rem}@media (min-width:640px){.footer-inner{flex-direction:row;align-items:center;justify-content:space-between;padding-left:1.25rem;padding-right:1.25rem}}.footer-links{display:flex;flex-wrap:wrap;gap:.75rem}.footer-link,.footer-links{align-items:center}.footer-link{display:inline-flex;gap:.25rem;font-size:.75rem;font-weight:500;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;transition-timing-function:cubic-bezier(0,0,.2,1);color:var(--color-text-muted)}.footer-link:hover{color:var(--color-accent)}.footer-small{font-size:.72rem;line-height:1.625;color:var(--color-text-muted)}.footer-float:hover{color:var(--color-accent);transform:translateY(-1px)}.footer-float:hover i{filter:drop-shadow(0 0 2px color-mix(in srgb,var(--color-accent) 60%,transparent))}.search-overlay{position:fixed;inset:0;z-index:40;display:none;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .18s ease-out}.search-overlay--open{opacity:1;display:block;pointer-events:auto}.search-panel{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;max-width:36rem;margin-inline:1.5rem;border-radius:1.1rem;border:1px solid var(--color-border);background-color:color-mix(in srgb,var(--color-bg) 96%,transparent);box-shadow:0 26px 70px rgba(0,0,0,.85);padding:.8rem .9rem .6rem;display:flex;flex-direction:column;gap:.6rem}.search-overlay--open .search-panel{animation:search-panel-in .18s ease-out}.search-overlay-backdrop{position:absolute;inset:0;background:radial-gradient(circle at top,rgba(0,0,0,.4),transparent 55%),rgba(0,0,0,.7);backdrop-filter:blur(12px)}.search-overlay .search-overlay--open .search-overlay-backdrop{animation:search-backdrop-in .18s ease-out}.search-overlay--closing .search-panel{animation:search-panel-out .18s ease-in forwards}.search-overlay--closing .search-overlay-backdrop{animation:search-backdrop-out .18s ease-in forwards}.search-panel-header{display:flex;align-items:center;gap:.6rem}.search-input-wrap{flex:1;display:flex;align-items:center;gap:.5rem;padding:.45rem .8rem;border-radius:999px;border:1px solid var(--color-border);background-color:color-mix(in srgb,var(--color-surface) 96%,transparent)}.search-input{flex:1;border:none;outline:none;font-size:.82rem;background:transparent;color:var(--color-text)}.search-input::-moz-placeholder{color:var(--color-text-muted)}.search-input::placeholder{color:var(--color-text-muted)}.search-close{width:2rem;height:2rem;border-radius:999px;border:1px solid var(--color-border);background-color:color-mix(in srgb,var(--color-bg) 90%,transparent);color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .16s ease-out,border-color .16s ease-out,color .16s ease-out,transform .16s ease-out}.search-close:hover{border-color:var(--color-accent);color:var(--color-accent);transform:translateY(-1px)}.search-panel-body{border-radius:.9rem;border:1px solid color-mix(in srgb,var(--color-border) 70%,transparent);background-color:color-mix(in srgb,var(--color-surface) 96%,transparent);padding:.5rem .4rem .4rem;display:flex;flex-direction:column}.search-results{max-height:18rem;padding:.25rem .15rem .4rem;overflow-y:auto}.search-empty-state{display:flex;flex-direction:column;align-items:center;padding:1.2rem .5rem 1.4rem;gap:.4rem}.search-empty-icon{width:2.3rem;height:2.3rem;border-radius:999px;border:1px solid var(--color-border);background-color:color-mix(in srgb,var(--color-bg) 92%,transparent);display:flex;align-items:center;justify-content:center}.search-empty-title{font-size:.86rem;font-weight:600;color:var(--color-text)}.search-empty-subtitle{font-size:.76rem;color:var(--color-text-muted)}.search-footer-hints{display:flex;flex-wrap:wrap;gap:.45rem;border-top:1px solid color-mix(in srgb,var(--color-border) 75%,transparent);padding:.4rem .5rem .1rem;margin-top:.1rem}.search-hint-key{display:inline-flex;align-items:center;gap:.25rem;font-size:.68rem;color:var(--color-text-muted)}.search-hint-key span:first-child,.search-hint-key span:nth-child(2){padding:.1rem .3rem;border-radius:.3rem;border:1px solid color-mix(in srgb,var(--color-border) 80%,transparent);background-color:color-mix(in srgb,var(--color-bg) 96%,transparent);font-size:.65rem}.search-hint-key.search-hint-right{margin-left:auto}.search-result-item{display:block;padding:.42rem .55rem;border-radius:.6rem;text-decoration:none;transition:background-color .12s ease-out,transform .12s ease-out}.search-result-item:hover{background-color:color-mix(in srgb,var(--color-surface) 92%,transparent);transform:translateY(-1px)}.search-result-title{font-size:.8rem;font-weight:500;color:var(--color-text)}.search-result-meta{margin-top:.15rem;font-size:.7rem;color:var(--color-text-muted)}.tech-carousel{display:flex;gap:.5rem;padding:.3rem .1rem .1rem;overflow-x:auto;scroll-snap-type:x mandatory}.tech-carousel::-webkit-scrollbar{height:4px}.tech-carousel::-webkit-scrollbar-thumb{border-radius:999px;background-color:hsla(0,0%,100%,.12)}.tech-pill{scroll-snap-align:start;display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .7rem;border-radius:999px;border:1px solid var(--color-border);background-color:color-mix(in srgb,var(--color-surface) 92%,transparent);box-shadow:0 10px 28px rgba(0,0,0,.28);white-space:nowrap}.badge-available{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .7rem;border-radius:999px;background-color:var(--color-accent);color:#fff;font-size:.7rem;font-weight:600;box-shadow:0 0 .4rem rgba(0,0,0,.4)}.tech-icon{font-size:1.5rem}.tech-strip{position:relative;overflow:hidden;padding-block:.4rem}.tech-strip-track{padding-top:.5rem;padding-bottom:.5rem;display:inline-flex;align-items:center;white-space:nowrap;animation-name:tech-marquee;animation-timing-function:linear;animation-iteration-count:infinite;animation-play-state:running;gap:1.5rem}.tech-strip--wide .tech-strip-track--primary{animation-duration:40s}.tech-strip--wide .tech-strip-track--secondary{animation-duration:40s;animation-direction:reverse}.tech-strip--compact .tech-strip-track--primary{animation-duration:40s}.tech-strip--compact .tech-strip-track--secondary{animation-duration:48s;animation-direction:reverse}.tech-strip--compact .tech-strip-track{gap:1.1rem}.tech-strip:hover .tech-strip-track{animation-play-state:paused}.tech-strip-item{display:inline-flex;align-items:center;gap:.4rem;opacity:.88;transition:opacity .15s ease-out,transform .15s ease-out}.tech-strip-item:hover{opacity:1;transform:translateY(-1px)}.markdown-body{max-width:85ch;margin-inline:auto;font-size:.95rem;line-height:1.75;color:var(--color-text);overflow-wrap:break-word;word-wrap:break-word;min-width:0}.markdown-body>*{margin-top:0;margin-bottom:0}.markdown-body>*+*{margin-top:1.25rem}.markdown-body p{color:var(--color-text);line-height:1.75}.markdown-body h1,.markdown-body h2,.markdown-body h3,.markdown-body h4,.markdown-body h5,.markdown-body h6{color:var(--color-text);font-weight:650;line-height:1.3;letter-spacing:-.01em;margin-top:2rem;margin-bottom:.75rem}.markdown-body h1{font-size:2rem;margin-top:0}.markdown-body h2{font-size:1.5rem;padding-bottom:.4rem;border-bottom:1px solid color-mix(in srgb,var(--color-border) 60%,transparent);margin-top:2.5rem}.markdown-body h3{font-size:1.25rem;margin-top:2rem}.markdown-body h4{font-size:1.1rem}.markdown-body h5{font-size:1rem}.markdown-body h6{font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted)}.markdown-body a{color:var(--color-accent);text-decoration:none;border-bottom:1px solid color-mix(in srgb,var(--color-accent) 35%,transparent);padding-bottom:.05rem;transition:color .15s ease-out,border-color .15s ease-out;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word}.markdown-body a:hover{color:color-mix(in srgb,var(--color-accent) 85%,#fff);border-bottom-color:var(--color-accent)}.markdown-body strong{font-weight:650;color:var(--color-text)}.markdown-body em{font-style:italic}.markdown-body ol,.markdown-body ul{padding-left:1.75rem;margin-top:1rem;margin-bottom:1rem}.markdown-body li{margin:.5rem 0;line-height:1.7;padding-left:.5rem;position:relative;transition:background-color .15s ease-out}.markdown-body li:hover{background-color:color-mix(in srgb,var(--color-surface) 30%,transparent);border-radius:.35rem}.markdown-body li>ol,.markdown-body li>ul{margin-top:.5rem;margin-bottom:.5rem}.markdown-body ul li::marker{color:var(--color-accent);font-size:1.1em}.markdown-body ul{list-style-type:disc}.markdown-body ul ul{list-style-type:circle}.markdown-body ul ul ul{list-style-type:square}.markdown-body ol{list-style-type:decimal}.markdown-body ol li::marker{color:var(--color-accent);font-weight:700;font-size:.95em}.markdown-body ol ol{list-style-type:lower-alpha}.markdown-body ol ol ol{list-style-type:lower-roman}.markdown-body li>p{margin-top:.35rem;margin-bottom:.35rem}.markdown-body li:first-child{margin-top:0}.markdown-body li:last-child{margin-bottom:0}.markdown-body dl{margin:1.5rem 0;padding:1.25rem;border-left:3px solid var(--color-accent);background:linear-gradient(to right,color-mix(in srgb,var(--color-accent) 8%,transparent),color-mix(in srgb,var(--color-surface) 40%,transparent) 3rem);border-radius:.6rem}.markdown-body dt{font-weight:650;color:var(--color-text);margin-top:1rem;margin-bottom:.5rem;font-size:1rem;display:flex;align-items:center;gap:.5rem}.markdown-body dt:first-child{margin-top:0}.markdown-body dt:before{content:"▸";color:var(--color-accent);font-size:.9em;font-weight:700}.markdown-body dd{margin-left:1.5rem;margin-bottom:.75rem;padding-left:1rem;border-left:2px solid color-mix(in srgb,var(--color-border) 60%,transparent);color:var(--color-text-muted);line-height:1.7}.markdown-body dd:last-child{margin-bottom:0}.markdown-body dd>p{margin:.25rem 0}.markdown-body dd>p:first-child{margin-top:0}.markdown-body dd>p:last-child{margin-bottom:0}.markdown-body ul.contains-task-list{list-style:none;padding-left:0}.markdown-body .task-list-item{display:flex;align-items:flex-start;gap:.65rem;padding:.5rem .75rem;margin:.35rem 0;border-radius:.45rem;transition:all .15s ease-out;background-color:color-mix(in srgb,var(--color-surface) 20%,transparent)}.markdown-body .task-list-item:hover{background-color:color-mix(in srgb,var(--color-surface) 50%,transparent);transform:translateX(3px)}.markdown-body .task-list-item input[type=checkbox]{margin-top:.35rem;flex-shrink:0;width:1.1rem;height:1.1rem;cursor:pointer;accent-color:var(--color-accent);border-radius:.25rem}.markdown-body .task-list-item input[type=checkbox]:checked{accent-color:#22c55e}.markdown-body .task-list-item input[type=checkbox]:checked+*{color:var(--color-text-muted);text-decoration:line-through;text-decoration-color:var(--color-text-muted)}.markdown-body .md-blockquote,.markdown-body blockquote{margin:1.75rem 0;padding:1.25rem 1.5rem;border-left:4px solid var(--color-accent);background:linear-gradient(to right,color-mix(in srgb,var(--color-accent) 8%,transparent),color-mix(in srgb,var(--color-surface) 60%,transparent) 3rem);border-radius:.6rem;color:var(--color-text);font-style:italic;box-shadow:0 2px 8px rgba(0,0,0,.15);position:relative}.markdown-body .md-blockquote:before,.markdown-body blockquote:before{content:'"';position:absolute;left:.75rem;top:.5rem;font-size:2.5rem;line-height:1;color:color-mix(in srgb,var(--color-accent) 25%,transparent);font-family:Georgia,serif;font-weight:700}.markdown-body .md-blockquote p,.markdown-body blockquote p{color:var(--color-text);font-size:.98rem;line-height:1.7}.markdown-body .md-blockquote p+p,.markdown-body blockquote p+p{margin-top:.85rem}.markdown-body .md-blockquote strong,.markdown-body blockquote strong{color:var(--color-text);font-weight:650}.markdown-body .md-alert{margin:1.75rem 0;padding:1rem 1.25rem 1rem 3rem;border-radius:.6rem;border-left:4px solid;position:relative;box-shadow:0 2px 8px rgba(0,0,0,.15)}.markdown-body .md-alert:before{content:"";position:absolute;left:1rem;top:1.1rem;width:1.25rem;height:1.25rem;background-size:contain;background-repeat:no-repeat;background-position:50%}.markdown-body .md-alert p:first-child{margin-top:0}.markdown-body .md-alert p:last-child{margin-bottom:0}.markdown-body .md-alert-note{background:linear-gradient(to right,color-mix(in srgb,#3b82f6 10%,transparent),color-mix(in srgb,var(--color-surface) 60%,transparent) 3rem);border-left-color:#3b82f6}.markdown-body .md-alert-note:before{content:"ℹ";display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;color:#3b82f6;background:none}.markdown-body .md-alert-tip{background:linear-gradient(to right,color-mix(in srgb,#22c55e 10%,transparent),color-mix(in srgb,var(--color-surface) 60%,transparent) 3rem);border-left-color:#22c55e}.markdown-body .md-alert-tip:before{content:"💡";font-size:1.1rem}.markdown-body .md-alert-important{background:linear-gradient(to right,color-mix(in srgb,var(--color-accent) 12%,transparent),color-mix(in srgb,var(--color-surface) 60%,transparent) 3rem);border-left-color:var(--color-accent)}.markdown-body .md-alert-important:before{content:"⚡";font-size:1.1rem}.markdown-body .md-alert-warning{background:linear-gradient(to right,color-mix(in srgb,#f59e0b 10%,transparent),color-mix(in srgb,var(--color-surface) 60%,transparent) 3rem);border-left-color:#f59e0b}.markdown-body .md-alert-warning:before{content:"⚠";display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:#f59e0b;background:none}.markdown-body .md-alert-caution,.markdown-body .md-alert-danger{background:linear-gradient(to right,color-mix(in srgb,#ef4444 10%,transparent),color-mix(in srgb,var(--color-surface) 60%,transparent) 3rem);border-left-color:#ef4444}.markdown-body .md-alert-caution:before,.markdown-body .md-alert-danger:before{content:"🛑";font-size:1.1rem}.markdown-body :not(pre)>code{font-family:JetBrains Mono,Fira Code,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.88em;padding:.15rem .4rem;border-radius:.35rem;background:color-mix(in srgb,var(--color-surface) 80%,transparent);border:1px solid color-mix(in srgb,var(--color-border) 70%,transparent);color:color-mix(in srgb,var(--color-accent) 90%,#fff)}html[data-theme=light] .markdown-body :not(pre)>code{background:#f3f4f6;border-color:#d1d5db;color:#7c3aed}.markdown-body pre{margin:1.5rem 0;padding:0;overflow:hidden;overflow-x:auto;border-radius:.75rem;border:1px solid color-mix(in srgb,var(--color-border) 70%,transparent);background:color-mix(in srgb,var(--color-surface) 40%,transparent);box-shadow:0 4px 12px rgba(0,0,0,.3);max-width:100%}html[data-theme=light] .markdown-body pre{background:#f9fafb;border-color:#e5e7eb;box-shadow:0 2px 8px rgba(0,0,0,.08)}.markdown-body pre code{display:block;padding:1.25rem 1.5rem;overflow-x:auto;font-family:JetBrains Mono,Fira Code,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.88rem;line-height:1.6;color:var(--color-text);background:transparent;border:none}.markdown-body .highlight{position:relative;background:color-mix(in srgb,var(--color-surface) 40%,transparent);box-shadow:0 4px 12px rgba(0,0,0,.3);overflow:hidden}.markdown-body .highlight pre{margin:0;border:none;border-radius:0;box-shadow:none}.mb-codeblock{margin:1.5rem 0;border:1px solid color-mix(in srgb,var(--color-border) 70%,transparent);border-radius:.75rem;background:color-mix(in srgb,var(--color-surface) 40%,transparent);box-shadow:0 4px 12px rgba(0,0,0,.3)}.mb-codeblock-header{padding:.75rem 1rem;border-bottom:1px solid color-mix(in srgb,var(--color-border) 60%,transparent);background:color-mix(in srgb,var(--color-bg) 50%,transparent)}.mb-codeblock-left{gap:.5rem}.mb-codeblock-label{color:var(--color-text-muted);font-size:.75rem;font-weight:500;letter-spacing:.02em}.mb-codeblock-badge{font-size:.7rem;font-weight:600;padding:.2rem .5rem;background:color-mix(in srgb,var(--color-accent) 20%,transparent);letter-spacing:.05em}.mb-codeblock-actions{gap:.25rem}.mb-codeblock-actions button{background:transparent;border:1px solid color-mix(in srgb,var(--color-border) 70%,transparent);color:var(--color-text-muted);cursor:pointer;font-size:.7rem;padding:.3rem .6rem;border-radius:.35rem;transition:all .15s ease-out;display:flex;align-items:center;gap:.35rem}.mb-codeblock-actions button:hover{color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 15%,transparent);border-color:var(--color-accent)}.mb-codeblock-content pre{border-radius:0;box-shadow:none}.mb-codeblock-content code{font-family:JetBrains Mono,Fira Code,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.88rem;line-height:1.6}.markdown-body table{width:100%;margin:1.5rem 0;border-collapse:collapse;font-size:.9rem;border-radius:.75rem;overflow:hidden;border:1px solid color-mix(in srgb,var(--color-border) 70%,transparent)}.markdown-body thead{background:color-mix(in srgb,var(--color-surface) 60%,transparent)}.markdown-body th{padding:.75rem 1rem;text-align:left;font-weight:600;color:var(--color-text);border-bottom:1px solid color-mix(in srgb,var(--color-border) 70%,transparent)}.markdown-body td{padding:.75rem 1rem;border-bottom:1px solid color-mix(in srgb,var(--color-border) 60%,transparent)}.markdown-body tbody tr:last-child td{border-bottom:none}.markdown-body tbody tr:hover{background:color-mix(in srgb,var(--color-surface) 30%,transparent)}.markdown-body hr{border:0;border-top:1px solid color-mix(in srgb,var(--color-border) 70%,transparent);margin:2rem 0}.markdown-body .md-link{position:relative}.markdown-body a.md-link[target=_blank]:after{display:inline-block;margin-left:.25rem;font-size:.85em;opacity:.6;transition:all .15s ease-out}.markdown-body a.md-link[target=_blank]:hover:after{opacity:1;transform:translate(2px,-2px)}.markdown-body .md-heading-anchor{position:relative;color:inherit;text-decoration:none;border-bottom:none;padding-bottom:0}.markdown-body .md-heading-anchor:before{content:"#";position:absolute;left:-1.5rem;opacity:0;color:var(--color-accent);font-weight:400;transition:opacity .15s ease-out}.markdown-body h1:hover .md-heading-anchor:before,.markdown-body h2:hover .md-heading-anchor:before,.markdown-body h3:hover .md-heading-anchor:before,.markdown-body h4:hover .md-heading-anchor:before,.markdown-body h5:hover .md-heading-anchor:before,.markdown-body h6:hover .md-heading-anchor:before{opacity:1}.markdown-body .md-heading-anchor:hover{color:var(--color-accent)}.markdown-body .table-wrap{margin:1.75rem 0;overflow-x:auto;border-radius:.75rem;border:1px solid color-mix(in srgb,var(--color-border) 70%,transparent);box-shadow:0 2px 8px rgba(0,0,0,.1)}.markdown-body .table-wrap table{margin:0;border:none;border-radius:0}.markdown-body .table-wrap::-webkit-scrollbar{height:8px}.markdown-body .table-wrap::-webkit-scrollbar-track{background:color-mix(in srgb,var(--color-bg) 30%,transparent);border-radius:0 0 .75rem .75rem}.markdown-body .table-wrap::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--color-accent) 50%,transparent);border-radius:4px}.markdown-body .table-wrap::-webkit-scrollbar-thumb:hover{background:var(--color-accent)}.markdown-body img{display:block;max-width:100%;height:auto;margin:1.5rem auto;border-radius:.75rem;border:1px solid color-mix(in srgb,var(--color-border) 60%,transparent)}.markdown-body figure{margin:1.5rem 0;text-align:center}.markdown-body figcaption{margin-top:.5rem;font-size:.85rem;color:var(--color-text-muted);font-style:italic}.markdown-body .md-image{margin:2rem 0;text-align:center}.markdown-body .md-image a{display:inline-block;position:relative;overflow:hidden;border-radius:.85rem;box-shadow:0 4px 12px rgba(0,0,0,.15);transition:all .25s ease-out;border:1px solid color-mix(in srgb,var(--color-border) 60%,transparent);border-bottom:none;padding-bottom:0}.markdown-body .md-image a:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,color-mix(in srgb,var(--color-accent) 0,transparent),color-mix(in srgb,var(--color-accent) 15%,transparent));opacity:0;transition:opacity .25s ease-out;pointer-events:none;z-index:1}.markdown-body .md-image a:after{content:"🔍";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);font-size:2.5rem;opacity:0;transition:all .25s ease-out;z-index:2;pointer-events:none;filter:drop-shadow(0 2px 8px rgba(0,0,0,.5))}.markdown-body .md-image a:hover{transform:translateY(-4px);box-shadow:0 12px 28px rgba(0,0,0,.25);border-color:color-mix(in srgb,var(--color-accent) 50%,transparent)}.markdown-body .md-image a:hover:before{opacity:1}.markdown-body .md-image a:hover:after{opacity:1;transform:translate(-50%,-50%) scale(1)}.markdown-body .md-image img{margin:0;border:none;border-radius:.75rem;display:block;transition:all .25s ease-out}.markdown-body .md-image a:hover img{filter:brightness(.85)}.markdown-body .md-image figcaption{display:none}.markdown-body .chroma{background:transparent}.markdown-body .chroma .err{color:#f87171}.markdown-body .chroma .lntd{padding:0}.markdown-body .chroma .lntable{border-spacing:0}html[data-theme=dark] .markdown-body .chroma .k,html[data-theme=dark] .markdown-body .chroma .kc,html[data-theme=dark] .markdown-body .chroma .kd,html[data-theme=dark] .markdown-body .chroma .kn,html[data-theme=dark] .markdown-body .chroma .kp,html[data-theme=dark] .markdown-body .chroma .kr,html[data-theme=dark] .markdown-body .chroma .kt{color:#c084fc}html[data-theme=dark] .markdown-body .chroma .n{color:#e5e7eb}html[data-theme=dark] .markdown-body .chroma .na{color:#fbbf24}html[data-theme=dark] .markdown-body .chroma .nb{color:#60a5fa}html[data-theme=dark] .markdown-body .chroma .nc{color:#fbbf24}html[data-theme=dark] .markdown-body .chroma .nf{color:#60a5fa}html[data-theme=dark] .markdown-body .chroma .nn{color:#fbbf24}html[data-theme=dark] .markdown-body .chroma .s,html[data-theme=dark] .markdown-body .chroma .s1,html[data-theme=dark] .markdown-body .chroma .s2,html[data-theme=dark] .markdown-body .chroma .sb,html[data-theme=dark] .markdown-body .chroma .sc,html[data-theme=dark] .markdown-body .chroma .sd{color:#86efac}html[data-theme=dark] .markdown-body .chroma .se,html[data-theme=dark] .markdown-body .chroma .si{color:#fbbf24}html[data-theme=dark] .markdown-body .chroma .sr,html[data-theme=dark] .markdown-body .chroma .ss{color:#86efac}html[data-theme=dark] .markdown-body .chroma .m,html[data-theme=dark] .markdown-body .chroma .mb,html[data-theme=dark] .markdown-body .chroma .mf,html[data-theme=dark] .markdown-body .chroma .mh,html[data-theme=dark] .markdown-body .chroma .mi,html[data-theme=dark] .markdown-body .chroma .mo{color:#fb923c}html[data-theme=dark] .markdown-body .chroma .o,html[data-theme=dark] .markdown-body .chroma .ow{color:#c084fc}html[data-theme=dark] .markdown-body .chroma .c,html[data-theme=dark] .markdown-body .chroma .c1,html[data-theme=dark] .markdown-body .chroma .cm{color:#6b7280;font-style:italic}html[data-theme=dark] .markdown-body .chroma .p{color:#9ca3af}html[data-theme=dark] .markdown-body .chroma .g,html[data-theme=dark] .markdown-body .chroma .gd{color:#ef4444}html[data-theme=dark] .markdown-body .chroma .ge{font-style:italic}html[data-theme=dark] .markdown-body .chroma .gi{color:#22c55e}html[data-theme=dark] .markdown-body .chroma .gs{font-weight:700}html[data-theme=light] .markdown-body .chroma .k,html[data-theme=light] .markdown-body .chroma .kc,html[data-theme=light] .markdown-body .chroma .kd,html[data-theme=light] .markdown-body .chroma .kn,html[data-theme=light] .markdown-body .chroma .kp,html[data-theme=light] .markdown-body .chroma .kr,html[data-theme=light] .markdown-body .chroma .kt{color:#7c3aed}html[data-theme=light] .markdown-body .chroma .n{color:#1f2937}html[data-theme=light] .markdown-body .chroma .na{color:#d97706}html[data-theme=light] .markdown-body .chroma .nb{color:#2563eb}html[data-theme=light] .markdown-body .chroma .nc{color:#d97706}html[data-theme=light] .markdown-body .chroma .nf{color:#2563eb}html[data-theme=light] .markdown-body .chroma .nn{color:#d97706}html[data-theme=light] .markdown-body .chroma .s,html[data-theme=light] .markdown-body .chroma .s1,html[data-theme=light] .markdown-body .chroma .s2,html[data-theme=light] .markdown-body .chroma .sb,html[data-theme=light] .markdown-body .chroma .sc,html[data-theme=light] .markdown-body .chroma .sd{color:#16a34a}html[data-theme=light] .markdown-body .chroma .se,html[data-theme=light] .markdown-body .chroma .si{color:#d97706}html[data-theme=light] .markdown-body .chroma .sr,html[data-theme=light] .markdown-body .chroma .ss{color:#16a34a}html[data-theme=light] .markdown-body .chroma .m,html[data-theme=light] .markdown-body .chroma .mb,html[data-theme=light] .markdown-body .chroma .mf,html[data-theme=light] .markdown-body .chroma .mh,html[data-theme=light] .markdown-body .chroma .mi,html[data-theme=light] .markdown-body .chroma .mo{color:#dc2626}html[data-theme=light] .markdown-body .chroma .o,html[data-theme=light] .markdown-body .chroma .ow{color:#7c3aed}html[data-theme=light] .markdown-body .chroma .c,html[data-theme=light] .markdown-body .chroma .c1,html[data-theme=light] .markdown-body .chroma .cm{color:#6b7280;font-style:italic}html[data-theme=light] .markdown-body .chroma .p{color:#4b5563}html[data-theme=light] .markdown-body .chroma .g,html[data-theme=light] .markdown-body .chroma .gd{color:#dc2626}html[data-theme=light] .markdown-body .chroma .ge{font-style:italic}html[data-theme=light] .markdown-body .chroma .gi{color:#16a34a}html[data-theme=light] .markdown-body .chroma .gs{font-weight:700}.mb-codeblock{margin:1.75rem 0;border:1px solid color-mix(in srgb,var(--color-border) 65%,transparent);border-radius:.85rem;overflow:hidden;background:color-mix(in srgb,var(--color-surface) 35%,transparent);box-shadow:0 4px 6px rgba(0,0,0,.1),0 10px 20px rgba(0,0,0,.15);transition:box-shadow .2s ease-out}.mb-codeblock:hover{box-shadow:0 4px 6px rgba(0,0,0,.15),0 12px 24px rgba(0,0,0,.2)}html[data-theme=light] .mb-codeblock{background:#f9fafb;border-color:#e5e7eb;box-shadow:0 2px 4px rgba(0,0,0,.05),0 4px 8px rgba(0,0,0,.08)}html[data-theme=light] .mb-codeblock:hover{box-shadow:0 4px 8px rgba(0,0,0,.08),0 8px 16px rgba(0,0,0,.12)}.mb-codeblock-header{display:flex;align-items:center;justify-content:space-between;padding:.7rem 1rem;border-bottom:1px solid color-mix(in srgb,var(--color-border) 55%,transparent);background:color-mix(in srgb,var(--color-bg) 45%,transparent);gap:1rem}html[data-theme=light] .mb-codeblock-header{background:#f3f4f6;border-bottom-color:#e5e7eb}.mb-codeblock-left{display:flex;align-items:center;gap:.6rem;min-width:0;flex:1}.mb-codeblock-badge{font-size:.68rem;font-weight:700;padding:.25rem .55rem;border-radius:.35rem;background:color-mix(in srgb,var(--color-accent) 22%,transparent);color:var(--color-accent);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;border:1px solid color-mix(in srgb,var(--color-accent) 35%,transparent)}.mb-codeblock-filename{display:inline-flex;align-items:center;gap:.4rem;color:var(--color-text);font-size:.75rem;font-weight:500;padding:.2rem .65rem;border-radius:.35rem;background:color-mix(in srgb,var(--color-bg) 35%,transparent);border:1px solid color-mix(in srgb,var(--color-border) 60%,transparent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:20rem}.mb-codeblock-actions{display:flex;gap:.4rem;flex-shrink:0}.mb-action-btn{display:inline-flex;align-items:center;gap:.35rem;background:transparent;border:1px solid color-mix(in srgb,var(--color-border) 70%,transparent);color:var(--color-text-muted);cursor:pointer;font-size:.7rem;font-weight:500;padding:.35rem .7rem;border-radius:.4rem;transition:all .15s ease-out;font-family:inherit;white-space:nowrap}.mb-action-btn:hover{color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 12%,transparent);border-color:var(--color-accent);transform:translateY(-1px);box-shadow:0 2px 8px rgba(168,85,247,.2)}.mb-action-btn:active{transform:translateY(0)}.mb-action-btn i{font-size:.7rem}.mb-btn-success{color:#22c55e!important;border-color:#22c55e!important;background:color-mix(in srgb,#22c55e 15%,transparent)!important}.mb-codeblock-content{position:relative;background:color-mix(in srgb,var(--color-bg) 20%,transparent);transition:max-height .3s ease-out}html[data-theme=light] .mb-codeblock-content{background:#fff}.mb-codeblock-content pre{margin:0;padding:1.25rem 1.5rem;overflow-x:auto;background:transparent;border:none}.mb-codeblock-content pre code{font-family:JetBrains Mono,Fira Code,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.88rem;line-height:1.65;font-weight:400}.mb-codeblock-content pre::-webkit-scrollbar{height:8px}.mb-codeblock-content pre::-webkit-scrollbar-track{background:color-mix(in srgb,var(--color-bg) 30%,transparent);border-radius:4px}.mb-codeblock-content pre::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--color-border) 70%,transparent);border-radius:4px}.mb-codeblock-content pre::-webkit-scrollbar-thumb:hover{background:var(--color-accent)}.mb-collapse-overlay{display:none;position:absolute;inset:0;background:linear-gradient(180deg,transparent 0,rgba(0,0,0,.25) 35%,rgba(0,0,0,.88));align-items:flex-end;justify-content:center;padding-bottom:1.2rem;cursor:pointer;z-index:10;backdrop-filter:blur(1px)}.mb-expand-trigger{display:inline-flex;align-items:center;gap:.45rem;padding:.5rem 1rem;border-radius:.5rem;border:1px solid var(--color-accent);background:color-mix(in srgb,var(--color-accent) 18%,transparent);color:var(--color-accent);font-size:.75rem;font-weight:650;cursor:pointer;transition:all .15s ease-out;backdrop-filter:blur(10px);box-shadow:0 4px 12px rgba(0,0,0,.3)}.mb-expand-trigger:hover{background:color-mix(in srgb,var(--color-accent) 28%,transparent);transform:translateY(-2px);box-shadow:0 6px 16px rgba(168,85,247,.35);border-color:color-mix(in srgb,var(--color-accent) 90%,#fff)}.mb-expand-trigger i{font-size:.7rem;animation:bounce-icon 1.8s ease-in-out infinite}@keyframes bounce-icon{0%,to{transform:translateY(0)}50%{transform:translateY(4px)}}.mb-codeblock[data-lang=javascript] .mb-codeblock-badge,.mb-codeblock[data-lang=js] .mb-codeblock-badge{background:color-mix(in srgb,#f7df1e 28%,transparent);color:#f7df1e;border-color:color-mix(in srgb,#f7df1e 40%,transparent)}.mb-codeblock[data-lang=ts] .mb-codeblock-badge,.mb-codeblock[data-lang=typescript] .mb-codeblock-badge{background:color-mix(in srgb,#3178c6 28%,transparent);color:#60a5fa;border-color:color-mix(in srgb,#3178c6 40%,transparent)}.mb-codeblock[data-lang=py] .mb-codeblock-badge,.mb-codeblock[data-lang=python] .mb-codeblock-badge{background:color-mix(in srgb,#3776ab 28%,transparent);color:#60a5fa;border-color:color-mix(in srgb,#3776ab 40%,transparent)}.mb-codeblock[data-lang=go] .mb-codeblock-badge{background:color-mix(in srgb,#00add8 28%,transparent);color:#22d3ee;border-color:color-mix(in srgb,#00add8 40%,transparent)}.mb-codeblock[data-lang=rs] .mb-codeblock-badge,.mb-codeblock[data-lang=rust] .mb-codeblock-badge{background:color-mix(in srgb,#ce422b 28%,transparent);color:#fb923c;border-color:color-mix(in srgb,#ce422b 40%,transparent)}.mb-codeblock[data-lang=html] .mb-codeblock-badge{background:color-mix(in srgb,#e34c26 28%,transparent);color:#f87171;border-color:color-mix(in srgb,#e34c26 40%,transparent)}.mb-codeblock[data-lang=css] .mb-codeblock-badge{background:color-mix(in srgb,#264de4 28%,transparent);color:#60a5fa;border-color:color-mix(in srgb,#264de4 40%,transparent)}.mb-codeblock[data-lang=bash] .mb-codeblock-badge,.mb-codeblock[data-lang=sh] .mb-codeblock-badge,.mb-codeblock[data-lang=shell] .mb-codeblock-badge{background:color-mix(in srgb,#4eaa25 28%,transparent);color:#86efac;border-color:color-mix(in srgb,#4eaa25 40%,transparent)}.mb-codeblock[data-lang=json] .mb-codeblock-badge{background:color-mix(in srgb,#888 28%,transparent);color:#d1d5db;border-color:color-mix(in srgb,#888 40%,transparent)}.mb-codeblock[data-lang=yaml] .mb-codeblock-badge,.mb-codeblock[data-lang=yml] .mb-codeblock-badge{background:color-mix(in srgb,#cb171e 28%,transparent);color:#fca5a5;border-color:color-mix(in srgb,#cb171e 40%,transparent)}.mb-codeblock[data-lang=java] .mb-codeblock-badge{background:color-mix(in srgb,#f89820 28%,transparent);color:#fbbf24;border-color:color-mix(in srgb,#f89820 40%,transparent)}.mb-codeblock[data-lang="c++"] .mb-codeblock-badge,.mb-codeblock[data-lang=cpp] .mb-codeblock-badge{background:color-mix(in srgb,#00599c 28%,transparent);color:#60a5fa;border-color:color-mix(in srgb,#00599c 40%,transparent)}.mb-codeblock[data-lang=c] .mb-codeblock-badge{background:color-mix(in srgb,#555 28%,transparent);color:#9ca3af;border-color:color-mix(in srgb,#555 40%,transparent)}.mb-codeblock[data-lang=rb] .mb-codeblock-badge,.mb-codeblock[data-lang=ruby] .mb-codeblock-badge{background:color-mix(in srgb,#cc342d 28%,transparent);color:#f87171;border-color:color-mix(in srgb,#cc342d 40%,transparent)}.mb-codeblock[data-lang=php] .mb-codeblock-badge{background:color-mix(in srgb,#777bb4 28%,transparent);color:#a78bfa;border-color:color-mix(in srgb,#777bb4 40%,transparent)}.mb-codeblock[data-lang=sql] .mb-codeblock-badge{background:color-mix(in srgb,#e38c00 28%,transparent);color:#fbbf24;border-color:color-mix(in srgb,#e38c00 40%,transparent)}@media (max-width:640px){.mb-codeblock-header{flex-direction:column;align-items:flex-start;gap:.6rem}.mb-codeblock-actions{width:100%;justify-content:flex-end}.mb-action-btn span{display:none}.mb-action-btn{padding:.4rem;width:2rem;height:2rem;justify-content:center}.mb-codeblock-filename{max-width:100%}}@keyframes tech-marquee{0%{transform:translateX(0)}to{transform:translateX(-50%)}}@media (prefers-reduced-motion:reduce){.tech-strip-track{animation:none}}.markdown-body .gallery-container{margin:2rem 0;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}@media (max-width:640px){.markdown-body .gallery-container{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}}.markdown-body .gallery-container a{display:block;border:none!important;padding:0;margin:0;border-radius:.5rem;overflow:hidden;transition:all .2s ease-out;position:relative;cursor:zoom-in;aspect-ratio:4/3}.markdown-body .gallery-container a:hover{transform:translateY(-2px);box-shadow:0 8px 16px rgba(0,0,0,.2)}.markdown-body .gallery-container img{display:block;width:100%;height:100%;-o-object-fit:cover;object-fit:cover;margin:0;border:none;border-radius:.5rem;transition:all .2s ease-out}.markdown-body .gallery-container a:hover img{filter:brightness(.9)}.article-layout{display:grid;grid-template-columns:1fr;gap:2rem;position:relative;min-width:0}@media (min-width:1024px){.article-layout{grid-template-columns:260px 1fr;gap:3rem}.article-toc{order:1}.article-main{order:2}}.article-main{min-width:0;overflow-x:hidden}.article-toc{width:100%}.toc-wrapper{position:sticky;top:2rem;background:color-mix(in srgb,var(--color-surface) 50%,transparent);border:1px solid var(--color-border);border-radius:.85rem;padding:1rem;box-shadow:0 4px 12px rgba(0,0,0,.15);backdrop-filter:blur(10px);transition:all .2s ease-out;max-height:calc(100vh - 24rem);overflow:hidden;display:flex;flex-direction:column}.toc-wrapper:hover{box-shadow:0 6px 16px rgba(0,0,0,.2);border-color:color-mix(in srgb,var(--color-accent) 40%,transparent)}.toc-header{justify-content:space-between;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid color-mix(in srgb,var(--color-border) 60%,transparent)}.toc-header,.toc-title{display:flex;align-items:center}.toc-title{gap:.5rem;font-size:.85rem;font-weight:650;color:var(--color-text);margin:0}.toc-title i{color:var(--color-accent);font-size:.75rem}.toc-toggle{display:flex;background:transparent;border:1px solid var(--color-border);color:var(--color-text-muted);width:1.75rem;height:1.75rem;border-radius:.4rem;cursor:pointer;transition:all .15s ease-out;align-items:center;justify-content:center}.toc-toggle:hover{color:var(--color-accent);border-color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 10%,transparent)}.toc-toggle i{font-size:.7rem;transition:transform .2s ease-out}.toc-wrapper.collapsed .toc-toggle i{transform:rotate(-90deg)}.toc-wrapper.collapsed .toc-nav{max-height:0;opacity:0;overflow:hidden}@media (max-width:1023px){.toc-wrapper{position:relative;top:0}}.toc-nav{font-size:.8rem;line-height:1.6;transition:all .3s ease-out;overflow-y:auto;overflow-x:hidden;flex:1;min-height:0}.toc-nav::-webkit-scrollbar{width:6px}.toc-nav::-webkit-scrollbar-track{background:color-mix(in srgb,var(--color-bg) 30%,transparent);border-radius:3px}.toc-nav::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--color-border) 70%,transparent);border-radius:3px}.toc-nav::-webkit-scrollbar-thumb:hover{background:var(--color-accent)}.toc-nav>ul{padding-left:0}.toc-nav ul,.toc-nav>ul{list-style:none;margin:0}.toc-nav ul ul{padding-left:1rem;margin-top:.25rem;border-left:1px solid color-mix(in srgb,var(--color-border) 50%,transparent)}.toc-nav li{margin:.35rem 0;padding-left:0}.toc-nav li:hover{background:none}.toc-nav a{display:block;padding:.35rem .5rem;color:var(--color-text-muted);text-decoration:none;border-left:2px solid transparent;border-radius:.35rem;transition:all .15s ease-out;border-bottom:none}.toc-nav a:hover{color:var(--color-text);background:color-mix(in srgb,var(--color-surface) 40%,transparent);transform:translateX(3px)}.toc-nav a.active,.toc-nav a:hover{border-left-color:var(--color-accent)}.toc-nav a.active{color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 12%,transparent);font-weight:600}@media (max-width:1023px){.article-toc{order:-1;margin-bottom:1.5rem}}.about-page{max-width:900px;margin-inline:auto}.about-hero{text-align:center;padding:3rem 0 4rem;position:relative}.about-hero:after{content:"";position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:60px;height:3px;background:linear-gradient(90deg,transparent,var(--color-accent),transparent);border-radius:999px}.about-hero-content{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.about-avatar,.about-avatar-placeholder{width:140px;height:140px;border-radius:50%;overflow:hidden;border:3px solid var(--color-accent);box-shadow:0 8px 24px rgba(0,0,0,.2),0 0 0 8px color-mix(in srgb,var(--color-accent) 15%,transparent);transition:all .3s ease-out}.about-avatar-placeholder:hover,.about-avatar:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 12px 32px rgba(0,0,0,.3),0 0 0 12px color-mix(in srgb,var(--color-accent) 20%,transparent)}.about-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.about-avatar-placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,color-mix(in srgb,var(--color-accent) 20%,transparent),color-mix(in srgb,var(--color-accent) 10%,transparent));backdrop-filter:blur(10px)}.about-avatar-placeholder i{font-size:4rem;color:var(--color-accent)}.about-title{font-size:2.5rem;font-weight:700;letter-spacing:-.02em;color:var(--color-text);margin:0;line-height:1.2}.about-subtitle{font-size:1.1rem;color:var(--color-text-muted);max-width:600px;line-height:1.6;margin:0}.about-content{margin-bottom:4rem}.about-content .card{background:color-mix(in srgb,var(--color-surface) 60%,transparent);border:1px solid color-mix(in srgb,var(--color-border) 70%,transparent);box-shadow:0 4px 16px rgba(0,0,0,.12);padding:2rem}.about-content .markdown-body h3{display:flex;align-items:center;gap:.75rem;margin-top:2.5rem;padding-bottom:.5rem;border-bottom:2px solid color-mix(in srgb,var(--color-accent) 30%,transparent)}.about-content .markdown-body h3:before{content:"";display:inline-block;width:4px;height:1.5rem;background:var(--color-accent);border-radius:999px}.timeline{position:relative;padding:2rem 0 1rem;margin-top:2rem}.timeline:before{content:"";position:absolute;left:20px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,transparent,var(--color-accent) 10%,var(--color-accent) 90%,transparent)}.timeline-item{position:relative;padding-left:60px;margin-bottom:3rem}.timeline-item:last-child{margin-bottom:0}.timeline-marker{position:absolute;left:0;top:8px;width:42px;height:42px;display:flex;align-items:center;justify-content:center;z-index:2}.timeline-marker:before{content:"";position:absolute;width:16px;height:16px;background:var(--color-accent);border-radius:50%;border:3px solid var(--color-bg);box-shadow:0 0 0 4px color-mix(in srgb,var(--color-accent) 20%,transparent),0 4px 12px rgba(0,0,0,.3);transition:all .3s ease-out}.timeline-item:hover .timeline-marker:before{transform:scale(1.3);box-shadow:0 0 0 6px color-mix(in srgb,var(--color-accent) 30%,transparent),0 6px 16px rgba(0,0,0,.4)}.timeline-content{background:color-mix(in srgb,var(--color-surface) 30%,transparent);border:1px solid color-mix(in srgb,var(--color-border) 50%,transparent);border-radius:.85rem;padding:1.5rem;transition:all .3s ease-out;position:relative;overflow:hidden}.timeline-content:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--color-accent);opacity:0;transition:opacity .3s ease-out}.timeline-item:hover .timeline-content{background:color-mix(in srgb,var(--color-surface) 50%,transparent);border-color:color-mix(in srgb,var(--color-accent) 40%,transparent);transform:translateX(4px);box-shadow:0 8px 24px rgba(0,0,0,.2)}.timeline-item:hover .timeline-content:before{opacity:1}.timeline-content>p:first-child{margin-top:0}.timeline-content>p:last-child{margin-bottom:0}.timeline-content strong{font-size:1.1rem;color:var(--color-text);display:block;margin-bottom:.25rem}.timeline-content em{font-size:.85rem;color:var(--color-text-muted);font-style:normal;display:block;margin-bottom:.75rem}.timeline-content a{color:var(--color-accent)}.timeline hr{display:none}.about-social{text-align:center;padding:3rem 2rem;background:color-mix(in srgb,var(--color-surface) 40%,transparent);border:1px solid color-mix(in srgb,var(--color-border) 60%,transparent);border-radius:1.25rem;box-shadow:0 4px 16px rgba(0,0,0,.1)}.about-social-title{font-size:1.25rem;font-weight:650;color:var(--color-text);margin-bottom:1.5rem}.about-social-links{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem}.about-social-link{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:999px;background:color-mix(in srgb,var(--color-bg) 60%,transparent);border:1px solid color-mix(in srgb,var(--color-border) 70%,transparent);color:var(--color-text-muted);text-decoration:none;font-size:.9rem;font-weight:500;transition:all .2s ease-out;box-shadow:0 2px 8px rgba(0,0,0,.08)}.about-social-link:hover{transform:translateY(-2px);background:color-mix(in srgb,var(--color-surface) 80%,transparent);border-color:var(--color-accent);color:var(--color-accent);box-shadow:0 6px 20px rgba(0,0,0,.15)}.about-social-link i{font-size:1.1rem}@media (max-width:640px){.about-hero{padding:2rem 0 3rem}.about-avatar,.about-avatar-placeholder{width:110px;height:110px}.about-avatar-placeholder i{font-size:3rem}.about-title{font-size:2rem}.about-subtitle{font-size:1rem}.about-social{padding:2rem 1.25rem}.about-social-links{flex-direction:column;align-items:stretch}.about-social-link{justify-content:center}.timeline:before{left:12px}.timeline-item{padding-left:40px}.timeline-marker{left:-5px;width:34px;height:34px}.timeline-marker:before{width:12px;height:12px}.timeline-content{padding:1rem}.timeline-content strong{font-size:1rem}.timeline-content em{font-size:.8rem}}.about-alt-page,.page-int{max-width:1200px;margin-inline:auto}.about-alt-layout{display:grid;grid-template-columns:1fr;gap:2rem;padding:2rem 0}@media (min-width:1024px){.about-alt-layout{grid-template-columns:320px 1fr;gap:3rem}}.about-alt-sidebar{position:relative}.about-alt-profile-card{background:linear-gradient(135deg,color-mix(in srgb,var(--color-surface) 70%,transparent),color-mix(in srgb,var(--color-surface) 50%,transparent));border:1px solid color-mix(in srgb,var(--color-border) 60%,transparent);border-radius:1.5rem;padding:2rem;text-align:center;box-shadow:0 8px 24px rgba(0,0,0,.2);position:sticky;top:2rem}.about-alt-avatar,.about-alt-avatar-placeholder{width:120px;height:120px;border-radius:50%;margin:0 auto 1.5rem;overflow:hidden;border:4px solid var(--color-accent);box-shadow:0 0 0 8px color-mix(in srgb,var(--color-accent) 15%,transparent);transition:all .3s ease-out}.about-alt-avatar-placeholder:hover,.about-alt-avatar:hover{transform:scale(1.05);box-shadow:0 0 0 12px color-mix(in srgb,var(--color-accent) 20%,transparent)}.about-alt-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.about-alt-avatar-placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,color-mix(in srgb,var(--color-accent) 30%,transparent),color-mix(in srgb,var(--color-accent) 15%,transparent))}.about-alt-avatar-placeholder i{font-size:3rem;color:var(--color-accent)}.about-alt-name{font-size:1.75rem;font-weight:700;color:var(--color-text);margin-bottom:.5rem}.about-alt-role{font-size:.9rem;color:var(--color-text-muted);line-height:1.5;margin-bottom:1rem}.about-alt-meta{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.85rem;color:var(--color-text-muted);margin-bottom:1.5rem}.about-alt-meta i{color:var(--color-accent)}.about-alt-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:2rem 0;padding:1.5rem 0;border-top:1px solid color-mix(in srgb,var(--color-border) 50%,transparent);border-bottom:1px solid color-mix(in srgb,var(--color-border) 50%,transparent)}.about-alt-stat{text-align:center}.about-alt-stat-value{font-size:1.75rem;font-weight:700;color:var(--color-accent);margin-bottom:.25rem}.about-alt-stat-label{font-size:.7rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.about-alt-social{display:flex;justify-content:center;gap:.75rem;margin-top:1.5rem}.about-alt-social-icon{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:50%;background:color-mix(in srgb,var(--color-bg) 50%,transparent);border:1px solid color-mix(in srgb,var(--color-border) 60%,transparent);color:var(--color-text-muted);transition:all .2s ease-out}.about-alt-social-icon:hover{background:var(--color-accent);border-color:var(--color-accent);color:#fff;transform:translateY(-3px);box-shadow:0 6px 16px rgba(0,0,0,.3)}.about-alt-social-icon i{font-size:1rem}.about-alt-content{display:flex;flex-direction:column;gap:2rem}.about-alt-section{background:color-mix(in srgb,var(--color-surface) 40%,transparent);border:1px solid color-mix(in srgb,var(--color-border) 60%,transparent);border-radius:1.25rem;padding:2rem;box-shadow:0 4px 16px rgba(0,0,0,.15)}.about-alt-section-title{display:flex;align-items:center;gap:.75rem;font-size:1.5rem;font-weight:700;color:var(--color-text);margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid color-mix(in srgb,var(--color-accent) 20%,transparent)}.about-alt-section-title i{color:var(--color-accent);font-size:1.25rem}.about-alt-experience-grid{display:grid;gap:1.5rem}.about-alt-experience-card{background:color-mix(in srgb,var(--color-bg) 40%,transparent);border:1px solid color-mix(in srgb,var(--color-border) 50%,transparent);border-left:4px solid var(--color-accent);border-radius:.85rem;padding:1.5rem;transition:all .3s ease-out;position:relative;overflow:hidden}.about-alt-experience-card:before{content:"";position:absolute;top:0;right:0;width:100px;height:100px;background:radial-gradient(circle at center,color-mix(in srgb,var(--color-accent) 10%,transparent),transparent 70%);opacity:0;transition:opacity .3s ease-out}.about-alt-experience-card:hover{border-left-width:6px;transform:translateX(6px);box-shadow:0 8px 24px rgba(0,0,0,.25)}.about-alt-experience-card:hover:before{opacity:1}.about-alt-experience-card p:first-child{margin-top:0}.about-alt-experience-card p:last-child{margin-bottom:0}.about-alt-experience-card strong{font-size:1.1rem;color:var(--color-text);display:block;margin-bottom:.25rem}.about-alt-experience-card em{font-size:.85rem;color:var(--color-text-muted);font-style:normal;display:block;margin-bottom:.75rem}.about-alt-skills{display:flex;flex-wrap:wrap;gap:.75rem}.about-alt-skill{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:color-mix(in srgb,var(--color-bg) 50%,transparent);border:1px solid color-mix(in srgb,var(--color-border) 60%,transparent);border-radius:999px;font-size:.85rem;font-weight:500;color:var(--color-text);transition:all .2s ease-out;cursor:default}.about-alt-skill i{font-size:1.1em;opacity:.9}.about-alt-skill:hover{background:var(--color-accent);border-color:var(--color-accent);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.2)}.about-alt-skill:hover i{opacity:1}@media (max-width:1023px){.about-alt-profile-card{position:relative;top:0}.about-alt-layout{grid-template-columns:1fr}}@media (max-width:640px){.about-alt-profile-card{padding:1.5rem}.about-alt-avatar,.about-alt-avatar-placeholder{width:100px;height:100px}.about-alt-name{font-size:1.5rem}.about-alt-stats{gap:.75rem}.about-alt-stat-value{font-size:1.5rem}.about-alt-section{padding:1.5rem}.about-alt-section-title{font-size:1.25rem}.about-alt-experience-card,.card-pad{padding:1.25rem}.layout-page{padding-inline:1rem;padding-block:1.5rem}.layout-page-tight{padding-inline:1rem;padding-block:1rem}.markdown-body{font-size:.9rem;padding:0}.markdown-body h1{font-size:1.75rem}.markdown-body h2{font-size:1.35rem;margin-top:2rem}.markdown-body h3{font-size:1.15rem;margin-top:1.5rem}.markdown-body h4{font-size:1rem}.markdown-body h5,.markdown-body h6{font-size:.9rem}.markdown-body .md-heading-anchor:before{left:-1rem;font-size:.85em}.markdown-body .md-blockquote,.markdown-body blockquote{margin:1.25rem 0;padding:1rem;border-left-width:3px}.markdown-body .md-blockquote:before,.markdown-body blockquote:before{font-size:2rem;left:.5rem;top:.25rem}.markdown-body .md-alert{padding:.85rem 1rem .85rem 2.5rem}.markdown-body .md-alert:before{left:.75rem;top:.95rem;font-size:.95rem}.markdown-body ol,.markdown-body ul{padding-left:1.25rem}.markdown-body pre{margin:1rem -1rem;border-radius:.5rem}.markdown-body pre code{font-size:.8rem;padding:1rem}.mb-codeblock{margin:1.25rem -1rem;border-radius:.5rem}.mb-codeblock-content pre{padding:1rem}.mb-codeblock-content pre code{font-size:.8rem}.markdown-body :not(pre)>code{font-size:.85em;padding:.1rem .35rem}.markdown-body table{font-size:.85rem}.markdown-body td,.markdown-body th{padding:.5rem .65rem}.markdown-body .table-wrap{margin:1.25rem -1rem;border-radius:.5rem}.markdown-body .md-image,.markdown-body img{margin:1.25rem 0}.markdown-body .md-image a{border-radius:.5rem}.markdown-body .md-image a:after{font-size:2rem}.markdown-body .md-image figcaption{font-size:.82rem;padding:.4rem .75rem}.heading-page{font-size:1.75rem!important;line-height:1.2}.article-main header{padding:0}.toc-wrapper{border-radius:.75rem;padding:.85rem}.toc-nav{font-size:.85rem}}@media (min-width:641px) and (max-width:1023px){.article-layout{display:flex;flex-wrap:wrap}.article-main{max-width:-webkit-fill-available}.layout-page{padding-inline:1.5rem;padding-block:2rem}.markdown-body{font-size:.93rem}.markdown-body h1{font-size:1.85rem}.markdown-body h2{font-size:1.4rem}.markdown-body h3{font-size:1.2rem}}@media (min-width:1536px){.article-layout{padding-inline:2rem}}@media (min-width:1920px){.markdown-body{font-size:1rem}}@media (hover:none) and (pointer:coarse){.toc-nav a{padding:.5rem .65rem;margin:.15rem 0}.toc-toggle{width:2.5rem;height:2.5rem}.mb-action-btn{padding:.5rem .85rem;font-size:.75rem}.markdown-body li:hover{background:none}.card-hover:hover{transform:none;box-shadow:none}}@media (max-height:500px) and (orientation:landscape){.toc-wrapper{position:relative;top:0}.layout-page{padding-block:1rem}}:root,html[data-theme=dark],html[data-theme=light]{color-scheme:dark;--dt-canvas:#000;--dt-surface-1:#07090e;--dt-surface-2:#121620;--dt-surface-3:#161b26;--dt-text-primary:#fff;--dt-text-secondary:#a1a1aa;--dt-text-muted:#71717a;--dt-border:rgba(39,39,42,.6);--dt-border-strong:rgba(63,63,70,.72);--dt-cyan:#22d3ee;--dt-blue:#3b82f6;--dt-indigo:#6366f1;--dt-yellow:#facc15;--dt-orange:#fb923c;--dt-green:#22c55e;--dt-red:#f43f5e;--dt-purple:#a855f7;--dt-cyan-rgb:34,211,238;--dt-blue-rgb:59,130,246;--dt-indigo-rgb:99,102,241;--dt-yellow-rgb:250,204,21;--dt-orange-rgb:251,146,60;--dt-green-rgb:34,197,94;--dt-red-rgb:244,63,94;--dt-purple-rgb:168,85,247;--color-bg:var(--dt-canvas);--color-surface:var(--dt-surface-1);--color-text:var(--dt-text-primary);--color-text-muted:var(--dt-text-secondary);--color-border:var(--dt-border);--color-accent:var(--dt-cyan);--font-display:"Inter",ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-mono-tech:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace}html{background:var(--dt-canvas)!important;scroll-behavior:smooth}body{min-height:100vh;background:radial-gradient(circle at 12% 8%,rgba(var(--dt-purple-rgb),.09),transparent 28rem),radial-gradient(circle at 88% 12%,rgba(var(--dt-cyan-rgb),.1),transparent 30rem),radial-gradient(circle at 72% 78%,rgba(var(--dt-indigo-rgb),.1),transparent 34rem),var(--dt-canvas)!important;color:var(--dt-text-primary)!important;font-family:var(--font-display)!important;-webkit-font-smoothing:antialiased;text-rendering:geometricPrecision}body:before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.055;background-image:linear-gradient(90deg,#fff 1px,transparent 0),linear-gradient(180deg,#fff 1px,transparent 0);background-size:64px 64px;-webkit-mask-image:radial-gradient(circle at center,#000,transparent 76%);mask-image:radial-gradient(circle at center,#000,transparent 76%)}body>*{position:relative;z-index:1}::-moz-selection{color:#020617;background:var(--dt-cyan)}::selection{color:#020617;background:var(--dt-cyan)}.heading-page,.heading-section,.hero-title,.page-title,.site-title,h1,h2,h3,h4{font-family:var(--font-display)!important;font-weight:800!important;letter-spacing:-.045em!important;color:var(--dt-text-primary)!important}.heading-page,.hero-title,.page-title,h1{font-weight:900!important;line-height:.94!important}.markdown,.prose,li,p{color:var(--dt-text-secondary)}.card-badge,.card-cta,.card-cta-btn,.card-cta-repo,.card-tag-pill,.eyebrow,.font-mono,.footer-small,.nav-link,.post-date,.project-meta,.tech-label,[data-mono=true],code,kbd,pre,samp{font-family:var(--font-mono-tech)!important;letter-spacing:.035em}a{color:color-mix(in srgb,var(--dt-cyan) 92%,#fff);text-decoration-thickness:1px;text-underline-offset:.18em}a:hover{color:#fff;text-shadow:0 0 18px rgba(var(--dt-cyan-rgb),.32)}.layout-page,.layout-page-tight{isolation:isolate}.footer-shell,.nav-shell{border:1px solid var(--dt-border)!important;background:linear-gradient(180deg,rgba(18,22,32,.88),rgba(7,9,14,.82))!important;box-shadow:0 24px 80px rgba(0,0,0,.68),inset 0 1px 0 hsla(0,0%,100%,.045)!important;backdrop-filter:blur(18px) saturate(128%)}.footer-shell:before,.nav-shell:before{background:linear-gradient(90deg,transparent,rgba(var(--dt-cyan-rgb),.62),rgba(var(--dt-indigo-rgb),.44),transparent)!important}.logo-badge{background:linear-gradient(135deg,var(--dt-cyan),var(--dt-indigo))!important;color:#020617!important;box-shadow:0 0 24px rgba(var(--dt-cyan-rgb),.35)}.btn-ghost,.footer-link,.nav-link{color:var(--dt-text-secondary)!important;text-transform:uppercase;letter-spacing:.13em;font-size:.72rem!important}.btn-ghost:hover,.footer-link:hover,.nav-link:hover,.theme-toggle:hover{color:var(--dt-cyan)!important;filter:drop-shadow(0 0 12px rgba(var(--dt-cyan-rgb),.44))}.theme-toggle{border-color:var(--dt-border)!important;background:rgba(18,22,32,.8)!important;color:var(--dt-text-secondary)!important}.btn-primary,button[type=submit],input[type=submit]{color:#020617!important;font-weight:800!important;background:linear-gradient(135deg,var(--dt-cyan),var(--dt-blue),var(--dt-indigo))!important;border:1px solid hsla(0,0%,100%,.1)!important;box-shadow:0 0 28px rgba(var(--dt-cyan-rgb),.28),0 18px 44px rgba(var(--dt-indigo-rgb),.18)!important}.btn-primary:hover,button[type=submit]:hover,input[type=submit]:hover{transform:translateY(-2px)!important;box-shadow:0 0 36px rgba(var(--dt-cyan-rgb),.42),0 22px 60px rgba(var(--dt-indigo-rgb),.28)!important}.card-cta,.card-cta-btn,.card-cta-repo{border-color:var(--dt-border)!important;background:rgba(18,22,32,.68)!important;color:var(--dt-text-secondary)!important}.card-cta-btn:hover,.card-cta-repo:hover,.card-cta:hover{color:var(--dt-cyan)!important;border-color:rgba(var(--dt-cyan-rgb),.44)!important;box-shadow:0 0 22px rgba(var(--dt-cyan-rgb),.16)!important}.card,.card-home,.card-home--post,.card-home--project,.markdown blockquote,.prose blockquote{position:relative;overflow:hidden;border:1px solid var(--dt-border)!important;background:linear-gradient(180deg,rgba(18,22,32,.52),rgba(7,9,14,.96)),var(--dt-surface-1)!important;box-shadow:0 22px 60px rgba(0,0,0,.58),inset 0 1px 0 hsla(0,0%,100%,.035)!important}.card-home--post:after,.card-home--project:before,.card-home:before,.card:before{content:"";position:absolute;inset:-1px;pointer-events:none;border-radius:inherit;background:radial-gradient(circle at 88% 12%,rgba(var(--card-rgb,var(--dt-cyan-rgb)),.18),transparent 12rem),linear-gradient(120deg,hsla(0,0%,100%,.06),transparent 38%);opacity:.42}.card-home--post:hover,.card-home--project:hover,.card-home:hover,.card:hover{transform:translateY(-4px)!important;border-color:rgba(var(--card-rgb,var(--dt-cyan-rgb)),.45)!important;box-shadow:0 28px 80px rgba(0,0,0,.72),0 0 42px rgba(var(--card-rgb,var(--dt-cyan-rgb)),.16),inset 0 1px 0 hsla(0,0%,100%,.06)!important}.card-home-icon{border-color:rgba(var(--card-rgb,var(--dt-cyan-rgb)),.36)!important;background:rgba(0,0,0,.44)!important;color:rgb(var(--card-rgb,var(--dt-cyan-rgb)))!important;box-shadow:0 0 22px rgba(var(--card-rgb,var(--dt-cyan-rgb)),.18)!important}.card-home--post:nth-of-type(7n+1),.card-home--project:nth-of-type(7n+1),.card-home:nth-of-type(7n+1){--card-rgb:var(--dt-cyan-rgb)}.card-home--post:nth-of-type(7n+2),.card-home--project:nth-of-type(7n+2),.card-home:nth-of-type(7n+2){--card-rgb:var(--dt-purple-rgb)}.card-home--post:nth-of-type(7n+3),.card-home--project:nth-of-type(7n+3),.card-home:nth-of-type(7n+3){--card-rgb:var(--dt-yellow-rgb)}.card-home--post:nth-of-type(7n+4),.card-home--project:nth-of-type(7n+4),.card-home:nth-of-type(7n+4){--card-rgb:var(--dt-orange-rgb)}.card-home--post:nth-of-type(7n+5),.card-home--project:nth-of-type(7n+5),.card-home:nth-of-type(7n+5){--card-rgb:var(--dt-green-rgb)}.card-home--post:nth-of-type(7n+6),.card-home--project:nth-of-type(7n+6),.card-home:nth-of-type(7n+6){--card-rgb:var(--dt-red-rgb)}.card-home--post:nth-of-type(7n+7),.card-home--project:nth-of-type(7n+7),.card-home:nth-of-type(7n+7){--card-rgb:var(--dt-indigo-rgb)}.card-badge,.card-badge--soft,.card-tag-pill{border:1px solid rgba(var(--card-rgb,var(--dt-cyan-rgb)),.28)!important;background:rgba(var(--card-rgb,var(--dt-cyan-rgb)),.1)!important;color:rgb(var(--card-rgb,var(--dt-cyan-rgb)))!important;text-transform:uppercase;letter-spacing:.12em;box-shadow:0 0 16px rgba(var(--card-rgb,var(--dt-cyan-rgb)),.1)}.layout-page-tight:first-of-type h1,.layout-page:first-of-type h1,main h1:first-child{max-width:15ch;background:linear-gradient(90deg,#fff 0,var(--dt-cyan) 42%,var(--dt-blue) 66%,var(--dt-indigo) 100%);-webkit-background-clip:text;background-clip:text;color:transparent!important;filter:drop-shadow(0 0 28px rgba(var(--dt-cyan-rgb),.22))}.eyebrow{color:var(--dt-cyan)!important;text-transform:uppercase;filter:drop-shadow(0 0 10px rgba(var(--dt-cyan-rgb),.28))}.skills-grid,.tech-marquee,.tech-marquee-track,.tech-stack{-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}.skill-pill,.tech-pill,[class*=tech] .card-tag-pill{border:1px solid var(--dt-border)!important;background:rgba(18,22,32,.58)!important;color:var(--dt-text-secondary)!important;backdrop-filter:blur(12px)}.skill-pill:hover,.tech-pill:hover{color:var(--dt-cyan)!important;border-color:rgba(var(--dt-cyan-rgb),.44)!important;box-shadow:0 0 22px rgba(var(--dt-cyan-rgb),.14)}.markdown,.prose{--tw-prose-body:var(--dt-text-secondary);--tw-prose-headings:var(--dt-text-primary);--tw-prose-links:var(--dt-cyan);--tw-prose-bold:var(--dt-text-primary);--tw-prose-code:var(--dt-cyan);--tw-prose-quotes:var(--dt-text-primary);--tw-prose-quote-borders:rgba(var(--dt-cyan-rgb),0.42)}.markdown h2,.markdown h3,.prose h2,.prose h3{border-bottom:1px solid var(--dt-border);padding-bottom:.42em}.markdown table,.prose table{overflow:hidden;border:1px solid var(--dt-border)!important;border-radius:1rem;background:var(--dt-surface-1)}.markdown th,.prose th{background:var(--dt-surface-2)!important;color:var(--dt-text-primary)!important;font-family:var(--font-mono-tech)!important;text-transform:uppercase;letter-spacing:.11em}.markdown td,.prose td{border-color:var(--dt-border)!important}.markdown pre,.prose pre,pre{border:1px solid rgba(var(--dt-cyan-rgb),.18)!important;background:radial-gradient(circle at 100% 0,rgba(var(--dt-cyan-rgb),.12),transparent 16rem),#02040a!important;box-shadow:0 0 36px rgba(var(--dt-cyan-rgb),.1)}code:not(pre code){border:1px solid rgba(var(--dt-cyan-rgb),.2);border-radius:.42rem;background:rgba(var(--dt-cyan-rgb),.075);color:var(--dt-cyan);padding:.08rem .34rem}.alert,.callout,.markdown blockquote{border-left:2px solid rgba(var(--callout-rgb,var(--dt-cyan-rgb)),.7)!important;background:radial-gradient(circle at 100% 0,rgba(var(--callout-rgb,var(--dt-cyan-rgb)),.11),transparent 18rem),rgba(7,9,14,.92)!important;box-shadow:0 0 28px rgba(var(--callout-rgb,var(--dt-cyan-rgb)),.09)!important}.alert-note,.callout-note{--callout-rgb:var(--dt-cyan-rgb)}.alert-tip,.callout-tip{--callout-rgb:var(--dt-green-rgb)}.alert-important,.callout-important{--callout-rgb:var(--dt-purple-rgb)}.alert-warning,.callout-warning{--callout-rgb:var(--dt-yellow-rgb)}.alert-danger,.callout-danger{--callout-rgb:var(--dt-red-rgb)}.dialog,.modal,.search-modal,.search-overlay,.search-panel{background:rgba(0,0,0,.72)!important;backdrop-filter:blur(22px) saturate(130%)}.search-box,.search-input,input[type=search],input[type=text],textarea{border:1px solid var(--dt-border)!important;background:rgba(18,22,32,.86)!important;color:var(--dt-text-primary)!important;box-shadow:inset 0 1px 0 hsla(0,0%,100%,.035)}.search-box:focus,.search-input:focus,input[type=search]:focus,input[type=text]:focus,textarea:focus{outline:none!important;border-color:rgba(var(--dt-cyan-rgb),.56)!important;box-shadow:0 0 0 3px rgba(var(--dt-cyan-rgb),.12),0 0 28px rgba(var(--dt-cyan-rgb),.1)!important}.curriculum-hero{position:relative;overflow:hidden;border:1px solid var(--dt-border);border-radius:1.75rem;padding:clamp(2rem,5vw,5rem);background:radial-gradient(circle at 16% 10%,rgba(var(--dt-yellow-rgb),.12),transparent 18rem),radial-gradient(circle at 90% 16%,rgba(var(--dt-purple-rgb),.13),transparent 22rem),linear-gradient(180deg,rgba(18,22,32,.66),rgba(7,9,14,.96));box-shadow:0 32px 100px rgba(0,0,0,.72)}.curriculum-title{max-width:11ch;font-size:clamp(3.2rem,8vw,7.5rem);font-weight:900;line-height:.9;letter-spacing:-.065em;background:linear-gradient(90deg,#fff,var(--dt-yellow),var(--dt-orange),var(--dt-purple));-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 0 30px rgba(var(--dt-orange-rgb),.22))}.curriculum-stats,.jump-nav{display:flex;flex-wrap:wrap;gap:.75rem}.curriculum-stat,.jump-chip,.jump-nav a{display:inline-flex;align-items:center;gap:.5rem;border:1px solid var(--dt-border);border-radius:999px;background:rgba(18,22,32,.68);color:var(--dt-text-secondary);padding:.58rem .9rem;font-family:var(--font-mono-tech);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;text-decoration:none;backdrop-filter:blur(12px)}.jump-chip:hover,.jump-nav a:hover{color:var(--dt-cyan);border-color:rgba(var(--dt-cyan-rgb),.45);box-shadow:0 0 22px rgba(var(--dt-cyan-rgb),.14)}.curriculum-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,18rem),1fr));gap:1rem}.curriculum-card{--card-rgb:var(--dt-cyan-rgb);position:relative;overflow:hidden;border:1px solid var(--dt-border);border-radius:1.25rem;padding:1.25rem;background:linear-gradient(180deg,rgba(18,22,32,.55),rgba(7,9,14,.96));box-shadow:0 22px 70px rgba(0,0,0,.56)}.curriculum-card:after{content:"";position:absolute;top:-5rem;right:-5rem;width:12rem;height:12rem;border-radius:999px;background:rgba(var(--card-rgb),.14);filter:blur(42px);pointer-events:none}.curriculum-card:hover{transform:translateY(-4px);border-color:rgba(var(--card-rgb),.46);box-shadow:0 28px 90px rgba(0,0,0,.72),0 0 40px rgba(var(--card-rgb),.14)}.curriculum-card[data-accent=cyan]{--card-rgb:var(--dt-cyan-rgb)}.curriculum-card[data-accent=indigo]{--card-rgb:var(--dt-indigo-rgb)}.curriculum-card[data-accent=yellow]{--card-rgb:var(--dt-yellow-rgb)}.curriculum-card[data-accent=orange]{--card-rgb:var(--dt-orange-rgb)}.curriculum-card[data-accent=green]{--card-rgb:var(--dt-green-rgb)}.curriculum-card[data-accent=red]{--card-rgb:var(--dt-red-rgb)}.curriculum-card[data-accent=purple]{--card-rgb:var(--dt-purple-rgb)}.curriculum-index{font-size:2.25rem;font-weight:800;letter-spacing:-.05em;filter:drop-shadow(0 0 18px rgba(var(--card-rgb),.34))}.curriculum-index,.curriculum-label{color:rgb(var(--card-rgb));font-family:var(--font-mono-tech)}.curriculum-label{display:inline-flex;border:1px solid rgba(var(--card-rgb),.3);border-radius:999px;background:rgba(var(--card-rgb),.1);padding:.25rem .55rem;font-size:.62rem;text-transform:uppercase;letter-spacing:.12em}.text-gradient-tech{background:linear-gradient(90deg,var(--dt-cyan),var(--dt-blue),var(--dt-indigo));-webkit-background-clip:text;background-clip:text;color:transparent!important;filter:drop-shadow(0 0 22px rgba(var(--dt-cyan-rgb),.24))}.text-gradient-warm{background:linear-gradient(90deg,var(--dt-yellow),var(--dt-orange),var(--dt-red));-webkit-background-clip:text;background-clip:text;color:transparent!important;filter:drop-shadow(0 0 22px rgba(var(--dt-orange-rgb),.24))}.glow-cyan{box-shadow:0 0 34px rgba(var(--dt-cyan-rgb),.24)!important}.glow-indigo{box-shadow:0 0 34px rgba(var(--dt-indigo-rgb),.24)!important}.glow-yellow{box-shadow:0 0 34px rgba(var(--dt-yellow-rgb),.22)!important}.glow-orange{box-shadow:0 0 34px rgba(var(--dt-orange-rgb),.22)!important}.glow-green{box-shadow:0 0 34px rgba(var(--dt-green-rgb),.22)!important}.glow-red{box-shadow:0 0 34px rgba(var(--dt-red-rgb),.22)!important}.glow-purple{box-shadow:0 0 34px rgba(var(--dt-purple-rgb),.22)!important}.hairline{border:1px solid var(--dt-border)!important}.surface-1{background:var(--dt-surface-1)!important}.surface-2{background:var(--dt-surface-2)!important}.surface-3{background:var(--dt-surface-3)!important}@media (max-width:640px){body:before{background-size:44px 44px;opacity:.04}.heading-page,.hero-title,.page-title,h1{letter-spacing:-.055em!important}.curriculum-hero{border-radius:1.25rem;padding:1.5rem}.curriculum-title{font-size:clamp(3rem,17vw,4.5rem)}}.last\:border-0:last-child{border-width:0}.group:hover .group-hover\:text-accent,.hover\:text-accent:hover{color:var(--color-accent)}@media (min-width:640px){.sm\:h-28{height:7rem}.sm\:w-28{width:7rem}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}.sm\:text-3xl{font-size:1.875rem;line-height:2.25rem}.sm\:text-4xl{font-size:2.25rem;line-height:2.5rem}}@media (min-width:768px){.md\:order-none{order:0}.md\:flex{display:flex}.md\:hidden{display:none}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-\[minmax\(0\2c 2fr\)_minmax\(0\2c 1\.2fr\)\]{grid-template-columns:minmax(0,2fr) minmax(0,1.2fr)}.md\:justify-end{justify-content:flex-end}}

/* Blog list cards: keep every post on the same cyan accent as the first card. */
.card-home--post {
  --card-rgb: var(--dt-cyan-rgb) !important;
}

.card-home--post:nth-of-type(even)::before {
  background: #22d3ee !important;
  box-shadow:
    0 0 18px rgba(34, 211, 238, 0.55),
    0 0 34px rgba(34, 211, 238, 0.22) !important;
}

.card-home--post:nth-of-type(even):hover {
  box-shadow:
    0 18px 42px rgba(0, 0, 0, 0.72),
    0 0 32px rgba(34, 211, 238, 0.08) !important;
}

.card-home--post::before {
  background: #22d3ee !important;
  box-shadow:
    0 0 18px rgba(34, 211, 238, 0.55),
    0 0 34px rgba(34, 211, 238, 0.22) !important;
}

.card-home--post:hover {
  box-shadow:
    0 18px 42px rgba(0, 0, 0, 0.72),
    0 0 32px rgba(34, 211, 238, 0.08) !important;
}

/* Blog post pages: disable hover-only motion, glow, and reveal effects. */
.article-layout a:hover {
  text-shadow: none !important;
  filter: none !important;
}

.article-main .card:hover {
  transform: none !important;
  border-color: var(--dt-border) !important;
  box-shadow:
    0 22px 60px rgba(0, 0, 0, 0.58),
    inset 0 1px 0 rgba(255, 255, 255, 0.035) !important;
}

.article-main .markdown-body tbody tr:hover {
  background: transparent !important;
}

.article-main .markdown-body a.md-link[target="_blank"]:hover::after {
  opacity: 0.6 !important;
  transform: none !important;
}

.article-main .markdown-body h1:hover .md-heading-anchor::before,
.article-main .markdown-body h2:hover .md-heading-anchor::before,
.article-main .markdown-body h3:hover .md-heading-anchor::before,
.article-main .markdown-body h4:hover .md-heading-anchor::before,
.article-main .markdown-body h5:hover .md-heading-anchor::before,
.article-main .markdown-body h6:hover .md-heading-anchor::before {
  opacity: 0 !important;
}

.article-main .markdown-body .md-heading-anchor:hover {
  color: inherit !important;
}

.article-main .markdown-body .md-image a:hover {
  transform: none !important;
  border-color: color-mix(in srgb, var(--color-border) 60%, transparent) !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
}

.article-main .markdown-body .md-image a:hover::before,
.article-main .markdown-body .md-image a:hover::after {
  opacity: 0 !important;
}

.article-main .markdown-body .md-image a:hover::after {
  transform: translate(-50%, -50%) scale(0.8) !important;
}

.article-main .markdown-body .md-image a:hover img {
  filter: none !important;
}

.article-main .mb-codeblock:hover {
  box-shadow:
    0 4px 6px rgba(0, 0, 0, 0.1),
    0 10px 20px rgba(0, 0, 0, 0.15) !important;
}

html[data-theme="light"] .article-main .mb-codeblock:hover {
  box-shadow:
    0 2px 4px rgba(0, 0, 0, 0.05),
    0 4px 8px rgba(0, 0, 0, 0.08) !important;
}

.article-main .mb-action-btn:hover,
.article-main .mb-expand-trigger:hover {
  transform: none !important;
  box-shadow: none !important;
}

/* Blog post TOC: pin near the viewport top and fill the viewport height. */
.article-toc {
  align-self: stretch;
}

.article-toc .toc-wrapper {
  top: 1.5rem !important;
  height: calc(100vh - 3rem) !important;
  max-height: calc(100vh - 3rem) !important;
}

.article-toc .toc-wrapper.collapsed {
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
}

.article-toc .toc-wrapper.collapsed .toc-header {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
  border-bottom-color: transparent !important;
}

.article-toc .toc-nav a.active {
  color: #ffffff !important;
}

/* Single post title: use the full article column up to the TOC sidebar. */
.article-main > header h1.heading-page {
  max-width: none !important;
  width: 100% !important;
}

@media (max-width: 1023px) {
  .article-toc {
    display: none !important;
  }

  .article-main {
    flex: none !important;
    min-width: 0 !important;
    width: 100%;
  }
}

/* Bright theme: give the light toggle a full, readable daytime palette. */
html[data-theme="light"] {
  color-scheme: light;
  --dt-canvas: #f6fbff;
  --dt-surface-1: #ffffff;
  --dt-surface-2: #edf7fb;
  --dt-surface-3: #dff1f7;
  --dt-text-primary: #0f172a;
  --dt-text-secondary: #475569;
  --dt-text-muted: #64748b;
  --dt-border: rgba(15, 23, 42, 0.12);
  --dt-border-strong: rgba(15, 23, 42, 0.2);
  --dt-cyan: #0891b2;
  --dt-blue: #2563eb;
  --dt-indigo: #4f46e5;
  --dt-yellow: #ca8a04;
  --dt-orange: #ea580c;
  --dt-green: #16a34a;
  --dt-red: #e11d48;
  --dt-purple: #7c3aed;
  --dt-cyan-rgb: 8, 145, 178;
  --dt-blue-rgb: 37, 99, 235;
  --dt-indigo-rgb: 79, 70, 229;
  --dt-yellow-rgb: 202, 138, 4;
  --dt-orange-rgb: 234, 88, 12;
  --dt-green-rgb: 22, 163, 74;
  --dt-red-rgb: 225, 29, 72;
  --dt-purple-rgb: 124, 58, 237;
  --color-bg: var(--dt-canvas);
  --color-surface: var(--dt-surface-1);
  --color-text: var(--dt-text-primary);
  --color-text-muted: var(--dt-text-secondary);
  --color-border: var(--dt-border);
  --color-accent: var(--dt-cyan);
}

html[data-theme="light"],
html[data-theme="light"] body {
  background-color: var(--dt-canvas) !important;
}

html[data-theme="light"] body {
  background:
    radial-gradient(circle at 12% 8%, rgba(var(--dt-purple-rgb), 0.08), transparent 28rem),
    radial-gradient(circle at 88% 12%, rgba(var(--dt-cyan-rgb), 0.13), transparent 30rem),
    linear-gradient(180deg, #ffffff 0%, #eef8fc 100%) !important;
  color: var(--dt-text-primary) !important;
}

html[data-theme="light"] body::before {
  opacity: 0.16;
  background-image:
    linear-gradient(90deg, rgba(15, 23, 42, 0.18) 1px, transparent 0),
    linear-gradient(180deg, rgba(15, 23, 42, 0.18) 1px, transparent 0);
}

html[data-theme="light"] ::selection {
  color: #ffffff;
  background: var(--dt-cyan);
}

html[data-theme="light"] .markdown,
html[data-theme="light"] .prose,
html[data-theme="light"] li,
html[data-theme="light"] p {
  color: var(--dt-text-secondary);
}

html[data-theme="light"] .heading-page,
html[data-theme="light"] .heading-section,
html[data-theme="light"] .hero-title,
html[data-theme="light"] .page-title,
html[data-theme="light"] .site-title,
html[data-theme="light"] h1,
html[data-theme="light"] h2,
html[data-theme="light"] h3,
html[data-theme="light"] h4 {
  color: var(--dt-text-primary) !important;
}

html[data-theme="light"] .layout-page-tight:first-of-type h1,
html[data-theme="light"] .layout-page:first-of-type h1,
html[data-theme="light"] main h1:first-child {
  background: linear-gradient(90deg, #0f172a 0, var(--dt-cyan) 42%, var(--dt-blue) 66%, var(--dt-indigo) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  filter: drop-shadow(0 8px 18px rgba(var(--dt-cyan-rgb), 0.12));
}

html[data-theme="light"] a {
  color: #0e7490;
}

html[data-theme="light"] a:hover {
  color: #0f172a;
  text-shadow: none;
}

html[data-theme="light"] .footer-shell,
html[data-theme="light"] .nav-shell {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(241, 248, 252, 0.88)) !important;
  border-color: var(--dt-border) !important;
  box-shadow:
    0 18px 52px rgba(15, 23, 42, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.82) !important;
}

html[data-theme="light"] .theme-toggle,
html[data-theme="light"] .dock-action,
html[data-theme="light"] .dock-toggle {
  background: rgba(255, 255, 255, 0.84) !important;
  border-color: var(--dt-border) !important;
  color: var(--dt-text-secondary) !important;
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.08) !important;
}

html[data-theme="light"] .btn-ghost,
html[data-theme="light"] .footer-link,
html[data-theme="light"] .nav-link {
  color: var(--dt-text-secondary) !important;
}

html[data-theme="light"] .btn-ghost:hover,
html[data-theme="light"] .footer-link:hover,
html[data-theme="light"] .nav-link:hover,
html[data-theme="light"] .theme-toggle:hover {
  color: var(--dt-cyan) !important;
  filter: none;
}

html[data-theme="light"] .card,
html[data-theme="light"] .card-home,
html[data-theme="light"] .card-home--post,
html[data-theme="light"] .card-home--project,
html[data-theme="light"] .markdown blockquote,
html[data-theme="light"] .prose blockquote {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.9), rgba(241, 248, 252, 0.96)), var(--dt-surface-1) !important;
  border-color: var(--dt-border) !important;
  box-shadow:
    0 18px 44px rgba(15, 23, 42, 0.1),
    inset 0 1px 0 rgba(255, 255, 255, 0.85) !important;
}

html[data-theme="light"] .card-home--post:hover,
html[data-theme="light"] .card-home--project:hover,
html[data-theme="light"] .card-home:hover,
html[data-theme="light"] .card:hover {
  border-color: rgba(var(--card-rgb, var(--dt-cyan-rgb)), 0.34) !important;
  box-shadow:
    0 22px 54px rgba(15, 23, 42, 0.13),
    0 0 30px rgba(var(--card-rgb, var(--dt-cyan-rgb)), 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.9) !important;
}

html[data-theme="light"] .article-main .card:hover {
  transform: none !important;
  border-color: var(--dt-border) !important;
  box-shadow:
    0 18px 44px rgba(15, 23, 42, 0.1),
    inset 0 1px 0 rgba(255, 255, 255, 0.85) !important;
}

html[data-theme="light"] .card-home--post::before,
html[data-theme="light"] .card-home--post:nth-of-type(even)::before {
  background: var(--dt-cyan) !important;
  box-shadow:
    0 0 18px rgba(var(--dt-cyan-rgb), 0.36),
    0 0 34px rgba(var(--dt-cyan-rgb), 0.14) !important;
}

html[data-theme="light"] .card-home-icon {
  background: rgba(255, 255, 255, 0.72) !important;
  border-color: rgba(var(--card-rgb, var(--dt-cyan-rgb)), 0.26) !important;
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.08) !important;
}

html[data-theme="light"] .card-badge,
html[data-theme="light"] .card-badge--soft,
html[data-theme="light"] .card-tag-pill,
html[data-theme="light"] .skill-pill,
html[data-theme="light"] .tech-pill {
  background: rgba(var(--card-rgb, var(--dt-cyan-rgb)), 0.08) !important;
  border-color: rgba(var(--card-rgb, var(--dt-cyan-rgb)), 0.22) !important;
  color: rgb(var(--card-rgb, var(--dt-cyan-rgb))) !important;
  box-shadow: none;
}

html[data-theme="light"] .card-cta,
html[data-theme="light"] .card-cta-btn,
html[data-theme="light"] .card-cta-repo {
  background: rgba(255, 255, 255, 0.72) !important;
  border-color: var(--dt-border) !important;
  color: var(--dt-text-secondary) !important;
}

html[data-theme="light"] .card-cta-btn:hover,
html[data-theme="light"] .card-cta-repo:hover,
html[data-theme="light"] .card-cta:hover {
  color: var(--dt-cyan) !important;
  border-color: rgba(var(--dt-cyan-rgb), 0.36) !important;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.1) !important;
}

html[data-theme="light"] .markdown h2,
html[data-theme="light"] .markdown h3,
html[data-theme="light"] .prose h2,
html[data-theme="light"] .prose h3 {
  border-bottom-color: var(--dt-border);
}

html[data-theme="light"] .markdown table,
html[data-theme="light"] .prose table {
  background: var(--dt-surface-1);
}

html[data-theme="light"] .markdown th,
html[data-theme="light"] .prose th {
  background: var(--dt-surface-2) !important;
}

html[data-theme="light"] .markdown pre,
html[data-theme="light"] .prose pre,
html[data-theme="light"] pre {
  background: radial-gradient(circle at 100% 0, rgba(var(--dt-cyan-rgb), 0.08), transparent 16rem), #f8fafc !important;
  border-color: rgba(var(--dt-cyan-rgb), 0.18) !important;
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.08);
}

html[data-theme="light"] code:not(pre code) {
  background: rgba(var(--dt-cyan-rgb), 0.08);
  border-color: rgba(var(--dt-cyan-rgb), 0.18);
  color: #0e7490;
}

html[data-theme="light"] .alert,
html[data-theme="light"] .callout,
html[data-theme="light"] .markdown blockquote {
  background: radial-gradient(circle at 100% 0, rgba(var(--callout-rgb, var(--dt-cyan-rgb)), 0.08), transparent 18rem), rgba(255, 255, 255, 0.9) !important;
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.08) !important;
}

html[data-theme="light"] .search-box,
html[data-theme="light"] .search-input,
html[data-theme="light"] input[type="search"],
html[data-theme="light"] input[type="text"],
html[data-theme="light"] textarea {
  background: rgba(255, 255, 255, 0.9) !important;
  color: var(--dt-text-primary) !important;
}

html[data-theme="light"] .toc-wrapper {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(241, 248, 252, 0.92)) !important;
  border-color: var(--dt-border) !important;
  box-shadow: 0 18px 44px rgba(15, 23, 42, 0.1) !important;
}

html[data-theme="light"] .toc-nav a {
  color: var(--dt-text-secondary) !important;
}

html[data-theme="light"] .toc-nav a:hover,
html[data-theme="light"] .toc-nav a.active {
  color: #ffffff !important;
  background: rgba(var(--dt-cyan-rgb), 0.88) !important;
  box-shadow: 0 8px 22px rgba(var(--dt-cyan-rgb), 0.18) !important;
}

/* Bright theme contrast fixes for older dark-mode utility overrides. */
html[data-theme="light"] {
  --dt-text-secondary: #334155;
  --dt-text-muted: #475569;
}

html[data-theme="light"] .nav-shell .nav-inner > a:first-child,
html[data-theme="light"] .nav-shell a:first-child,
html[data-theme="light"] header .nav-inner > a:first-child,
html[data-theme="light"] header a[href="/"]:first-child,
html[data-theme="light"] header a[href="./"]:first-child,
html[data-theme="light"] .nav-shell .nav-inner > a:first-child span:not(.logo-badge),
html[data-theme="light"] header .nav-inner > a:first-child span:not(.logo-badge) {
  color: var(--dt-text-primary) !important;
  -webkit-text-fill-color: var(--dt-text-primary) !important;
  text-shadow: none !important;
}

html[data-theme="light"] main h1:first-of-type,
html[data-theme="light"] .layout-page h1:first-of-type,
html[data-theme="light"] .layout-page-tight h1:first-of-type {
  color: var(--dt-text-primary) !important;
  -webkit-text-fill-color: var(--dt-text-primary) !important;
  background: none !important;
  background-image: none !important;
  text-shadow: none !important;
  filter: none !important;
}

html[data-theme="light"] main h1:first-of-type + p,
html[data-theme="light"] .layout-page h1:first-of-type + p,
html[data-theme="light"] .layout-page-tight h1:first-of-type + p,
html[data-theme="light"] .text-muted,
html[data-theme="light"] .post-date,
html[data-theme="light"] .project-meta,
html[data-theme="light"] .footer-small,
html[data-theme="light"] .card-home p,
html[data-theme="light"] .card-home-body p,
html[data-theme="light"] .markdown-body,
html[data-theme="light"] .markdown-body p,
html[data-theme="light"] .markdown-body li,
html[data-theme="light"] .toc-nav a {
  color: var(--dt-text-secondary) !important;
  -webkit-text-fill-color: currentColor !important;
}

html[data-theme="light"] .card-home h2,
html[data-theme="light"] .card-home h3,
html[data-theme="light"] .card-home .font-semibold,
html[data-theme="light"] .card-home--post .font-semibold,
html[data-theme="light"] .card-home--project .font-semibold,
html[data-theme="light"] .markdown-body h1,
html[data-theme="light"] .markdown-body h2,
html[data-theme="light"] .markdown-body h3,
html[data-theme="light"] .markdown-body h4,
html[data-theme="light"] .markdown-body strong {
  color: var(--dt-text-primary) !important;
  -webkit-text-fill-color: var(--dt-text-primary) !important;
}

html[data-theme="light"] .badge-available,
html[data-theme="light"] span.badge-available,
html[data-theme="light"] .badge-available span,
html[data-theme="light"] span.badge-available span {
  color: #075985 !important;
  -webkit-text-fill-color: #075985 !important;
  text-shadow: none !important;
}

html[data-theme="light"] .badge-available span:first-child,
html[data-theme="light"] span.badge-available span:first-child {
  background: var(--dt-cyan) !important;
  box-shadow: 0 0 10px rgba(var(--dt-cyan-rgb), 0.32) !important;
}

html[data-theme="light"] .toc-nav a.active,
html[data-theme="light"] .toc-nav a:hover {
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
}

/* Markdown bold spacing: render one visual space around **bold** text in body copy. */
.markdown-body p strong::before,
.markdown-body li strong::before,
.markdown-body blockquote strong::before,
.markdown-body dd strong::before,
.markdown-body td strong::before,
.markdown-body figcaption strong::before {
  content: "\00a0";
}

.markdown-body p strong::after,
.markdown-body li strong::after,
.markdown-body blockquote strong::after,
.markdown-body dd strong::after,
.markdown-body td strong::after,
.markdown-body figcaption strong::after {
  content: "\00a0";
}
